@open-rlb/nestjs-amqp 1.0.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 +300 -0
- package/amqp-lib/amqp/connection.d.ts +51 -0
- package/amqp-lib/amqp/connection.js +503 -0
- package/amqp-lib/amqp/connection.js.map +1 -0
- package/amqp-lib/amqp/errorBehaviors.d.ts +9 -0
- package/amqp-lib/amqp/errorBehaviors.js +47 -0
- package/amqp-lib/amqp/errorBehaviors.js.map +1 -0
- package/amqp-lib/amqp/utils.d.ts +7 -0
- package/amqp-lib/amqp/utils.js +110 -0
- package/amqp-lib/amqp/utils.js.map +1 -0
- package/amqp-lib/config/rabbitmq-exchange.config.d.ts +13 -0
- package/amqp-lib/config/rabbitmq-exchange.config.js +3 -0
- package/amqp-lib/config/rabbitmq-exchange.config.js.map +1 -0
- package/amqp-lib/config/rabbitmq-queue.config.d.ts +25 -0
- package/amqp-lib/config/rabbitmq-queue.config.js +3 -0
- package/amqp-lib/config/rabbitmq-queue.config.js.map +1 -0
- package/amqp-lib/config/rabbitmq.config.d.ts +49 -0
- package/amqp-lib/config/rabbitmq.config.js +3 -0
- package/amqp-lib/config/rabbitmq.config.js.map +1 -0
- package/amqp-lib/index.d.ts +4 -0
- package/amqp-lib/index.js +21 -0
- package/amqp-lib/index.js.map +1 -0
- package/amqp-lib/models/correlation-message.model.d.ts +5 -0
- package/amqp-lib/models/correlation-message.model.js +3 -0
- package/amqp-lib/models/correlation-message.model.js.map +1 -0
- package/amqp-lib/models/errors.model.d.ts +15 -0
- package/amqp-lib/models/errors.model.js +35 -0
- package/amqp-lib/models/errors.model.js.map +1 -0
- package/amqp-lib/models/nack.model.d.ts +5 -0
- package/amqp-lib/models/nack.model.js +13 -0
- package/amqp-lib/models/nack.model.js.map +1 -0
- package/amqp-lib/models/rabbitmq-handler.model.d.ts +38 -0
- package/amqp-lib/models/rabbitmq-handler.model.js +3 -0
- package/amqp-lib/models/rabbitmq-handler.model.js.map +1 -0
- package/amqp-lib/models/subscription-result.model.d.ts +4 -0
- package/amqp-lib/models/subscription-result.model.js +3 -0
- package/amqp-lib/models/subscription-result.model.js.map +1 -0
- package/amqp-lib/types.d.ts +45 -0
- package/amqp-lib/types.js +11 -0
- package/amqp-lib/types.js.map +1 -0
- package/amqp.module.d.ts +2 -0
- package/amqp.module.js +29 -0
- package/amqp.module.js.map +1 -0
- package/index.d.ts +4 -0
- package/index.js +21 -0
- package/index.js.map +1 -0
- package/modules/broker/broker.module.d.ts +27 -0
- package/modules/broker/broker.module.js +132 -0
- package/modules/broker/broker.module.js.map +1 -0
- package/modules/broker/config/broker.config.d.ts +3 -0
- package/modules/broker/config/broker.config.js +3 -0
- package/modules/broker/config/broker.config.js.map +1 -0
- package/modules/broker/config/handler-auth.config.d.ts +22 -0
- package/modules/broker/config/handler-auth.config.js +3 -0
- package/modules/broker/config/handler-auth.config.js.map +1 -0
- package/modules/broker/config/topics.config.d.ts +8 -0
- package/modules/broker/config/topics.config.js +3 -0
- package/modules/broker/config/topics.config.js.map +1 -0
- package/modules/broker/const.d.ts +9 -0
- package/modules/broker/const.js +13 -0
- package/modules/broker/const.js.map +1 -0
- package/modules/broker/data/events/messages.d.ts +29 -0
- package/modules/broker/data/events/messages.js +3 -0
- package/modules/broker/data/events/messages.js.map +1 -0
- package/modules/broker/decorators/broker-action.decorator.d.ts +8 -0
- package/modules/broker/decorators/broker-action.decorator.js +66 -0
- package/modules/broker/decorators/broker-action.decorator.js.map +1 -0
- package/modules/broker/decorators/index.d.ts +1 -0
- package/modules/broker/decorators/index.js +18 -0
- package/modules/broker/decorators/index.js.map +1 -0
- package/modules/broker/index.d.ts +9 -0
- package/modules/broker/index.js +26 -0
- package/modules/broker/index.js.map +1 -0
- package/modules/broker/pipes/boolean.pipe.d.ts +4 -0
- package/modules/broker/pipes/boolean.pipe.js +23 -0
- package/modules/broker/pipes/boolean.pipe.js.map +1 -0
- package/modules/broker/pipes/index.d.ts +2 -0
- package/modules/broker/pipes/index.js +19 -0
- package/modules/broker/pipes/index.js.map +1 -0
- package/modules/broker/pipes/number.pipe.d.ts +4 -0
- package/modules/broker/pipes/number.pipe.js +10 -0
- package/modules/broker/pipes/number.pipe.js.map +1 -0
- package/modules/broker/services/auto-discovery.service.d.ts +6 -0
- package/modules/broker/services/auto-discovery.service.js +28 -0
- package/modules/broker/services/auto-discovery.service.js.map +1 -0
- package/modules/broker/services/broker.service.d.ts +31 -0
- package/modules/broker/services/broker.service.js +323 -0
- package/modules/broker/services/broker.service.js.map +1 -0
- package/modules/broker/services/handler-registry.service.d.ts +12 -0
- package/modules/broker/services/handler-registry.service.js +58 -0
- package/modules/broker/services/handler-registry.service.js.map +1 -0
- package/modules/broker/services/metadata-scanner.service.d.ts +23 -0
- package/modules/broker/services/metadata-scanner.service.js +238 -0
- package/modules/broker/services/metadata-scanner.service.js.map +1 -0
- package/modules/broker/services/reflect.service.d.ts +22 -0
- package/modules/broker/services/reflect.service.js +195 -0
- package/modules/broker/services/reflect.service.js.map +1 -0
- package/modules/broker/services/utils.service.d.ts +8 -0
- package/modules/broker/services/utils.service.js +28 -0
- package/modules/broker/services/utils.service.js.map +1 -0
- package/modules/proxy/config/path-definition.config.d.ts +51 -0
- package/modules/proxy/config/path-definition.config.js +3 -0
- package/modules/proxy/config/path-definition.config.js.map +1 -0
- package/modules/proxy/index.d.ts +7 -0
- package/modules/proxy/index.js +20 -0
- package/modules/proxy/index.js.map +1 -0
- package/modules/proxy/proxy.module.d.ts +4 -0
- package/modules/proxy/proxy.module.js +38 -0
- package/modules/proxy/proxy.module.js.map +1 -0
- package/modules/proxy/services/acl.service.d.ts +4 -0
- package/modules/proxy/services/acl.service.js +5 -0
- package/modules/proxy/services/acl.service.js.map +1 -0
- package/modules/proxy/services/http-auth-handler.service.d.ts +19 -0
- package/modules/proxy/services/http-auth-handler.service.js +146 -0
- package/modules/proxy/services/http-auth-handler.service.js.map +1 -0
- package/modules/proxy/services/http-handler.service.d.ts +21 -0
- package/modules/proxy/services/http-handler.service.js +210 -0
- package/modules/proxy/services/http-handler.service.js.map +1 -0
- package/modules/proxy/services/jwt.service.d.ts +12 -0
- package/modules/proxy/services/jwt.service.js +107 -0
- package/modules/proxy/services/jwt.service.js.map +1 -0
- package/modules/proxy/services/websocket.service.d.ts +21 -0
- package/modules/proxy/services/websocket.service.js +180 -0
- package/modules/proxy/services/websocket.service.js.map +1 -0
- package/modules/remote-config/index.d.ts +2 -0
- package/modules/remote-config/index.js +19 -0
- package/modules/remote-config/index.js.map +1 -0
- package/modules/remote-config/remote-config.module.d.ts +2 -0
- package/modules/remote-config/remote-config.module.js +22 -0
- package/modules/remote-config/remote-config.module.js.map +1 -0
- package/modules/remote-config/remote-config.service.d.ts +12 -0
- package/modules/remote-config/remote-config.service.js +68 -0
- package/modules/remote-config/remote-config.service.js.map +1 -0
- package/open-rlb-amqp.schema.json +1297 -0
- package/package.json +88 -0
- package/tsconfig.build.tsbuildinfo +1 -0
|
@@ -0,0 +1,38 @@
|
|
|
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 ProxyModule_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.ProxyModule = void 0;
|
|
11
|
+
const axios_1 = require("@nestjs/axios");
|
|
12
|
+
const common_1 = require("@nestjs/common");
|
|
13
|
+
const config_1 = require("@nestjs/config");
|
|
14
|
+
const broker_1 = require("../broker");
|
|
15
|
+
const http_auth_handler_service_1 = require("./services/http-auth-handler.service");
|
|
16
|
+
const http_handler_service_1 = require("./services/http-handler.service");
|
|
17
|
+
const jwt_service_1 = require("./services/jwt.service");
|
|
18
|
+
const websocket_service_1 = require("./services/websocket.service");
|
|
19
|
+
let ProxyModule = ProxyModule_1 = class ProxyModule {
|
|
20
|
+
static forRoot(providers) {
|
|
21
|
+
return {
|
|
22
|
+
module: ProxyModule_1,
|
|
23
|
+
imports: [],
|
|
24
|
+
providers: [...(providers || [])],
|
|
25
|
+
exports: [http_handler_service_1.HttpHandlerService],
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
exports.ProxyModule = ProxyModule;
|
|
30
|
+
exports.ProxyModule = ProxyModule = ProxyModule_1 = __decorate([
|
|
31
|
+
(0, common_1.Global)(),
|
|
32
|
+
(0, common_1.Module)({
|
|
33
|
+
imports: [config_1.ConfigModule, broker_1.BrokerModule, axios_1.HttpModule],
|
|
34
|
+
providers: [http_handler_service_1.HttpHandlerService, jwt_service_1.JwtService, http_auth_handler_service_1.HttpAuthHandlerService, websocket_service_1.WebSocketService],
|
|
35
|
+
exports: [http_handler_service_1.HttpHandlerService]
|
|
36
|
+
})
|
|
37
|
+
], ProxyModule);
|
|
38
|
+
//# sourceMappingURL=proxy.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proxy.module.js","sourceRoot":"","sources":["../../../libs/rlb-nestjs-amqp/src/modules/proxy/proxy.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,yCAA2C;AAC3C,2CAAyE;AACzE,2CAA8C;AAC9C,sCAAyC;AACzC,oFAA8E;AAC9E,0EAAqE;AACrE,wDAAoD;AACpD,oEAAgE;AASzD,IAAM,WAAW,mBAAjB,MAAM,WAAW;IAEtB,MAAM,CAAC,OAAO,CAAC,SAAqB;QAElC,OAAO;YACL,MAAM,EAAE,aAAW;YACnB,OAAO,EAAE,EAAE;YACX,SAAS,EAAE,CAAC,GAAG,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC;YACjC,OAAO,EAAE,CAAC,yCAAkB,CAAC;SAC9B,CAAC;IACJ,CAAC;CACF,CAAA;AAXY,kCAAW;sBAAX,WAAW;IANvB,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,qBAAY,EAAE,qBAAY,EAAE,kBAAU,CAAC;QACjD,SAAS,EAAE,CAAC,yCAAkB,EAAE,wBAAU,EAAE,kDAAsB,EAAE,oCAAgB,CAAC;QACrF,OAAO,EAAE,CAAC,yCAAkB,CAAC;KAC9B,CAAC;GACW,WAAW,CAWvB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acl.service.js","sourceRoot":"","sources":["../../../../libs/rlb-nestjs-amqp/src/modules/proxy/services/acl.service.ts"],"names":[],"mappings":";;;AAAa,QAAA,wBAAwB,GAAG,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Request } from 'express';
|
|
2
|
+
import { ProcessedAuthData } from '..';
|
|
3
|
+
import { HandlerAuthConfig } from '../../broker/config/handler-auth.config';
|
|
4
|
+
import { PathDefinition } from '../config/path-definition.config';
|
|
5
|
+
import { IAclRoleService } from './acl.service';
|
|
6
|
+
import { JwtService } from './jwt.service';
|
|
7
|
+
export declare class HttpAuthHandlerService {
|
|
8
|
+
private readonly aclRoleService;
|
|
9
|
+
private readonly authProviders;
|
|
10
|
+
private readonly jwtService;
|
|
11
|
+
constructor(aclRoleService: IAclRoleService, authProviders: HandlerAuthConfig[], jwtService: JwtService);
|
|
12
|
+
processAuthData(req: Request, path: PathDefinition): Promise<ProcessedAuthData>;
|
|
13
|
+
checkJwt(req: Request, authConfig: HandlerAuthConfig): Promise<ProcessedAuthData>;
|
|
14
|
+
checkBasicAuth(req: Request, authConfig: HandlerAuthConfig): Promise<ProcessedAuthData>;
|
|
15
|
+
checkStringCompare(req: Request, authConfig: HandlerAuthConfig): Promise<ProcessedAuthData>;
|
|
16
|
+
checkRoles(data: {
|
|
17
|
+
[key: string]: any;
|
|
18
|
+
}, path: PathDefinition): Promise<boolean>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,146 @@
|
|
|
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 __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.HttpAuthHandlerService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const const_1 = require("../../broker/const");
|
|
18
|
+
const acl_service_1 = require("./acl.service");
|
|
19
|
+
const jwt_service_1 = require("./jwt.service");
|
|
20
|
+
let HttpAuthHandlerService = class HttpAuthHandlerService {
|
|
21
|
+
constructor(aclRoleService, authProviders, jwtService) {
|
|
22
|
+
this.aclRoleService = aclRoleService;
|
|
23
|
+
this.authProviders = authProviders;
|
|
24
|
+
this.jwtService = jwtService;
|
|
25
|
+
}
|
|
26
|
+
async processAuthData(req, path) {
|
|
27
|
+
let out = { success: false };
|
|
28
|
+
if (!path?.auth)
|
|
29
|
+
return out;
|
|
30
|
+
const authConfig = this.authProviders.find(o => o.name === path.auth);
|
|
31
|
+
if (!authConfig)
|
|
32
|
+
throw new Error(`Auth provider ${path.auth} not found`);
|
|
33
|
+
switch (authConfig.type) {
|
|
34
|
+
case 'basic':
|
|
35
|
+
out = await this.checkBasicAuth(req, authConfig);
|
|
36
|
+
break;
|
|
37
|
+
case 'jwt':
|
|
38
|
+
out = await this.checkJwt(req, authConfig);
|
|
39
|
+
break;
|
|
40
|
+
case 'jwks':
|
|
41
|
+
out = await this.checkJwt(req, authConfig);
|
|
42
|
+
break;
|
|
43
|
+
case 'str-compare':
|
|
44
|
+
await this.checkStringCompare(req, authConfig);
|
|
45
|
+
break;
|
|
46
|
+
default:
|
|
47
|
+
break;
|
|
48
|
+
}
|
|
49
|
+
return out;
|
|
50
|
+
}
|
|
51
|
+
async checkJwt(req, authConfig) {
|
|
52
|
+
let decoded;
|
|
53
|
+
let out = { success: false };
|
|
54
|
+
const jwt = req.headers.authorization?.split(" ")[1];
|
|
55
|
+
if (!jwt)
|
|
56
|
+
return out;
|
|
57
|
+
if (authConfig.type === 'jwt') {
|
|
58
|
+
decoded = await this.jwtService.verifyTokenSecret(authConfig, jwt);
|
|
59
|
+
}
|
|
60
|
+
if (authConfig.type === 'jwks') {
|
|
61
|
+
decoded = await this.jwtService.verifyTokenJwks(authConfig, jwt);
|
|
62
|
+
}
|
|
63
|
+
if (!decoded) {
|
|
64
|
+
return out;
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
if (!authConfig.jwtMap) {
|
|
68
|
+
out = decoded;
|
|
69
|
+
out.success = true;
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
authConfig.jwtMap.map(o => o.split(':')).forEach(([source, dest]) => {
|
|
73
|
+
if (decoded?.[source])
|
|
74
|
+
out[`${authConfig.headerPrefix}${dest.trim().toUpperCase()}`] = decoded?.[source];
|
|
75
|
+
});
|
|
76
|
+
out.success = true;
|
|
77
|
+
}
|
|
78
|
+
return out;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
async checkBasicAuth(req, authConfig) {
|
|
82
|
+
let out = { success: false };
|
|
83
|
+
const authHeader = req.headers.authorization;
|
|
84
|
+
if (!authHeader || !authHeader.startsWith('Basic ')) {
|
|
85
|
+
return out;
|
|
86
|
+
}
|
|
87
|
+
const base64Credentials = authHeader.split(' ')[1];
|
|
88
|
+
const credentials = Buffer.from(base64Credentials, 'base64').toString('ascii');
|
|
89
|
+
const [username, password] = credentials.split(':');
|
|
90
|
+
if (username === authConfig.clientId && password === authConfig.clientSecret) {
|
|
91
|
+
out[`${authConfig.headerPrefix}USERNAME`] = username;
|
|
92
|
+
out.success = true;
|
|
93
|
+
return out;
|
|
94
|
+
}
|
|
95
|
+
return out;
|
|
96
|
+
}
|
|
97
|
+
async checkStringCompare(req, authConfig) {
|
|
98
|
+
let out = { success: false };
|
|
99
|
+
const authHeader = req.headers.authorization;
|
|
100
|
+
if (!authHeader || !authHeader.startsWith(authConfig.headerPrefix)) {
|
|
101
|
+
return out;
|
|
102
|
+
}
|
|
103
|
+
const token = authHeader.substring(authConfig.headerPrefix.length).trim();
|
|
104
|
+
if (token === authConfig.secret) {
|
|
105
|
+
out[`${authConfig.headerPrefix}TOKEN`] = token;
|
|
106
|
+
out.success = true;
|
|
107
|
+
return out;
|
|
108
|
+
}
|
|
109
|
+
return out;
|
|
110
|
+
}
|
|
111
|
+
async checkRoles(data, path) {
|
|
112
|
+
if (!path?.auth)
|
|
113
|
+
return true;
|
|
114
|
+
if (!path?.roles)
|
|
115
|
+
return true;
|
|
116
|
+
const authConfig = this.authProviders.find(o => o.name === path.auth);
|
|
117
|
+
if (!authConfig)
|
|
118
|
+
throw new Error(`Auth provider ${path.auth} not found`);
|
|
119
|
+
if (authConfig.type !== 'jwt' && authConfig.type !== 'jwks')
|
|
120
|
+
throw new Error(`Auth provider ${path.auth} is not a JWT or JWKS provider`);
|
|
121
|
+
if (!authConfig.usernameClaim)
|
|
122
|
+
throw new Error(`Auth provider ${path.auth} has no username claim defined`);
|
|
123
|
+
if (!authConfig.aclTopic)
|
|
124
|
+
throw new Error(`Auth provider ${path.auth} has no ACL topic defined`);
|
|
125
|
+
if (!authConfig.aclAction)
|
|
126
|
+
throw new Error(`Auth provider ${path.auth} has no ACL action defined`);
|
|
127
|
+
if (!this.aclRoleService)
|
|
128
|
+
throw new Error(`ACL Role Service not found. Please check AppModule.`);
|
|
129
|
+
if (!data)
|
|
130
|
+
return false;
|
|
131
|
+
const userId = data[`${authConfig.headerPrefix}${authConfig.uidClaim}`];
|
|
132
|
+
if (!userId)
|
|
133
|
+
return false;
|
|
134
|
+
const canUserDo = await this.aclRoleService.canUserDo(authConfig.aclTopic, authConfig.aclAction, userId);
|
|
135
|
+
return canUserDo;
|
|
136
|
+
}
|
|
137
|
+
};
|
|
138
|
+
exports.HttpAuthHandlerService = HttpAuthHandlerService;
|
|
139
|
+
exports.HttpAuthHandlerService = HttpAuthHandlerService = __decorate([
|
|
140
|
+
(0, common_1.Injectable)(),
|
|
141
|
+
__param(0, (0, common_1.Optional)()),
|
|
142
|
+
__param(0, (0, common_1.Inject)(acl_service_1.RLB_GTW_ACL_ROLE_SERVICE)),
|
|
143
|
+
__param(1, (0, common_1.Inject)(const_1.RLB_AMQP_AUTH_OPTIONS)),
|
|
144
|
+
__metadata("design:paramtypes", [Object, Array, jwt_service_1.JwtService])
|
|
145
|
+
], HttpAuthHandlerService);
|
|
146
|
+
//# sourceMappingURL=http-auth-handler.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-auth-handler.service.js","sourceRoot":"","sources":["../../../../libs/rlb-nestjs-amqp/src/modules/proxy/services/http-auth-handler.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { OnModuleInit } from "@nestjs/common";
|
|
2
|
+
import { HttpAdapterHost } from "@nestjs/core";
|
|
3
|
+
import { BrokerService } from "../../broker";
|
|
4
|
+
import { AppConfig, UtilsService } from "../../broker/services/utils.service";
|
|
5
|
+
import { GatewayConfig, PathDefinition } from "../config/path-definition.config";
|
|
6
|
+
import { HttpAuthHandlerService } from "./http-auth-handler.service";
|
|
7
|
+
export declare class HttpHandlerService implements OnModuleInit {
|
|
8
|
+
private readonly httpAdapterHost;
|
|
9
|
+
private readonly broker;
|
|
10
|
+
private readonly utils;
|
|
11
|
+
private readonly httpAuthHandlerService;
|
|
12
|
+
private readonly appConfig;
|
|
13
|
+
private readonly gatewayConfig;
|
|
14
|
+
private server;
|
|
15
|
+
private readonly logger;
|
|
16
|
+
private readonly multer;
|
|
17
|
+
constructor(httpAdapterHost: HttpAdapterHost, broker: BrokerService, utils: UtilsService, httpAuthHandlerService: HttpAuthHandlerService, appConfig: AppConfig, gatewayConfig: GatewayConfig);
|
|
18
|
+
onModuleInit(): Promise<void>;
|
|
19
|
+
registerPath(path: PathDefinition): void;
|
|
20
|
+
private httpHeaders;
|
|
21
|
+
}
|
|
@@ -0,0 +1,210 @@
|
|
|
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 __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var HttpHandlerService_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.HttpHandlerService = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const core_1 = require("@nestjs/core");
|
|
19
|
+
const multer = require("multer");
|
|
20
|
+
const broker_1 = require("../../broker");
|
|
21
|
+
const const_1 = require("../../broker/const");
|
|
22
|
+
const utils_service_1 = require("../../broker/services/utils.service");
|
|
23
|
+
const http_auth_handler_service_1 = require("./http-auth-handler.service");
|
|
24
|
+
let HttpHandlerService = HttpHandlerService_1 = class HttpHandlerService {
|
|
25
|
+
constructor(httpAdapterHost, broker, utils, httpAuthHandlerService, appConfig, gatewayConfig) {
|
|
26
|
+
this.httpAdapterHost = httpAdapterHost;
|
|
27
|
+
this.broker = broker;
|
|
28
|
+
this.utils = utils;
|
|
29
|
+
this.httpAuthHandlerService = httpAuthHandlerService;
|
|
30
|
+
this.appConfig = appConfig;
|
|
31
|
+
this.gatewayConfig = gatewayConfig;
|
|
32
|
+
this.logger = new common_1.Logger(HttpHandlerService_1.name);
|
|
33
|
+
this.multer = multer({
|
|
34
|
+
storage: multer.memoryStorage(),
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
async onModuleInit() {
|
|
38
|
+
this.server = this.httpAdapterHost.httpAdapter.getInstance();
|
|
39
|
+
const extPath = [];
|
|
40
|
+
if (this.gatewayConfig.loadConfig?.paths) {
|
|
41
|
+
const o = await this.broker.requestData(this.gatewayConfig.loadConfig.paths.topic, this.gatewayConfig.loadConfig.paths.action, {});
|
|
42
|
+
extPath.push(...o);
|
|
43
|
+
}
|
|
44
|
+
const paths = [...this.gatewayConfig?.paths || [], ...extPath];
|
|
45
|
+
for (const path of paths) {
|
|
46
|
+
this.registerPath(path);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
registerPath(path) {
|
|
50
|
+
if (!path.method)
|
|
51
|
+
throw new Error("Method is required for path definition");
|
|
52
|
+
if (!path.path)
|
|
53
|
+
throw new Error("Path is required for path definition");
|
|
54
|
+
if (!path.topic)
|
|
55
|
+
throw new Error("Topic is required for path definition");
|
|
56
|
+
if (!path.mode)
|
|
57
|
+
throw new Error("Mode is required for path definition");
|
|
58
|
+
this.server[path.method.toLowerCase()](path.path, this.multer.any(), async (req, res) => {
|
|
59
|
+
const authData = await this.httpAuthHandlerService.processAuthData(req, path);
|
|
60
|
+
if (path.auth && !authData?.success && path.allowAnonymous !== true) {
|
|
61
|
+
res.status(401).json({ message: "Unauthorized" });
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
if (!(await this.httpAuthHandlerService.checkRoles(authData, path))) {
|
|
65
|
+
res.status(403).json({ message: "Forbidden" });
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
const httpHeaders = this.httpHeaders(req, path);
|
|
69
|
+
let data = req[path.dataSource] || req.body || {};
|
|
70
|
+
if (path.dataSource === 'body') {
|
|
71
|
+
data = { ...req.params, ...(req.body || {}) };
|
|
72
|
+
}
|
|
73
|
+
else if (path.dataSource === 'query') {
|
|
74
|
+
data = { ...req.params, ...(req.query || {}) };
|
|
75
|
+
}
|
|
76
|
+
else if (path.dataSource === 'params') {
|
|
77
|
+
data = req.params || {};
|
|
78
|
+
}
|
|
79
|
+
else if (path.dataSource === 'body-query') {
|
|
80
|
+
data = { ...req.params, ...(req.query || {}), ...(req.body || {}) };
|
|
81
|
+
}
|
|
82
|
+
else if (path.dataSource === 'query-body') {
|
|
83
|
+
data = { ...req.params, ...(req.body || {}), ...(req.query || {}) };
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
data = { ...req.params, ...(req.body || {}), ...(req.query || {}) };
|
|
87
|
+
}
|
|
88
|
+
if (path.parseRaw) {
|
|
89
|
+
Object.assign(data, { $raw: req.rawBody });
|
|
90
|
+
}
|
|
91
|
+
if (req.files) {
|
|
92
|
+
Object.assign(data, { $files: req.files });
|
|
93
|
+
}
|
|
94
|
+
Object.assign(data, req.params);
|
|
95
|
+
if (data['$files']) {
|
|
96
|
+
for (const file of data['$files']) {
|
|
97
|
+
const o = file.buffer;
|
|
98
|
+
file.buffer = o.toString('binary');
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
try {
|
|
102
|
+
if (path.mode === "event") {
|
|
103
|
+
this.broker.publishMessage(path.topic, data, { ...authData, ...httpHeaders, "X-GTW-METHOD": req.method, "X-GTW-PATH": path.path });
|
|
104
|
+
res.status(202).end();
|
|
105
|
+
this.logger.log(`[${path.mode.toUpperCase()}] [${path.method.toUpperCase()}] '${path.path}' => ${path.topic} | PROCESSED 'EVENT'`);
|
|
106
|
+
}
|
|
107
|
+
else if (path.mode === "rpc") {
|
|
108
|
+
try {
|
|
109
|
+
const headers = new Map();
|
|
110
|
+
if (path.headers) {
|
|
111
|
+
for (const key in path.headers) {
|
|
112
|
+
headers.set(key, path.headers[key]);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
const resp = await this.broker.requestData(path.topic, path.action, data, { ...authData, ...httpHeaders, "X-GTW-METHOD": req.method, "X-GTW-PATH": path.path }, path.timeout);
|
|
116
|
+
if (resp) {
|
|
117
|
+
if (path.redirect) {
|
|
118
|
+
res.redirect(path.redirect, resp);
|
|
119
|
+
this.logger.log(`[${path.mode.toUpperCase()}] [${path.method.toUpperCase()}] '${path.path}' => ${path.topic} | REDIRECT '${path.redirect}'`);
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
if (!headers.has("Content-Type"))
|
|
123
|
+
headers.set("Content-Type", "application/json");
|
|
124
|
+
if (headers.get("Content-Type").toString().includes('json')) {
|
|
125
|
+
res.status(200).setHeaders(headers).json(resp);
|
|
126
|
+
this.logger.log(`[${path.mode.toUpperCase()}] [${path.method.toUpperCase()}] '${path.path}' => ${path.topic} | PROCESSED 'JSON'`);
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
if (path.binary) {
|
|
130
|
+
res.status(200).setHeaders(headers).end(Buffer.from(resp.toString(), 'base64'));
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
res.status(200).setHeaders(headers).end(resp);
|
|
134
|
+
}
|
|
135
|
+
this.logger.log(`[${path.mode.toUpperCase()}] [${path.method.toUpperCase()}] '${path.path}' => ${path.topic} | PROCESSED 'RAW'`);
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
res.status(204).end();
|
|
139
|
+
this.logger.log(`[${path.mode.toUpperCase()}] [${path.method.toUpperCase()}] '${path.path}' => ${path.topic} | PROCESSED 'NO CONTENT'`);
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
catch (error) {
|
|
143
|
+
switch (error.name) {
|
|
144
|
+
case "BadRequestError":
|
|
145
|
+
res.status(400).json(this.utils.error2Object(error, this.appConfig.environment !== 'production'));
|
|
146
|
+
break;
|
|
147
|
+
case "ForbiddenError":
|
|
148
|
+
res.status(403).json(this.utils.error2Object(error, this.appConfig.environment !== 'production'));
|
|
149
|
+
break;
|
|
150
|
+
case "InvalidParamsErrror":
|
|
151
|
+
res.status(400).json(this.utils.error2Object(error, this.appConfig.environment !== 'production'));
|
|
152
|
+
break;
|
|
153
|
+
case "NotFoundError":
|
|
154
|
+
res.status(404).json(this.utils.error2Object(error, this.appConfig.environment !== 'production'));
|
|
155
|
+
break;
|
|
156
|
+
case "UnauthorizedError":
|
|
157
|
+
res.status(401).json(this.utils.error2Object(error, this.appConfig.environment !== 'production'));
|
|
158
|
+
break;
|
|
159
|
+
default:
|
|
160
|
+
res.status(500).json(this.utils.error2Object(error, this.appConfig.environment !== 'production'));
|
|
161
|
+
break;
|
|
162
|
+
}
|
|
163
|
+
this.logger.log(`[${path.mode.toUpperCase()}] [${path.method.toUpperCase()}] '${path.path}' => ${path.topic} | ERROR '${error.name}' ${error.message}`);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
throw new Error(`Invalid mode '${path.mode}' for path definition`);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
catch (error) {
|
|
171
|
+
if (this.appConfig.environment === "development") {
|
|
172
|
+
this.logger.error(error.message);
|
|
173
|
+
res.status(500).json(error);
|
|
174
|
+
}
|
|
175
|
+
else {
|
|
176
|
+
res.status(500).json({ message: "Internal server error", name: error.name });
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
httpHeaders(req, path) {
|
|
182
|
+
const data = {};
|
|
183
|
+
if (path.forwardHeaders) {
|
|
184
|
+
for (const key in path.forwardHeaders) {
|
|
185
|
+
const header = path.forwardHeaders[key]?.toLocaleLowerCase().trim();
|
|
186
|
+
const headerValue = Object.keys(req.headers).find(h => h.toLowerCase().trim() === header);
|
|
187
|
+
if (headerValue) {
|
|
188
|
+
if (this.gatewayConfig.headerPrefix) {
|
|
189
|
+
data[`${this.gatewayConfig.headerPrefix}${key}`] = req.headers[headerValue];
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
data[`${key}`] = req.headers[headerValue];
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
return data;
|
|
198
|
+
}
|
|
199
|
+
};
|
|
200
|
+
exports.HttpHandlerService = HttpHandlerService;
|
|
201
|
+
exports.HttpHandlerService = HttpHandlerService = HttpHandlerService_1 = __decorate([
|
|
202
|
+
(0, common_1.Injectable)(),
|
|
203
|
+
__param(4, (0, common_1.Inject)(const_1.RLB_AMQP_APP_OPTIONS)),
|
|
204
|
+
__param(5, (0, common_1.Inject)(const_1.RLB_AMQP_GATEWAY_OPTIONS)),
|
|
205
|
+
__metadata("design:paramtypes", [core_1.HttpAdapterHost,
|
|
206
|
+
broker_1.BrokerService,
|
|
207
|
+
utils_service_1.UtilsService,
|
|
208
|
+
http_auth_handler_service_1.HttpAuthHandlerService, Object, Object])
|
|
209
|
+
], HttpHandlerService);
|
|
210
|
+
//# sourceMappingURL=http-handler.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-handler.service.js","sourceRoot":"","sources":["../../../../libs/rlb-nestjs-amqp/src/modules/proxy/services/http-handler.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { OnModuleInit } from "@nestjs/common";
|
|
2
|
+
import { JwtPayload } from "jsonwebtoken";
|
|
3
|
+
import { HandlerAuthConfig } from "../../broker/config/handler-auth.config";
|
|
4
|
+
export declare class JwtService implements OnModuleInit {
|
|
5
|
+
private readonly authConfig;
|
|
6
|
+
private readonly jwksClients;
|
|
7
|
+
private readonly logger;
|
|
8
|
+
constructor(authConfig: HandlerAuthConfig[]);
|
|
9
|
+
onModuleInit(): void;
|
|
10
|
+
verifyTokenJwks<T = JwtPayload>(authConfig: HandlerAuthConfig, token: string): Promise<T | undefined>;
|
|
11
|
+
verifyTokenSecret<T = JwtPayload>(authConfig: HandlerAuthConfig, token: string): Promise<T | undefined>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,107 @@
|
|
|
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 __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var JwtService_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.JwtService = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const https_1 = require("https");
|
|
19
|
+
const jsonwebtoken_1 = require("jsonwebtoken");
|
|
20
|
+
const jwks_rsa_1 = require("jwks-rsa");
|
|
21
|
+
const const_1 = require("../../broker/const");
|
|
22
|
+
let JwtService = JwtService_1 = class JwtService {
|
|
23
|
+
constructor(authConfig) {
|
|
24
|
+
this.authConfig = authConfig;
|
|
25
|
+
this.logger = new common_1.Logger(JwtService_1.name);
|
|
26
|
+
this.jwksClients = {};
|
|
27
|
+
}
|
|
28
|
+
onModuleInit() {
|
|
29
|
+
for (const authConfig of this.authConfig) {
|
|
30
|
+
if (authConfig.type === "jwks") {
|
|
31
|
+
this.jwksClients[authConfig.name] = new jwks_rsa_1.JwksClient({
|
|
32
|
+
jwksUri: authConfig.jwksUri,
|
|
33
|
+
cache: true,
|
|
34
|
+
rateLimit: true,
|
|
35
|
+
jwksRequestsPerMinute: 10,
|
|
36
|
+
requestAgent: new https_1.Agent({ rejectUnauthorized: false })
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
verifyTokenJwks(authConfig, token) {
|
|
42
|
+
if (!authConfig) {
|
|
43
|
+
this.logger.warn("No auth config provided for JWT verification");
|
|
44
|
+
return Promise.resolve(undefined);
|
|
45
|
+
}
|
|
46
|
+
if (!this.jwksClients[authConfig.name]) {
|
|
47
|
+
this.logger.warn(`No jwks client found for ${authConfig.name}`);
|
|
48
|
+
return Promise.resolve(undefined);
|
|
49
|
+
}
|
|
50
|
+
return new Promise((resolve, reject) => {
|
|
51
|
+
if (!token) {
|
|
52
|
+
this.logger.warn("No token provided for JWT verification");
|
|
53
|
+
resolve(undefined);
|
|
54
|
+
}
|
|
55
|
+
(0, jsonwebtoken_1.verify)(token, (header, callback) => {
|
|
56
|
+
this.jwksClients[authConfig.name].getSigningKey(header.kid, (err, key) => {
|
|
57
|
+
if (err) {
|
|
58
|
+
this.logger.error(`[JWKS] [${authConfig.name}] Error getting signing key`, err);
|
|
59
|
+
callback(err);
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
const signingKey = key.getPublicKey();
|
|
63
|
+
callback(null, signingKey);
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
}, {
|
|
67
|
+
issuer: authConfig.issuer,
|
|
68
|
+
audience: authConfig.audience,
|
|
69
|
+
algorithms: authConfig.algorithms
|
|
70
|
+
}, (err, decoded) => {
|
|
71
|
+
if (err) {
|
|
72
|
+
resolve(undefined);
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
resolve(decoded);
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
verifyTokenSecret(authConfig, token) {
|
|
80
|
+
if (!authConfig) {
|
|
81
|
+
return Promise.resolve(undefined);
|
|
82
|
+
}
|
|
83
|
+
return new Promise((resolve, reject) => {
|
|
84
|
+
if (!token) {
|
|
85
|
+
resolve(undefined);
|
|
86
|
+
}
|
|
87
|
+
(0, jsonwebtoken_1.verify)(token, authConfig.secret, {
|
|
88
|
+
issuer: authConfig.issuer,
|
|
89
|
+
audience: authConfig.audience,
|
|
90
|
+
algorithms: authConfig.algorithms
|
|
91
|
+
}, (err, decoded) => {
|
|
92
|
+
if (err) {
|
|
93
|
+
resolve(undefined);
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
resolve(decoded);
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
exports.JwtService = JwtService;
|
|
102
|
+
exports.JwtService = JwtService = JwtService_1 = __decorate([
|
|
103
|
+
(0, common_1.Injectable)(),
|
|
104
|
+
__param(0, (0, common_1.Inject)(const_1.RLB_AMQP_AUTH_OPTIONS)),
|
|
105
|
+
__metadata("design:paramtypes", [Array])
|
|
106
|
+
], JwtService);
|
|
107
|
+
//# sourceMappingURL=jwt.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwt.service.js","sourceRoot":"","sources":["../../../../libs/rlb-nestjs-amqp/src/modules/proxy/services/jwt.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { HttpService } from '@nestjs/axios';
|
|
2
|
+
import { OnModuleInit } from '@nestjs/common';
|
|
3
|
+
import { AmqpConnection } from "../../../amqp-lib";
|
|
4
|
+
import { BrokerConfig, BrokerService } from '../../broker';
|
|
5
|
+
import { GatewayConfig } from '../config/path-definition.config';
|
|
6
|
+
export declare class WebSocketService implements OnModuleInit {
|
|
7
|
+
private readonly amqpConnection;
|
|
8
|
+
private readonly httpClient;
|
|
9
|
+
private readonly broker;
|
|
10
|
+
private readonly gatewayConfig;
|
|
11
|
+
private readonly brokerConfig;
|
|
12
|
+
private server;
|
|
13
|
+
private readonly logger;
|
|
14
|
+
private readonly subjects;
|
|
15
|
+
private readonly subscriptions;
|
|
16
|
+
constructor(amqpConnection: AmqpConnection, httpClient: HttpService, broker: BrokerService, gatewayConfig: GatewayConfig, brokerConfig: BrokerConfig);
|
|
17
|
+
private handleDisconnect;
|
|
18
|
+
private handleConnection;
|
|
19
|
+
private getQueryParams;
|
|
20
|
+
onModuleInit(): Promise<void>;
|
|
21
|
+
}
|