@andretimm/pharus 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.
Files changed (42) hide show
  1. package/README.md +175 -0
  2. package/dist/core/collector.d.ts +18 -0
  3. package/dist/core/collector.js +61 -0
  4. package/dist/core/collector.js.map +1 -0
  5. package/dist/core/collector.spec.d.ts +1 -0
  6. package/dist/core/collector.spec.js +50 -0
  7. package/dist/core/collector.spec.js.map +1 -0
  8. package/dist/core/transport.d.ts +6 -0
  9. package/dist/core/transport.js +29 -0
  10. package/dist/core/transport.js.map +1 -0
  11. package/dist/core/types.d.ts +36 -0
  12. package/dist/core/types.js +3 -0
  13. package/dist/core/types.js.map +1 -0
  14. package/dist/core/utils.d.ts +7 -0
  15. package/dist/core/utils.js +97 -0
  16. package/dist/core/utils.js.map +1 -0
  17. package/dist/express/index.d.ts +1 -0
  18. package/dist/express/index.js +18 -0
  19. package/dist/express/index.js.map +1 -0
  20. package/dist/express/middleware.d.ts +3 -0
  21. package/dist/express/middleware.js +25 -0
  22. package/dist/express/middleware.js.map +1 -0
  23. package/dist/fastify/index.d.ts +3 -0
  24. package/dist/fastify/index.js +10 -0
  25. package/dist/fastify/index.js.map +1 -0
  26. package/dist/fastify/plugin.d.ts +4 -0
  27. package/dist/fastify/plugin.js +31 -0
  28. package/dist/fastify/plugin.js.map +1 -0
  29. package/dist/index.d.ts +2 -0
  30. package/dist/index.js +19 -0
  31. package/dist/index.js.map +1 -0
  32. package/dist/nestjs/index.d.ts +2 -0
  33. package/dist/nestjs/index.js +19 -0
  34. package/dist/nestjs/index.js.map +1 -0
  35. package/dist/nestjs/interceptor.d.ts +11 -0
  36. package/dist/nestjs/interceptor.js +80 -0
  37. package/dist/nestjs/interceptor.js.map +1 -0
  38. package/dist/nestjs/module.d.ts +10 -0
  39. package/dist/nestjs/module.js +67 -0
  40. package/dist/nestjs/module.js.map +1 -0
  41. package/dist/tsconfig.tsbuildinfo +1 -0
  42. package/package.json +89 -0
package/dist/index.js ADDED
@@ -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("./core/types"), exports);
18
+ __exportStar(require("./core/collector"), exports);
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA6B;AAC7B,mDAAiC"}
@@ -0,0 +1,2 @@
1
+ export * from './module';
2
+ export * from './interceptor';
@@ -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("./module"), exports);
18
+ __exportStar(require("./interceptor"), exports);
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/nestjs/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB;AACzB,gDAA8B"}
@@ -0,0 +1,11 @@
1
+ import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
2
+ import { Observable } from 'rxjs';
3
+ import { MetricsCollector } from '../core/collector';
4
+ import { MetricsOptions } from '../core/types';
5
+ export declare class MetricsInterceptor implements NestInterceptor {
6
+ private readonly collector;
7
+ private readonly options;
8
+ private readonly logger;
9
+ constructor(collector: MetricsCollector, options: MetricsOptions);
10
+ intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
11
+ }
@@ -0,0 +1,80 @@
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 MetricsInterceptor_1;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.MetricsInterceptor = void 0;
17
+ const common_1 = require("@nestjs/common");
18
+ const rxjs_1 = require("rxjs");
19
+ const operators_1 = require("rxjs/operators");
20
+ const collector_1 = require("../core/collector");
21
+ const utils_1 = require("../core/utils");
22
+ const uuid_1 = require("uuid");
23
+ let MetricsInterceptor = MetricsInterceptor_1 = class MetricsInterceptor {
24
+ constructor(collector, options) {
25
+ this.collector = collector;
26
+ this.options = options;
27
+ this.logger = new common_1.Logger(MetricsInterceptor_1.name);
28
+ }
29
+ intercept(context, next) {
30
+ var _a;
31
+ const type = context.getType();
32
+ if (type !== 'http') {
33
+ return next.handle();
34
+ }
35
+ const httpContext = context.switchToHttp();
36
+ const req = httpContext.getRequest();
37
+ const res = httpContext.getResponse();
38
+ const startTime = Date.now();
39
+ const requestId = req.id || req.requestId || (0, uuid_1.v4)();
40
+ if (!req.id && !req.requestId) {
41
+ req.requestId = requestId;
42
+ }
43
+ const method = req.method;
44
+ const url = req.url || req.originalUrl;
45
+ const ip = req.ip || ((_a = req.socket) === null || _a === void 0 ? void 0 : _a.remoteAddress);
46
+ const userAgent = req.headers['user-agent'];
47
+ let requestSize = 0;
48
+ if (req.headers && req.headers['content-length']) {
49
+ requestSize = parseInt(req.headers['content-length'], 10);
50
+ }
51
+ return next.handle().pipe((0, operators_1.tap)((data) => {
52
+ const duration = Date.now() - startTime;
53
+ if (!res.getHeader || !res.getHeader('content-length')) {
54
+ }
55
+ const metric = utils_1.MetricsExtractor.extract(this.options, req, res, duration, requestId);
56
+ if (metric.responseSize === 0 && data) {
57
+ metric.responseSize = utils_1.MetricsExtractor.calculateResponseSize(data);
58
+ }
59
+ this.collector.add(metric);
60
+ }), (0, operators_1.catchError)((error) => {
61
+ const duration = Date.now() - startTime;
62
+ let statusCode = 500;
63
+ if (error instanceof common_1.HttpException) {
64
+ statusCode = error.getStatus();
65
+ }
66
+ const metric = utils_1.MetricsExtractor.extract(this.options, req, Object.assign(Object.assign({}, res), { statusCode }), duration, requestId);
67
+ metric.statusCode = statusCode;
68
+ metric.error = error.message;
69
+ this.collector.add(metric);
70
+ return (0, rxjs_1.throwError)(() => error);
71
+ }));
72
+ }
73
+ };
74
+ exports.MetricsInterceptor = MetricsInterceptor;
75
+ exports.MetricsInterceptor = MetricsInterceptor = MetricsInterceptor_1 = __decorate([
76
+ (0, common_1.Injectable)(),
77
+ __param(1, (0, common_1.Inject)('METRICS_OPTIONS')),
78
+ __metadata("design:paramtypes", [collector_1.MetricsCollector, Object])
79
+ ], MetricsInterceptor);
80
+ //# sourceMappingURL=interceptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interceptor.js","sourceRoot":"","sources":["../../src/nestjs/interceptor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { DynamicModule } from '@nestjs/common';
2
+ import { MetricsOptions } from '../core/types';
3
+ export declare class MetricsModule {
4
+ static forRoot(options: MetricsOptions): DynamicModule;
5
+ static forRootAsync(options: {
6
+ useFactory: (...args: any[]) => Promise<MetricsOptions> | MetricsOptions;
7
+ inject?: any[];
8
+ imports?: any[];
9
+ }): DynamicModule;
10
+ }
@@ -0,0 +1,67 @@
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 MetricsModule_1;
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.MetricsModule = void 0;
11
+ const common_1 = require("@nestjs/common");
12
+ const core_1 = require("@nestjs/core");
13
+ const collector_1 = require("../core/collector");
14
+ const interceptor_1 = require("./interceptor");
15
+ let MetricsModule = MetricsModule_1 = class MetricsModule {
16
+ static forRoot(options) {
17
+ return {
18
+ module: MetricsModule_1,
19
+ providers: [
20
+ {
21
+ provide: 'METRICS_OPTIONS',
22
+ useValue: options,
23
+ },
24
+ {
25
+ provide: collector_1.MetricsCollector,
26
+ useFactory: (opts) => collector_1.MetricsCollector.initialize(opts),
27
+ inject: ['METRICS_OPTIONS'],
28
+ },
29
+ interceptor_1.MetricsInterceptor,
30
+ {
31
+ provide: core_1.APP_INTERCEPTOR,
32
+ useClass: interceptor_1.MetricsInterceptor,
33
+ },
34
+ ],
35
+ exports: [collector_1.MetricsCollector, interceptor_1.MetricsInterceptor],
36
+ };
37
+ }
38
+ static forRootAsync(options) {
39
+ return {
40
+ module: MetricsModule_1,
41
+ imports: options.imports || [],
42
+ providers: [
43
+ {
44
+ provide: 'METRICS_OPTIONS',
45
+ useFactory: options.useFactory,
46
+ inject: options.inject || [],
47
+ },
48
+ {
49
+ provide: collector_1.MetricsCollector,
50
+ useFactory: (opts) => collector_1.MetricsCollector.initialize(opts),
51
+ inject: ['METRICS_OPTIONS'],
52
+ },
53
+ interceptor_1.MetricsInterceptor,
54
+ {
55
+ provide: core_1.APP_INTERCEPTOR,
56
+ useClass: interceptor_1.MetricsInterceptor,
57
+ },
58
+ ],
59
+ exports: [collector_1.MetricsCollector, interceptor_1.MetricsInterceptor],
60
+ };
61
+ }
62
+ };
63
+ exports.MetricsModule = MetricsModule;
64
+ exports.MetricsModule = MetricsModule = MetricsModule_1 = __decorate([
65
+ (0, common_1.Global)()
66
+ ], MetricsModule);
67
+ //# sourceMappingURL=module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"module.js","sourceRoot":"","sources":["../../src/nestjs/module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAuD;AACvD,uCAA+C;AAC/C,iDAAqD;AAErD,+CAAmD;AAG5C,IAAM,aAAa,qBAAnB,MAAM,aAAa;IACxB,MAAM,CAAC,OAAO,CAAC,OAAuB;QACpC,OAAO;YACL,MAAM,EAAE,eAAa;YACrB,SAAS,EAAE;gBACT;oBACE,OAAO,EAAE,iBAAiB;oBAC1B,QAAQ,EAAE,OAAO;iBAClB;gBACD;oBACE,OAAO,EAAE,4BAAgB;oBACzB,UAAU,EAAE,CAAC,IAAoB,EAAE,EAAE,CAAC,4BAAgB,CAAC,UAAU,CAAC,IAAI,CAAC;oBACvE,MAAM,EAAE,CAAC,iBAAiB,CAAC;iBAC5B;gBACD,gCAAkB;gBAClB;oBACE,OAAO,EAAE,sBAAe;oBACxB,QAAQ,EAAE,gCAAkB;iBAC7B;aACF;YACD,OAAO,EAAE,CAAC,4BAAgB,EAAE,gCAAkB,CAAC;SAChD,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,YAAY,CAAC,OAInB;QACC,OAAO;YACL,MAAM,EAAE,eAAa;YACrB,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,EAAE;YAC9B,SAAS,EAAE;gBACT;oBACE,OAAO,EAAE,iBAAiB;oBAC1B,UAAU,EAAE,OAAO,CAAC,UAAU;oBAC9B,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,EAAE;iBAC7B;gBACD;oBACE,OAAO,EAAE,4BAAgB;oBACzB,UAAU,EAAE,CAAC,IAAoB,EAAE,EAAE,CAAC,4BAAgB,CAAC,UAAU,CAAC,IAAI,CAAC;oBACvE,MAAM,EAAE,CAAC,iBAAiB,CAAC;iBAC5B;gBACD,gCAAkB;gBAClB;oBACE,OAAO,EAAE,sBAAe;oBACxB,QAAQ,EAAE,gCAAkB;iBAC7B;aACF;YACD,OAAO,EAAE,CAAC,4BAAgB,EAAE,gCAAkB,CAAC;SAChD,CAAC;IACJ,CAAC;CACF,CAAA;AApDY,sCAAa;wBAAb,aAAa;IADzB,IAAA,eAAM,GAAE;GACI,aAAa,CAoDzB"}