@stefaninigo/core 0.9.0
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/README.md +73 -0
- package/dist/libs/stefaninigo/cache/cache-service.interface.d.ts +6 -0
- package/dist/libs/stefaninigo/cache/cache-service.interface.js +3 -0
- package/dist/libs/stefaninigo/cache/cache-service.interface.js.map +1 -0
- package/dist/libs/stefaninigo/cache/cache.module.d.ts +19 -0
- package/dist/libs/stefaninigo/cache/cache.module.js +52 -0
- package/dist/libs/stefaninigo/cache/cache.module.js.map +1 -0
- package/dist/libs/stefaninigo/cache/index.d.ts +2 -0
- package/dist/libs/stefaninigo/cache/index.js +19 -0
- package/dist/libs/stefaninigo/cache/index.js.map +1 -0
- package/dist/libs/stefaninigo/cache/local/loca.service.d.ts +12 -0
- package/dist/libs/stefaninigo/cache/local/loca.service.js +30 -0
- package/dist/libs/stefaninigo/cache/local/loca.service.js.map +1 -0
- package/dist/libs/stefaninigo/cache/redis/redis.service.d.ts +12 -0
- package/dist/libs/stefaninigo/cache/redis/redis.service.js +80 -0
- package/dist/libs/stefaninigo/cache/redis/redis.service.js.map +1 -0
- package/dist/libs/stefaninigo/config/config.service.d.ts +20 -0
- package/dist/libs/stefaninigo/config/config.service.js +113 -0
- package/dist/libs/stefaninigo/config/config.service.js.map +1 -0
- package/dist/libs/stefaninigo/config/index.d.ts +1 -0
- package/dist/libs/stefaninigo/config/index.js +18 -0
- package/dist/libs/stefaninigo/config/index.js.map +1 -0
- package/dist/libs/stefaninigo/core/bootstrap/bootstrap.helpers.d.ts +15 -0
- package/dist/libs/stefaninigo/core/bootstrap/bootstrap.helpers.js +32 -0
- package/dist/libs/stefaninigo/core/bootstrap/bootstrap.helpers.js.map +1 -0
- package/dist/libs/stefaninigo/core/bootstrap/index.d.ts +1 -0
- package/dist/libs/stefaninigo/core/bootstrap/index.js +18 -0
- package/dist/libs/stefaninigo/core/bootstrap/index.js.map +1 -0
- package/dist/libs/stefaninigo/core/dtos/index.d.ts +1 -0
- package/dist/libs/stefaninigo/core/dtos/index.js +18 -0
- package/dist/libs/stefaninigo/core/dtos/index.js.map +1 -0
- package/dist/libs/stefaninigo/core/dtos/problem-details.dto.d.ts +13 -0
- package/dist/libs/stefaninigo/core/dtos/problem-details.dto.js +84 -0
- package/dist/libs/stefaninigo/core/dtos/problem-details.dto.js.map +1 -0
- package/dist/libs/stefaninigo/core/errors/bad-request.error.d.ts +4 -0
- package/dist/libs/stefaninigo/core/errors/bad-request.error.js +12 -0
- package/dist/libs/stefaninigo/core/errors/bad-request.error.js.map +1 -0
- package/dist/libs/stefaninigo/core/errors/conflict.error.d.ts +4 -0
- package/dist/libs/stefaninigo/core/errors/conflict.error.js +12 -0
- package/dist/libs/stefaninigo/core/errors/conflict.error.js.map +1 -0
- package/dist/libs/stefaninigo/core/errors/forbidden.error.d.ts +4 -0
- package/dist/libs/stefaninigo/core/errors/forbidden.error.js +12 -0
- package/dist/libs/stefaninigo/core/errors/forbidden.error.js.map +1 -0
- package/dist/libs/stefaninigo/core/errors/http.error.d.ts +6 -0
- package/dist/libs/stefaninigo/core/errors/http.error.js +13 -0
- package/dist/libs/stefaninigo/core/errors/http.error.js.map +1 -0
- package/dist/libs/stefaninigo/core/errors/index.d.ts +7 -0
- package/dist/libs/stefaninigo/core/errors/index.js +24 -0
- package/dist/libs/stefaninigo/core/errors/index.js.map +1 -0
- package/dist/libs/stefaninigo/core/errors/internal-server.error.d.ts +4 -0
- package/dist/libs/stefaninigo/core/errors/internal-server.error.js +12 -0
- package/dist/libs/stefaninigo/core/errors/internal-server.error.js.map +1 -0
- package/dist/libs/stefaninigo/core/errors/not-found.error.d.ts +4 -0
- package/dist/libs/stefaninigo/core/errors/not-found.error.js +12 -0
- package/dist/libs/stefaninigo/core/errors/not-found.error.js.map +1 -0
- package/dist/libs/stefaninigo/core/errors/unauthorized.error.d.ts +4 -0
- package/dist/libs/stefaninigo/core/errors/unauthorized.error.js +12 -0
- package/dist/libs/stefaninigo/core/errors/unauthorized.error.js.map +1 -0
- package/dist/libs/stefaninigo/core/health/health.controller.d.ts +9 -0
- package/dist/libs/stefaninigo/core/health/health.controller.js +73 -0
- package/dist/libs/stefaninigo/core/health/health.controller.js.map +1 -0
- package/dist/libs/stefaninigo/core/health/health.module.d.ts +9 -0
- package/dist/libs/stefaninigo/core/health/health.module.js +56 -0
- package/dist/libs/stefaninigo/core/health/health.module.js.map +1 -0
- package/dist/libs/stefaninigo/core/health/health.service.d.ts +16 -0
- package/dist/libs/stefaninigo/core/health/health.service.js +143 -0
- package/dist/libs/stefaninigo/core/health/health.service.js.map +1 -0
- package/dist/libs/stefaninigo/core/health/health.types.d.ts +56 -0
- package/dist/libs/stefaninigo/core/health/health.types.js +6 -0
- package/dist/libs/stefaninigo/core/health/health.types.js.map +1 -0
- package/dist/libs/stefaninigo/core/health/index.d.ts +4 -0
- package/dist/libs/stefaninigo/core/health/index.js +21 -0
- package/dist/libs/stefaninigo/core/health/index.js.map +1 -0
- package/dist/libs/stefaninigo/core/index.d.ts +6 -0
- package/dist/libs/stefaninigo/core/index.js +23 -0
- package/dist/libs/stefaninigo/core/index.js.map +1 -0
- package/dist/libs/stefaninigo/core/interceptors/index.d.ts +3 -0
- package/dist/libs/stefaninigo/core/interceptors/index.js +20 -0
- package/dist/libs/stefaninigo/core/interceptors/index.js.map +1 -0
- package/dist/libs/stefaninigo/core/interceptors/logging.interceptor.d.ts +10 -0
- package/dist/libs/stefaninigo/core/interceptors/logging.interceptor.js +88 -0
- package/dist/libs/stefaninigo/core/interceptors/logging.interceptor.js.map +1 -0
- package/dist/libs/stefaninigo/core/interceptors/problem-details.interceptor.d.ts +18 -0
- package/dist/libs/stefaninigo/core/interceptors/problem-details.interceptor.js +227 -0
- package/dist/libs/stefaninigo/core/interceptors/problem-details.interceptor.js.map +1 -0
- package/dist/libs/stefaninigo/core/interceptors/response.interceptor.d.ts +6 -0
- package/dist/libs/stefaninigo/core/interceptors/response.interceptor.js +89 -0
- package/dist/libs/stefaninigo/core/interceptors/response.interceptor.js.map +1 -0
- package/dist/libs/stefaninigo/core/middleware/index.d.ts +1 -0
- package/dist/libs/stefaninigo/core/middleware/index.js +18 -0
- package/dist/libs/stefaninigo/core/middleware/index.js.map +1 -0
- package/dist/libs/stefaninigo/core/middleware/trace-id.middleware.d.ts +5 -0
- package/dist/libs/stefaninigo/core/middleware/trace-id.middleware.js +24 -0
- package/dist/libs/stefaninigo/core/middleware/trace-id.middleware.js.map +1 -0
- package/dist/libs/stefaninigo/database/database-service.interface.d.ts +58 -0
- package/dist/libs/stefaninigo/database/database-service.interface.js +19 -0
- package/dist/libs/stefaninigo/database/database-service.interface.js.map +1 -0
- package/dist/libs/stefaninigo/database/database.module.d.ts +21 -0
- package/dist/libs/stefaninigo/database/database.module.js +58 -0
- package/dist/libs/stefaninigo/database/database.module.js.map +1 -0
- package/dist/libs/stefaninigo/database/dynamodb/dynamodb.service.d.ts +35 -0
- package/dist/libs/stefaninigo/database/dynamodb/dynamodb.service.js +203 -0
- package/dist/libs/stefaninigo/database/dynamodb/dynamodb.service.js.map +1 -0
- package/dist/libs/stefaninigo/database/index.d.ts +2 -0
- package/dist/libs/stefaninigo/database/index.js +19 -0
- package/dist/libs/stefaninigo/database/index.js.map +1 -0
- package/dist/libs/stefaninigo/database/mongodb/mongodb.service.d.ts +43 -0
- package/dist/libs/stefaninigo/database/mongodb/mongodb.service.js +353 -0
- package/dist/libs/stefaninigo/database/mongodb/mongodb.service.js.map +1 -0
- package/dist/libs/stefaninigo/database/postgresdb/postgresdb.services.d.ts +32 -0
- package/dist/libs/stefaninigo/database/postgresdb/postgresdb.services.js +289 -0
- package/dist/libs/stefaninigo/database/postgresdb/postgresdb.services.js.map +1 -0
- package/dist/libs/stefaninigo/events/index.d.ts +1 -0
- package/dist/libs/stefaninigo/events/index.js +18 -0
- package/dist/libs/stefaninigo/events/index.js.map +1 -0
- package/dist/libs/stefaninigo/events/types/domain-events.d.ts +152 -0
- package/dist/libs/stefaninigo/events/types/domain-events.js +3 -0
- package/dist/libs/stefaninigo/events/types/domain-events.js.map +1 -0
- package/dist/libs/stefaninigo/geo/index.d.ts +2 -0
- package/dist/libs/stefaninigo/geo/index.js +19 -0
- package/dist/libs/stefaninigo/geo/index.js.map +1 -0
- package/dist/libs/stefaninigo/geo/types/geo.types.d.ts +27 -0
- package/dist/libs/stefaninigo/geo/types/geo.types.js +3 -0
- package/dist/libs/stefaninigo/geo/types/geo.types.js.map +1 -0
- package/dist/libs/stefaninigo/geo/utils/geo.utils.d.ts +8 -0
- package/dist/libs/stefaninigo/geo/utils/geo.utils.js +54 -0
- package/dist/libs/stefaninigo/geo/utils/geo.utils.js.map +1 -0
- package/dist/libs/stefaninigo/index.d.ts +10 -0
- package/dist/libs/stefaninigo/index.js +26 -0
- package/dist/libs/stefaninigo/index.js.map +1 -0
- package/dist/libs/stefaninigo/messaging/index.d.ts +2 -0
- package/dist/libs/stefaninigo/messaging/index.js +19 -0
- package/dist/libs/stefaninigo/messaging/index.js.map +1 -0
- package/dist/libs/stefaninigo/messaging/messagin-service.interface.d.ts +8 -0
- package/dist/libs/stefaninigo/messaging/messagin-service.interface.js +3 -0
- package/dist/libs/stefaninigo/messaging/messagin-service.interface.js.map +1 -0
- package/dist/libs/stefaninigo/messaging/messagin.module.d.ts +19 -0
- package/dist/libs/stefaninigo/messaging/messagin.module.js +52 -0
- package/dist/libs/stefaninigo/messaging/messagin.module.js.map +1 -0
- package/dist/libs/stefaninigo/messaging/sns/sns.service.d.ts +16 -0
- package/dist/libs/stefaninigo/messaging/sns/sns.service.js +62 -0
- package/dist/libs/stefaninigo/messaging/sns/sns.service.js.map +1 -0
- package/dist/libs/stefaninigo/messaging/sqs/sqs.service.d.ts +23 -0
- package/dist/libs/stefaninigo/messaging/sqs/sqs.service.js +64 -0
- package/dist/libs/stefaninigo/messaging/sqs/sqs.service.js.map +1 -0
- package/dist/libs/stefaninigo/storage/index.d.ts +2 -0
- package/dist/libs/stefaninigo/storage/index.js +19 -0
- package/dist/libs/stefaninigo/storage/index.js.map +1 -0
- package/dist/libs/stefaninigo/storage/s3/s3-services.d.ts +25 -0
- package/dist/libs/stefaninigo/storage/s3/s3-services.js +137 -0
- package/dist/libs/stefaninigo/storage/s3/s3-services.js.map +1 -0
- package/dist/libs/stefaninigo/storage/storage.interface.d.ts +8 -0
- package/dist/libs/stefaninigo/storage/storage.interface.js +3 -0
- package/dist/libs/stefaninigo/storage/storage.interface.js.map +1 -0
- package/dist/libs/stefaninigo/storage/storage.module.d.ts +18 -0
- package/dist/libs/stefaninigo/storage/storage.module.js +49 -0
- package/dist/libs/stefaninigo/storage/storage.module.js.map +1 -0
- package/dist/libs/stefaninigo/transport/http/http-request.builder.d.ts +15 -0
- package/dist/libs/stefaninigo/transport/http/http-request.builder.js +71 -0
- package/dist/libs/stefaninigo/transport/http/http-request.builder.js.map +1 -0
- package/dist/libs/stefaninigo/transport/http/http-transport.service.d.ts +10 -0
- package/dist/libs/stefaninigo/transport/http/http-transport.service.js +43 -0
- package/dist/libs/stefaninigo/transport/http/http-transport.service.js.map +1 -0
- package/dist/libs/stefaninigo/transport/http/http.interface.d.ts +19 -0
- package/dist/libs/stefaninigo/transport/http/http.interface.js +3 -0
- package/dist/libs/stefaninigo/transport/http/http.interface.js.map +1 -0
- package/dist/libs/stefaninigo/transport/index.d.ts +2 -0
- package/dist/libs/stefaninigo/transport/index.js +19 -0
- package/dist/libs/stefaninigo/transport/index.js.map +1 -0
- package/dist/libs/stefaninigo/transport/transport.interface.d.ts +11 -0
- package/dist/libs/stefaninigo/transport/transport.interface.js +3 -0
- package/dist/libs/stefaninigo/transport/transport.interface.js.map +1 -0
- package/dist/libs/stefaninigo/transport/trasnport.module.d.ts +24 -0
- package/dist/libs/stefaninigo/transport/trasnport.module.js +62 -0
- package/dist/libs/stefaninigo/transport/trasnport.module.js.map +1 -0
- package/dist/libs/stefaninigo/transport/web-socket/aws/aws-ws-transport.service.d.ts +20 -0
- package/dist/libs/stefaninigo/transport/web-socket/aws/aws-ws-transport.service.js +178 -0
- package/dist/libs/stefaninigo/transport/web-socket/aws/aws-ws-transport.service.js.map +1 -0
- package/package.json +98 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../libs/stefaninigo/src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4CAA0B;AAC1B,0CAAwB;AACxB,6CAA2B;AAC3B,8CAA4B;AAC5B,2CAAyB;AACzB,8CAA4B;AAC5B,wCAAsB;AACtB,2CAAyB;AACzB,yCAAuB"}
|
|
@@ -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("./messagin.module"), exports);
|
|
18
|
+
__exportStar(require("./messagin-service.interface"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../libs/stefaninigo/src/messaging/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAiC;AACjC,+DAA4C"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface MessagingServiceSQS {
|
|
2
|
+
publish(message: string, topicOrQueueName: string, options?: object): Promise<void>;
|
|
3
|
+
subscribe(queueName: string, handler: (message: string) => void): Promise<void>;
|
|
4
|
+
}
|
|
5
|
+
export interface MessagingServiceSNS {
|
|
6
|
+
publish(message: string, topicOrQueueName: string, options?: object): Promise<void>;
|
|
7
|
+
subscribe(topicArn: string, protocol: 'http' | 'https' | 'email' | 'sms', endpoint: string, options?: object, handler?: (message: string) => void): Promise<void>;
|
|
8
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"messagin-service.interface.js","sourceRoot":"","sources":["../../../../libs/stefaninigo/src/messaging/messagin-service.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { DynamicModule } from '@nestjs/common';
|
|
2
|
+
import { MessagingServiceSQS, MessagingServiceSNS } from "./messagin-service.interface";
|
|
3
|
+
declare const messagingStrategies: {
|
|
4
|
+
[key: string]: new (config: {
|
|
5
|
+
[key: string]: any;
|
|
6
|
+
}) => MessagingServiceSQS | MessagingServiceSNS;
|
|
7
|
+
};
|
|
8
|
+
interface MessagingProviderConfig {
|
|
9
|
+
name: string;
|
|
10
|
+
provider: keyof typeof messagingStrategies;
|
|
11
|
+
}
|
|
12
|
+
export declare class MessagingModule {
|
|
13
|
+
static PROVIDERS: {
|
|
14
|
+
SQS: string;
|
|
15
|
+
SNS: string;
|
|
16
|
+
};
|
|
17
|
+
static forRootAsync(providers: MessagingProviderConfig[]): DynamicModule;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,52 @@
|
|
|
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 MessagingModule_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.MessagingModule = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const sqs_service_1 = require("./sqs/sqs.service");
|
|
13
|
+
const sns_service_1 = require("./sns/sns.service");
|
|
14
|
+
const config_1 = require("../config");
|
|
15
|
+
const config_2 = require("@nestjs/config");
|
|
16
|
+
const PROVIDERS = {
|
|
17
|
+
SQS: 'SQS',
|
|
18
|
+
SNS: 'SNS',
|
|
19
|
+
};
|
|
20
|
+
const messagingStrategies = {
|
|
21
|
+
[PROVIDERS.SQS]: sqs_service_1.SQSMessagingService,
|
|
22
|
+
[PROVIDERS.SNS]: sns_service_1.SNSMessagingService,
|
|
23
|
+
};
|
|
24
|
+
let MessagingModule = MessagingModule_1 = class MessagingModule {
|
|
25
|
+
static forRootAsync(providers) {
|
|
26
|
+
const asyncProviders = providers.map(({ name, provider }) => {
|
|
27
|
+
const MessagingServiceClass = messagingStrategies[provider];
|
|
28
|
+
if (!MessagingServiceClass) {
|
|
29
|
+
throw new Error(`Unknown messaging provider: ${provider}`);
|
|
30
|
+
}
|
|
31
|
+
return {
|
|
32
|
+
provide: name,
|
|
33
|
+
useFactory: async (configService) => new MessagingServiceClass(configService.messagin.getConfig(provider)),
|
|
34
|
+
inject: [config_1.StefaniniGoConfigService, config_2.ConfigService],
|
|
35
|
+
};
|
|
36
|
+
});
|
|
37
|
+
return {
|
|
38
|
+
module: MessagingModule_1,
|
|
39
|
+
providers: asyncProviders,
|
|
40
|
+
exports: asyncProviders,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
exports.MessagingModule = MessagingModule;
|
|
45
|
+
MessagingModule.PROVIDERS = PROVIDERS;
|
|
46
|
+
exports.MessagingModule = MessagingModule = MessagingModule_1 = __decorate([
|
|
47
|
+
(0, common_1.Module)({
|
|
48
|
+
providers: [config_1.StefaniniGoConfigService, config_2.ConfigService],
|
|
49
|
+
exports: [config_1.StefaniniGoConfigService, config_2.ConfigService],
|
|
50
|
+
})
|
|
51
|
+
], MessagingModule);
|
|
52
|
+
//# sourceMappingURL=messagin.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"messagin.module.js","sourceRoot":"","sources":["../../../../libs/stefaninigo/src/messaging/messagin.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAiE;AACjE,mDAAwD;AACxD,mDAAwD;AACxD,sCAAqD;AACrD,2CAA+C;AAG/C,MAAM,SAAS,GAAG;IAChB,GAAG,EAAE,KAAK;IACV,GAAG,EAAE,KAAK;CACX,CAAC;AAEF,MAAM,mBAAmB,GAAyG;IAChI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,iCAAmB;IACpC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,iCAAmB;CACrC,CAAC;AAWK,IAAM,eAAe,uBAArB,MAAM,eAAe;IAG1B,MAAM,CAAC,YAAY,CAAC,SAAoC;QACtD,MAAM,cAAc,GAAe,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE;YACtE,MAAM,qBAAqB,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;YAE5D,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBAC3B,MAAM,IAAI,KAAK,CAAC,+BAA+B,QAAQ,EAAE,CAAC,CAAC;YAC7D,CAAC;YAED,OAAO;gBACL,OAAO,EAAE,IAAI;gBACb,UAAU,EAAE,KAAK,EAAE,aAAuC,EAAE,EAAE,CAAC,IAAI,qBAAqB,CAAC,aAAa,CAAC,QAAQ,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;gBACpI,MAAM,EAAE,CAAC,iCAAwB,EAAE,sBAAa,CAAC;aAClD,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,OAAO;YACL,MAAM,EAAE,iBAAe;YACvB,SAAS,EAAE,cAAc;YACzB,OAAO,EAAE,cAAc;SACxB,CAAC;IACJ,CAAC;;AAvBU,0CAAe;AACnB,yBAAS,GAAG,SAAS,AAAZ,CAAa;0BADlB,eAAe;IAJ3B,IAAA,eAAM,EAAC;QACN,SAAS,EAAE,CAAC,iCAAwB,EAAE,sBAAa,CAAC;QACpD,OAAO,EAAE,CAAC,iCAAwB,EAAE,sBAAa,CAAC;KACnD,CAAC;GACW,eAAe,CAwB3B"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { MessagingServiceSNS } from "../messagin-service.interface";
|
|
2
|
+
interface SNSMessagingConfig {
|
|
3
|
+
region: string;
|
|
4
|
+
accessKeyId: string;
|
|
5
|
+
secretAccessKey: string;
|
|
6
|
+
}
|
|
7
|
+
export declare class SNSMessagingService implements MessagingServiceSNS {
|
|
8
|
+
private readonly logger;
|
|
9
|
+
private snsClient;
|
|
10
|
+
constructor(config: SNSMessagingConfig);
|
|
11
|
+
publish(message: string, topicArn: string, options?: object): Promise<void>;
|
|
12
|
+
subscribe(topicArn: string, protocol: 'http' | 'https' | 'email' | 'sms', endpoint: string, options?: object, handler?: (message: string) => void): Promise<void>;
|
|
13
|
+
handleNotification(req: any, res: any): Promise<void>;
|
|
14
|
+
private confirmSubscription;
|
|
15
|
+
}
|
|
16
|
+
export {};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SNSMessagingService = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const client_sns_1 = require("@aws-sdk/client-sns");
|
|
6
|
+
class SNSMessagingService {
|
|
7
|
+
constructor(config) {
|
|
8
|
+
this.logger = new common_1.Logger(SNSMessagingService.name);
|
|
9
|
+
this.snsClient = new client_sns_1.SNSClient({
|
|
10
|
+
region: config.region,
|
|
11
|
+
credentials: {
|
|
12
|
+
accessKeyId: config.accessKeyId,
|
|
13
|
+
secretAccessKey: config.secretAccessKey,
|
|
14
|
+
},
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
async publish(message, topicArn, options) {
|
|
18
|
+
const params = {
|
|
19
|
+
Message: message,
|
|
20
|
+
TopicArn: topicArn,
|
|
21
|
+
...options,
|
|
22
|
+
};
|
|
23
|
+
const command = new client_sns_1.PublishCommand(params);
|
|
24
|
+
await this.snsClient.send(command);
|
|
25
|
+
}
|
|
26
|
+
async subscribe(topicArn, protocol, endpoint, options, handler) {
|
|
27
|
+
const params = {
|
|
28
|
+
TopicArn: topicArn,
|
|
29
|
+
Protocol: protocol,
|
|
30
|
+
Endpoint: endpoint
|
|
31
|
+
};
|
|
32
|
+
const command = new client_sns_1.SubscribeCommand(params);
|
|
33
|
+
const subscription = await this.snsClient.send(command);
|
|
34
|
+
this.logger.log(`Suscripción creada para el tópico SNS: ${subscription.SubscriptionArn}`);
|
|
35
|
+
}
|
|
36
|
+
async handleNotification(req, res) {
|
|
37
|
+
const messageType = req.headers['x-amz-sns-message-type'];
|
|
38
|
+
if (messageType === 'SubscriptionConfirmation') {
|
|
39
|
+
const confirmationUrl = req.body.SubscribeURL;
|
|
40
|
+
await this.confirmSubscription(confirmationUrl);
|
|
41
|
+
res.status(200).send('Subscription confirmed');
|
|
42
|
+
}
|
|
43
|
+
else if (messageType === 'Notification') {
|
|
44
|
+
const snsMessage = req.body.Message;
|
|
45
|
+
this.logger.log(`Received SNS message: ${snsMessage}`);
|
|
46
|
+
res.status(200).send('Message received');
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
res.status(400).send('Invalid SNS message');
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
async confirmSubscription(confirmationUrl) {
|
|
53
|
+
const https = require('https');
|
|
54
|
+
https.get(confirmationUrl, (res) => {
|
|
55
|
+
this.logger.log(`Subscription confirmed: ${res.statusCode}`);
|
|
56
|
+
}).on('error', (err) => {
|
|
57
|
+
this.logger.error(`Error confirming subscription: ${err.message}`);
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
exports.SNSMessagingService = SNSMessagingService;
|
|
62
|
+
//# sourceMappingURL=sns.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sns.service.js","sourceRoot":"","sources":["../../../../../libs/stefaninigo/src/messaging/sns/sns.service.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AACxC,oDAAkF;AASlF,MAAa,mBAAmB;IAI9B,YAAY,MAA0B;QAHrB,WAAM,GAAG,IAAI,eAAM,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;QAI7D,IAAI,CAAC,SAAS,GAAG,IAAI,sBAAS,CAAC;YAC7B,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,WAAW,EAAE;gBACX,WAAW,EAAE,MAAM,CAAC,WAAW;gBAC/B,eAAe,EAAE,MAAM,CAAC,eAAe;aACxC;SACF,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAe,EAAE,QAAgB,EAAE,OAAgB;QAC/D,MAAM,MAAM,GAAG;YACb,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,QAAQ;YAClB,GAAG,OAAO;SACX,CAAC;QAEF,MAAM,OAAO,GAAG,IAAI,2BAAc,CAAC,MAAM,CAAC,CAAC;QAC3C,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,QAAgB,EAAE,QAA4C,EAAE,QAAgB,EAAE,OAAe,EAAE,OAAmC;QACpJ,MAAM,MAAM,GAAG;YACb,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,QAAQ;SACnB,CAAC;QAEF,MAAM,OAAO,GAAG,IAAI,6BAAgB,CAAC,MAAM,CAAC,CAAC;QAC7C,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACxD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,0CAA0C,YAAY,CAAC,eAAe,EAAE,CAAC,CAAC;IAC5F,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,GAAQ,EAAE,GAAQ;QACzC,MAAM,WAAW,GAAG,GAAG,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC;QAE1D,IAAI,WAAW,KAAK,0BAA0B,EAAE,CAAC;YAC/C,MAAM,eAAe,GAAG,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;YAC9C,MAAM,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC,CAAC;YAChD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;QACjD,CAAC;aAAM,IAAI,WAAW,KAAK,cAAc,EAAE,CAAC;YAC1C,MAAM,UAAU,GAAG,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;YACpC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,yBAAyB,UAAU,EAAE,CAAC,CAAC;YACvD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAC3C,CAAC;aAAM,CAAC;YACN,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,mBAAmB,CAAC,eAAuB;QACvD,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;QAC/B,KAAK,CAAC,GAAG,CAAC,eAAe,EAAE,CAAC,GAAQ,EAAE,EAAE;YACtC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,2BAA2B,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC;QAC/D,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAQ,EAAE,EAAE;YAC1B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,kCAAkC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AA7DD,kDA6DC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { MessagingServiceSQS } from "../messagin-service.interface";
|
|
2
|
+
interface SQSMessagingConfig {
|
|
3
|
+
region: string;
|
|
4
|
+
accessKeyId: string;
|
|
5
|
+
secretAccessKey: string;
|
|
6
|
+
MaxNumberOfMessages: number;
|
|
7
|
+
WaitTimeSeconds: number;
|
|
8
|
+
pollInterval: number;
|
|
9
|
+
}
|
|
10
|
+
export declare class SQSMessagingService implements MessagingServiceSQS {
|
|
11
|
+
private readonly logger;
|
|
12
|
+
private sqsClient;
|
|
13
|
+
private readonly pollInterval;
|
|
14
|
+
private readonly MaxNumberOfMessages;
|
|
15
|
+
private readonly WaitTimeSeconds;
|
|
16
|
+
private intervalId;
|
|
17
|
+
constructor(config: SQSMessagingConfig);
|
|
18
|
+
publish(message: string, queueUrl: string, options?: object): Promise<void>;
|
|
19
|
+
subscribe(queueUrl: string, handler: (message: string) => void): Promise<void>;
|
|
20
|
+
stopPolling(): void;
|
|
21
|
+
private pollQueue;
|
|
22
|
+
}
|
|
23
|
+
export {};
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SQSMessagingService = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const client_sqs_1 = require("@aws-sdk/client-sqs");
|
|
6
|
+
class SQSMessagingService {
|
|
7
|
+
constructor(config) {
|
|
8
|
+
this.logger = new common_1.Logger(SQSMessagingService.name);
|
|
9
|
+
this.sqsClient = new client_sqs_1.SQSClient({
|
|
10
|
+
region: config.region,
|
|
11
|
+
credentials: {
|
|
12
|
+
accessKeyId: config.accessKeyId,
|
|
13
|
+
secretAccessKey: config.secretAccessKey,
|
|
14
|
+
},
|
|
15
|
+
});
|
|
16
|
+
this.pollInterval = config.pollInterval || 10000;
|
|
17
|
+
this.MaxNumberOfMessages = config.MaxNumberOfMessages || 10;
|
|
18
|
+
this.WaitTimeSeconds = config.WaitTimeSeconds || 20;
|
|
19
|
+
}
|
|
20
|
+
async publish(message, queueUrl, options) {
|
|
21
|
+
const params = {
|
|
22
|
+
QueueUrl: queueUrl,
|
|
23
|
+
MessageBody: message,
|
|
24
|
+
...options,
|
|
25
|
+
};
|
|
26
|
+
const command = new client_sqs_1.SendMessageCommand(params);
|
|
27
|
+
await this.sqsClient.send(command);
|
|
28
|
+
}
|
|
29
|
+
async subscribe(queueUrl, handler) {
|
|
30
|
+
const params = {
|
|
31
|
+
QueueUrl: queueUrl,
|
|
32
|
+
MaxNumberOfMessages: this.MaxNumberOfMessages,
|
|
33
|
+
WaitTimeSeconds: this.WaitTimeSeconds,
|
|
34
|
+
};
|
|
35
|
+
this.intervalId = setInterval(() => this.pollQueue(params, handler), this.pollInterval);
|
|
36
|
+
}
|
|
37
|
+
stopPolling() {
|
|
38
|
+
if (this.intervalId) {
|
|
39
|
+
clearInterval(this.intervalId);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
async pollQueue(params, handler) {
|
|
43
|
+
try {
|
|
44
|
+
const command = new client_sqs_1.ReceiveMessageCommand(params);
|
|
45
|
+
const data = await this.sqsClient.send(command);
|
|
46
|
+
if (data.Messages) {
|
|
47
|
+
for (const msg of data.Messages) {
|
|
48
|
+
handler(msg.Body || '');
|
|
49
|
+
const deleteParams = {
|
|
50
|
+
QueueUrl: params.QueueUrl,
|
|
51
|
+
ReceiptHandle: msg.ReceiptHandle,
|
|
52
|
+
};
|
|
53
|
+
const deleteCommand = new client_sqs_1.DeleteMessageCommand(deleteParams);
|
|
54
|
+
await this.sqsClient.send(deleteCommand);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
catch (error) {
|
|
59
|
+
this.logger.error('Error receiving message from SQS', error);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
exports.SQSMessagingService = SQSMessagingService;
|
|
64
|
+
//# sourceMappingURL=sqs.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqs.service.js","sourceRoot":"","sources":["../../../../../libs/stefaninigo/src/messaging/sqs/sqs.service.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AACxC,oDAAiH;AAYjH,MAAa,mBAAmB;IAQ9B,YAAY,MAA0B;QAPrB,WAAM,GAAG,IAAI,eAAM,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;QAQ7D,IAAI,CAAC,SAAS,GAAG,IAAI,sBAAS,CAAC;YAC7B,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,WAAW,EAAE;gBACX,WAAW,EAAE,MAAM,CAAC,WAAW;gBAC/B,eAAe,EAAE,MAAM,CAAC,eAAe;aACxC;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,KAAK,CAAC;QACjD,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC,mBAAmB,IAAI,EAAE,CAAC;QAC5D,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,eAAe,IAAI,EAAE,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAe,EAAE,QAAgB,EAAE,OAAgB;QAC/D,MAAM,MAAM,GAAG;YACb,QAAQ,EAAE,QAAQ;YAClB,WAAW,EAAE,OAAO;YACpB,GAAG,OAAO;SACX,CAAC;QAEF,MAAM,OAAO,GAAG,IAAI,+BAAkB,CAAC,MAAM,CAAC,CAAC;QAC/C,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,QAAgB,EAAE,OAAkC;QAClE,MAAM,MAAM,GAAG;YACb,QAAQ,EAAE,QAAQ;YAClB,mBAAmB,EAAE,IAAI,CAAC,mBAAmB;YAC7C,eAAe,EAAE,IAAI,CAAC,eAAe;SACtC,CAAC;QAEF,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1F,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,SAAS,CAAC,MAAW,EAAE,OAAkC;QACrE,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,IAAI,kCAAqB,CAAC,MAAM,CAAC,CAAC;YAClD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAEhD,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;oBAChC,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;oBACxB,MAAM,YAAY,GAAG;wBACnB,QAAQ,EAAE,MAAM,CAAC,QAAQ;wBACzB,aAAa,EAAE,GAAG,CAAC,aAAc;qBAClC,CAAC;oBACF,MAAM,aAAa,GAAG,IAAI,iCAAoB,CAAC,YAAY,CAAC,CAAC;oBAC7D,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBAC3C,CAAC;YACH,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC;CACF;AArED,kDAqEC"}
|
|
@@ -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("./storage.module"), exports);
|
|
18
|
+
__exportStar(require("./storage.interface"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../libs/stefaninigo/src/storage/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAgC;AAChC,sDAAmC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { StorageService } from '../storage.interface';
|
|
2
|
+
import { Readable } from 'stream';
|
|
3
|
+
interface S3Config {
|
|
4
|
+
region: string;
|
|
5
|
+
accessKeyId: string;
|
|
6
|
+
secretAccessKey: string;
|
|
7
|
+
bucket: string;
|
|
8
|
+
expiresIn: number;
|
|
9
|
+
containerPath: string;
|
|
10
|
+
}
|
|
11
|
+
export declare class S3Service implements StorageService {
|
|
12
|
+
private readonly s3;
|
|
13
|
+
private readonly bucket;
|
|
14
|
+
private readonly containerPath;
|
|
15
|
+
private readonly expiresIn;
|
|
16
|
+
constructor(config: S3Config);
|
|
17
|
+
private validateConfig;
|
|
18
|
+
private buildFilePath;
|
|
19
|
+
uploadFile(file: Express.Multer.File, key: string, containerPath?: string): Promise<any>;
|
|
20
|
+
downloadFile(key: string, containerPath?: string): Promise<Readable>;
|
|
21
|
+
listFiles(containerPath?: string): Promise<any>;
|
|
22
|
+
deleteFile(key: string, containerPath?: string): Promise<any>;
|
|
23
|
+
getFileUrl(key: string, containerPath?: string, expiresIn?: number, contentDisposition?: string, contentType?: string): Promise<string>;
|
|
24
|
+
}
|
|
25
|
+
export {};
|
|
@@ -0,0 +1,137 @@
|
|
|
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.S3Service = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const client_s3_1 = require("@aws-sdk/client-s3");
|
|
15
|
+
const s3_request_presigner_1 = require("@aws-sdk/s3-request-presigner");
|
|
16
|
+
const lib_storage_1 = require("@aws-sdk/lib-storage");
|
|
17
|
+
let S3Service = class S3Service {
|
|
18
|
+
constructor(config) {
|
|
19
|
+
this.expiresIn = 3600;
|
|
20
|
+
this.validateConfig(config);
|
|
21
|
+
this.s3 = new client_s3_1.S3Client({
|
|
22
|
+
region: config.region,
|
|
23
|
+
credentials: {
|
|
24
|
+
accessKeyId: config.accessKeyId,
|
|
25
|
+
secretAccessKey: config.secretAccessKey,
|
|
26
|
+
},
|
|
27
|
+
});
|
|
28
|
+
this.bucket = config.bucket;
|
|
29
|
+
this.containerPath = config.containerPath;
|
|
30
|
+
this.expiresIn = config.expiresIn;
|
|
31
|
+
}
|
|
32
|
+
validateConfig(config) {
|
|
33
|
+
if (!config.region) {
|
|
34
|
+
throw new Error('Invalid S3Config: region is required');
|
|
35
|
+
}
|
|
36
|
+
if (!config.accessKeyId) {
|
|
37
|
+
throw new Error('Invalid S3Config: accessKeyId is required');
|
|
38
|
+
}
|
|
39
|
+
if (!config.secretAccessKey) {
|
|
40
|
+
throw new Error('Invalid S3Config: secretAccessKey is required');
|
|
41
|
+
}
|
|
42
|
+
if (!config.bucket) {
|
|
43
|
+
throw new Error('Invalid S3Config: bucket is required');
|
|
44
|
+
}
|
|
45
|
+
if (!config.containerPath) {
|
|
46
|
+
throw new Error('Invalid S3Config: containerPath is required');
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
buildFilePath(key, containerPath) {
|
|
50
|
+
return `${containerPath || this.containerPath}/${key}`.replace(/\/+/g, '/');
|
|
51
|
+
}
|
|
52
|
+
async uploadFile(file, key, containerPath) {
|
|
53
|
+
const filePath = this.buildFilePath(key, containerPath);
|
|
54
|
+
try {
|
|
55
|
+
const upload = new lib_storage_1.Upload({
|
|
56
|
+
client: this.s3,
|
|
57
|
+
params: {
|
|
58
|
+
Bucket: this.bucket,
|
|
59
|
+
Key: filePath,
|
|
60
|
+
Body: file.buffer,
|
|
61
|
+
},
|
|
62
|
+
});
|
|
63
|
+
return await upload.done();
|
|
64
|
+
}
|
|
65
|
+
catch (error) {
|
|
66
|
+
throw new Error('Failed to upload file');
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
async downloadFile(key, containerPath) {
|
|
70
|
+
const filePath = this.buildFilePath(key, containerPath);
|
|
71
|
+
try {
|
|
72
|
+
const command = new client_s3_1.GetObjectCommand({
|
|
73
|
+
Bucket: this.bucket,
|
|
74
|
+
Key: filePath,
|
|
75
|
+
});
|
|
76
|
+
const response = await this.s3.send(command);
|
|
77
|
+
return response.Body;
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
throw new Error('Failed to download file');
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
async listFiles(containerPath) {
|
|
84
|
+
try {
|
|
85
|
+
const commandParams = { Bucket: this.bucket };
|
|
86
|
+
if (containerPath) {
|
|
87
|
+
commandParams.Prefix = containerPath.endsWith('/') ? containerPath : `${containerPath}/`;
|
|
88
|
+
}
|
|
89
|
+
const command = new client_s3_1.ListObjectsV2Command(commandParams);
|
|
90
|
+
const response = await this.s3.send(command);
|
|
91
|
+
return response.Contents ? response.Contents.map(file => file.Key) : [];
|
|
92
|
+
}
|
|
93
|
+
catch (error) {
|
|
94
|
+
throw new Error('Failed to list files');
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
async deleteFile(key, containerPath) {
|
|
98
|
+
const filePath = this.buildFilePath(key, containerPath);
|
|
99
|
+
try {
|
|
100
|
+
const command = new client_s3_1.DeleteObjectCommand({
|
|
101
|
+
Bucket: this.bucket,
|
|
102
|
+
Key: filePath,
|
|
103
|
+
});
|
|
104
|
+
return await this.s3.send(command);
|
|
105
|
+
}
|
|
106
|
+
catch (error) {
|
|
107
|
+
throw new Error('Failed to delete file');
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
async getFileUrl(key, containerPath, expiresIn = 3600, contentDisposition, contentType) {
|
|
111
|
+
try {
|
|
112
|
+
const objectKey = containerPath ? `${containerPath}/${key}` : key;
|
|
113
|
+
const commandInput = {
|
|
114
|
+
Bucket: this.bucket,
|
|
115
|
+
Key: objectKey
|
|
116
|
+
};
|
|
117
|
+
if (contentDisposition) {
|
|
118
|
+
commandInput.ResponseContentDisposition = contentDisposition;
|
|
119
|
+
}
|
|
120
|
+
if (contentType) {
|
|
121
|
+
commandInput.ResponseContentType = contentType;
|
|
122
|
+
}
|
|
123
|
+
const command = new client_s3_1.GetObjectCommand(commandInput);
|
|
124
|
+
const url = await (0, s3_request_presigner_1.getSignedUrl)(this.s3, command, { expiresIn: this.expiresIn || expiresIn });
|
|
125
|
+
return url;
|
|
126
|
+
}
|
|
127
|
+
catch (error) {
|
|
128
|
+
throw new Error('Failed to get file URL');
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
};
|
|
132
|
+
exports.S3Service = S3Service;
|
|
133
|
+
exports.S3Service = S3Service = __decorate([
|
|
134
|
+
(0, common_1.Injectable)(),
|
|
135
|
+
__metadata("design:paramtypes", [Object])
|
|
136
|
+
], S3Service);
|
|
137
|
+
//# sourceMappingURL=s3-services.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"s3-services.js","sourceRoot":"","sources":["../../../../../libs/stefaninigo/src/storage/s3/s3-services.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Readable } from 'stream';
|
|
2
|
+
export interface StorageService {
|
|
3
|
+
uploadFile(file: Express.Multer.File, key: string, containerPath?: string): Promise<any>;
|
|
4
|
+
getFileUrl(key: string, containerPath?: string, expiresIn?: number, contentDisposition?: string, contentType?: string): Promise<string>;
|
|
5
|
+
downloadFile(key: string, containerPath?: string): Promise<Readable>;
|
|
6
|
+
listFiles(containerPath?: string): Promise<any>;
|
|
7
|
+
deleteFile(key: string, containerPath?: string): Promise<any>;
|
|
8
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage.interface.js","sourceRoot":"","sources":["../../../../libs/stefaninigo/src/storage/storage.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { DynamicModule } from '@nestjs/common';
|
|
2
|
+
import { StorageService } from './storage.interface';
|
|
3
|
+
declare const storageStrategies: {
|
|
4
|
+
[key: string]: new (config: {
|
|
5
|
+
[key: string]: any;
|
|
6
|
+
}) => StorageService;
|
|
7
|
+
};
|
|
8
|
+
interface StorageProviderConfig {
|
|
9
|
+
name: string;
|
|
10
|
+
provider: keyof typeof storageStrategies;
|
|
11
|
+
}
|
|
12
|
+
export declare class StorageModule {
|
|
13
|
+
static PROVIDERS: {
|
|
14
|
+
S3: string;
|
|
15
|
+
};
|
|
16
|
+
static forRootAsync(providers: StorageProviderConfig[]): DynamicModule;
|
|
17
|
+
}
|
|
18
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
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 StorageModule_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.StorageModule = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const s3_services_1 = require("./s3/s3-services");
|
|
13
|
+
const config_1 = require("../config");
|
|
14
|
+
const config_2 = require("@nestjs/config");
|
|
15
|
+
const PROVIDERS = {
|
|
16
|
+
S3: "S3"
|
|
17
|
+
};
|
|
18
|
+
const storageStrategies = {
|
|
19
|
+
[PROVIDERS.S3]: s3_services_1.S3Service
|
|
20
|
+
};
|
|
21
|
+
let StorageModule = StorageModule_1 = class StorageModule {
|
|
22
|
+
static forRootAsync(providers) {
|
|
23
|
+
const asyncProviders = providers.map(({ name, provider }) => {
|
|
24
|
+
const StorageServiceClass = storageStrategies[provider];
|
|
25
|
+
if (!StorageServiceClass) {
|
|
26
|
+
throw new Error(`Unknown storage provider: ${provider}`);
|
|
27
|
+
}
|
|
28
|
+
return {
|
|
29
|
+
provide: name,
|
|
30
|
+
useFactory: async (configService) => new StorageServiceClass(configService?.storage?.getConfig(provider)),
|
|
31
|
+
inject: [config_1.StefaniniGoConfigService],
|
|
32
|
+
};
|
|
33
|
+
});
|
|
34
|
+
return {
|
|
35
|
+
module: StorageModule_1,
|
|
36
|
+
providers: asyncProviders,
|
|
37
|
+
exports: asyncProviders,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
exports.StorageModule = StorageModule;
|
|
42
|
+
StorageModule.PROVIDERS = PROVIDERS;
|
|
43
|
+
exports.StorageModule = StorageModule = StorageModule_1 = __decorate([
|
|
44
|
+
(0, common_1.Module)({
|
|
45
|
+
providers: [config_1.StefaniniGoConfigService, config_2.ConfigService],
|
|
46
|
+
exports: [config_1.StefaniniGoConfigService, config_2.ConfigService],
|
|
47
|
+
})
|
|
48
|
+
], StorageModule);
|
|
49
|
+
//# sourceMappingURL=storage.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage.module.js","sourceRoot":"","sources":["../../../../libs/stefaninigo/src/storage/storage.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAiE;AACjE,kDAA6C;AAE7C,sCAAqD;AACrD,2CAA+C;AAE/C,MAAM,SAAS,GAAG;IAChB,EAAE,EAAE,IAAI;CACT,CAAA;AAED,MAAM,iBAAiB,GAA8E;IACnG,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,uBAAS;CAC1B,CAAC;AAWK,IAAM,aAAa,qBAAnB,MAAM,aAAa;IAExB,MAAM,CAAC,YAAY,CAAC,SAAkC;QACpD,MAAM,cAAc,GAAe,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE;YACtE,MAAM,mBAAmB,GAAG,iBAAiB,CAAC,QAAQ,CAAC,CAAC;YAExD,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBACzB,MAAM,IAAI,KAAK,CAAC,6BAA6B,QAAQ,EAAE,CAAC,CAAC;YAC3D,CAAC;YAED,OAAO;gBACL,OAAO,EAAE,IAAI;gBACb,UAAU,EAAE,KAAK,EAAE,aAAuC,EAAE,EAAE,CAAC,IAAI,mBAAmB,CAAC,aAAa,EAAE,OAAO,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC;gBACnI,MAAM,EAAE,CAAC,iCAAwB,CAAC;aACnC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,OAAO;YACL,MAAM,EAAE,eAAa;YACrB,SAAS,EAAE,cAAc;YACzB,OAAO,EAAE,cAAc;SACxB,CAAC;IACJ,CAAC;;AAtBU,sCAAa;AACjB,uBAAS,GAAG,SAAS,AAAZ,CAAa;wBADlB,aAAa;IAJzB,IAAA,eAAM,EAAC;QACN,SAAS,EAAE,CAAC,iCAAwB,EAAE,sBAAa,CAAC;QACpD,OAAO,EAAE,CAAC,iCAAwB,EAAE,sBAAa,CAAC;KACnD,CAAC;GACW,aAAa,CAuBzB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { HttpRequestBuilder, HttpRequestOptions } from './http.interface';
|
|
2
|
+
export declare class HttpRequestBuilderImpl implements HttpRequestBuilder {
|
|
3
|
+
private options;
|
|
4
|
+
constructor(initialOptions?: Partial<HttpRequestOptions>);
|
|
5
|
+
get(url: string): this;
|
|
6
|
+
post(url: string): this;
|
|
7
|
+
put(url: string): this;
|
|
8
|
+
delete(url: string): this;
|
|
9
|
+
patch(url: string): this;
|
|
10
|
+
headers(headers: Record<string, string>): this;
|
|
11
|
+
addHeader(key: string, value: string): this;
|
|
12
|
+
query(queryParams: Record<string, any>): this;
|
|
13
|
+
body(body: any): this;
|
|
14
|
+
build(): HttpRequestOptions;
|
|
15
|
+
}
|