@infineit-nestjs/services 1.0.10 → 1.0.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/types/helper.module.d.ts +4 -0
- package/dist/types/index.d.ts +9 -112
- package/dist/types/services/argon2.service.d.ts +7 -0
- package/dist/types/services/data.transformer.service.d.ts +6 -0
- package/dist/types/services/http.client.service.d.ts +22 -0
- package/dist/types/services/index.d.ts +8 -0
- package/dist/types/services/logger.service.d.ts +35 -0
- package/dist/types/services/merge.service.d.ts +14 -0
- package/dist/types/services/message.formatter.service.d.ts +9 -0
- package/dist/types/services/prisma.service.d.ts +20 -0
- package/dist/types/services/validator.service.d.ts +7 -0
- package/package.json +3 -2
package/dist/types/index.d.ts
CHANGED
|
@@ -1,112 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
declare class Argon2Service {
|
|
12
|
-
constructor();
|
|
13
|
-
hashPassword(password: string): Promise<string>;
|
|
14
|
-
verifyPassword(password: string, hash: string): Promise<boolean>;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
declare class DataTransformerService {
|
|
18
|
-
processData(processData: any[], fieldsToInclude: string[]): Promise<any[]>;
|
|
19
|
-
private processChunkWithWorker;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
interface ILogData {
|
|
25
|
-
organization?: string;
|
|
26
|
-
context?: string;
|
|
27
|
-
app?: string;
|
|
28
|
-
sourceClass?: string;
|
|
29
|
-
correlationId?: string;
|
|
30
|
-
error?: Error;
|
|
31
|
-
props?: NodeJS.Dict<any>;
|
|
32
|
-
}
|
|
33
|
-
declare enum LogLevel {
|
|
34
|
-
Emergency = "emergency",
|
|
35
|
-
Fatal = "fatal",
|
|
36
|
-
Error = "error",
|
|
37
|
-
Warn = "warn",
|
|
38
|
-
Info = "info",
|
|
39
|
-
Debug = "debug"
|
|
40
|
-
}
|
|
41
|
-
declare class LoggerService {
|
|
42
|
-
private logger;
|
|
43
|
-
constructor(logger: Logger);
|
|
44
|
-
log(level: LogLevel, message: string | Error, data?: ILogData, profile?: string): void;
|
|
45
|
-
debug(message: string, data?: ILogData, profile?: string): void;
|
|
46
|
-
info(message: string, data?: ILogData, profile?: string): void;
|
|
47
|
-
warn(message: string | Error, data?: ILogData, profile?: string): void;
|
|
48
|
-
error(message: string | Error, data?: ILogData, profile?: string): void;
|
|
49
|
-
fatal(message: string | Error, data?: ILogData, profile?: string): void;
|
|
50
|
-
emergency(message: string | Error, data?: ILogData, profile?: string): void;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
declare class HttpServiceClient {
|
|
54
|
-
private readonly configService;
|
|
55
|
-
private readonly loggerService;
|
|
56
|
-
private circuitBreaker;
|
|
57
|
-
private requestCounter;
|
|
58
|
-
private responseTimeHistogram;
|
|
59
|
-
constructor(configService: ConfigService, loggerService: LoggerService);
|
|
60
|
-
private configureMetrics;
|
|
61
|
-
private configureAxiosRetry;
|
|
62
|
-
private configureCircuitBreaker;
|
|
63
|
-
private callService;
|
|
64
|
-
private handleServiceError;
|
|
65
|
-
getResource(service: string, method: 'get' | 'post' | 'patch' | 'delete', endpoint: string, data?: any): Promise<any>;
|
|
66
|
-
private getServiceBaseURL;
|
|
67
|
-
getMultipleResources(services: string[], method: 'get' | 'post' | 'patch' | 'delete', endpoint: string, data?: any): Promise<any[]>;
|
|
68
|
-
getMultipleResourcesInBatch(services: string[], method: 'get' | 'post' | 'patch' | 'delete', endpoint: string, data?: any): Promise<any[]>;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
declare class MessageFormatterService {
|
|
72
|
-
static capitalizeFirstLetter(word: string): string;
|
|
73
|
-
static toLowerCase(word: string): string;
|
|
74
|
-
static formatMessage(template: string, label: string): string;
|
|
75
|
-
static toSingularOrPlural(word: string, count: number): string;
|
|
76
|
-
static prepareMessage(template: string, label: string, capitalize?: boolean): string;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
declare class MergeService {
|
|
80
|
-
mergeEntities<T extends Record<string, any>, R extends Record<string, any>>(baseData: T[], relatedDataMap: Record<string, any[]>, relationships: Record<string, {
|
|
81
|
-
foreignKey: keyof T;
|
|
82
|
-
filters?: Record<string, any>;
|
|
83
|
-
nestedRelationships?: Record<string, {
|
|
84
|
-
foreignKey: keyof R;
|
|
85
|
-
filters?: Record<string, any>;
|
|
86
|
-
}>;
|
|
87
|
-
}>, options?: {
|
|
88
|
-
flatten?: boolean;
|
|
89
|
-
}): Promise<T[]>;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
declare class PrismaService extends PrismaClient implements OnModuleInit, OnModuleDestroy {
|
|
93
|
-
private readonly configService;
|
|
94
|
-
constructor(configService: ConfigService<AllConfigType>);
|
|
95
|
-
onModuleInit(): Promise<void>;
|
|
96
|
-
onModuleDestroy(): Promise<void>;
|
|
97
|
-
executeRawQuery<T>(queryMethod: Function, ...args: any[]): Promise<T | T[] | null>;
|
|
98
|
-
private getQueryDetails;
|
|
99
|
-
private sanitizeData;
|
|
100
|
-
executeRawQueryOld(queryObj?: any, data?: any, fields?: string[]): Promise<any>;
|
|
101
|
-
executeTransaction(actions: (prisma: Prisma.TransactionClient) => Promise<any>): Promise<any>;
|
|
102
|
-
isHealthy(): Promise<HealthIndicatorResult>;
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
declare class ValidatorService {
|
|
106
|
-
isImage(mimeType: string): boolean;
|
|
107
|
-
isEmail(value: string): boolean;
|
|
108
|
-
isNumber(value: string): boolean;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
export { Argon2Service, DataTransformerService, HelperModule, HttpServiceClient, LogLevel, LoggerService, MergeService, MessageFormatterService, PrismaService, ValidatorService };
|
|
112
|
-
export type { ILogData };
|
|
1
|
+
export { HelperModule } from './helper.module.js';
|
|
2
|
+
export { Argon2Service } from './services/argon2.service.js';
|
|
3
|
+
export { DataTransformerService } from './services/data.transformer.service.js';
|
|
4
|
+
export { HttpServiceClient } from './services/http.client.service.js';
|
|
5
|
+
export { ILogData, LogLevel, LoggerService } from './services/logger.service.js';
|
|
6
|
+
export { MessageFormatterService } from './services/message.formatter.service.js';
|
|
7
|
+
export { MergeService } from './services/merge.service.js';
|
|
8
|
+
export { PrismaService } from './services/prisma.service.js';
|
|
9
|
+
export { ValidatorService } from './services/validator.service.js';
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { ConfigService } from '@nestjs/config';
|
|
2
|
+
import { LoggerService } from './logger.service.js';
|
|
3
|
+
|
|
4
|
+
declare class HttpServiceClient {
|
|
5
|
+
private readonly configService;
|
|
6
|
+
private readonly loggerService;
|
|
7
|
+
private circuitBreaker;
|
|
8
|
+
private requestCounter;
|
|
9
|
+
private responseTimeHistogram;
|
|
10
|
+
constructor(configService: ConfigService, loggerService: LoggerService);
|
|
11
|
+
private configureMetrics;
|
|
12
|
+
private configureAxiosRetry;
|
|
13
|
+
private configureCircuitBreaker;
|
|
14
|
+
private callService;
|
|
15
|
+
private handleServiceError;
|
|
16
|
+
getResource(service: string, method: 'get' | 'post' | 'patch' | 'delete', endpoint: string, data?: any): Promise<any>;
|
|
17
|
+
private getServiceBaseURL;
|
|
18
|
+
getMultipleResources(services: string[], method: 'get' | 'post' | 'patch' | 'delete', endpoint: string, data?: any): Promise<any[]>;
|
|
19
|
+
getMultipleResourcesInBatch(services: string[], method: 'get' | 'post' | 'patch' | 'delete', endpoint: string, data?: any): Promise<any[]>;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export { HttpServiceClient };
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { Argon2Service } from './argon2.service.js';
|
|
2
|
+
export { DataTransformerService } from './data.transformer.service.js';
|
|
3
|
+
export { HttpServiceClient } from './http.client.service.js';
|
|
4
|
+
export { ILogData, LogLevel, LoggerService } from './logger.service.js';
|
|
5
|
+
export { MessageFormatterService } from './message.formatter.service.js';
|
|
6
|
+
export { MergeService } from './merge.service.js';
|
|
7
|
+
export { PrismaService } from './prisma.service.js';
|
|
8
|
+
export { ValidatorService } from './validator.service.js';
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import type Logger from '@infineit/winston-logger/logger/domain/logger';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
interface ILogData {
|
|
6
|
+
organization?: string;
|
|
7
|
+
context?: string;
|
|
8
|
+
app?: string;
|
|
9
|
+
sourceClass?: string;
|
|
10
|
+
correlationId?: string;
|
|
11
|
+
error?: Error;
|
|
12
|
+
props?: NodeJS.Dict<any>;
|
|
13
|
+
}
|
|
14
|
+
declare enum LogLevel {
|
|
15
|
+
Emergency = "emergency",
|
|
16
|
+
Fatal = "fatal",
|
|
17
|
+
Error = "error",
|
|
18
|
+
Warn = "warn",
|
|
19
|
+
Info = "info",
|
|
20
|
+
Debug = "debug"
|
|
21
|
+
}
|
|
22
|
+
declare class LoggerService {
|
|
23
|
+
private logger;
|
|
24
|
+
constructor(logger: Logger);
|
|
25
|
+
log(level: LogLevel, message: string | Error, data?: ILogData, profile?: string): void;
|
|
26
|
+
debug(message: string, data?: ILogData, profile?: string): void;
|
|
27
|
+
info(message: string, data?: ILogData, profile?: string): void;
|
|
28
|
+
warn(message: string | Error, data?: ILogData, profile?: string): void;
|
|
29
|
+
error(message: string | Error, data?: ILogData, profile?: string): void;
|
|
30
|
+
fatal(message: string | Error, data?: ILogData, profile?: string): void;
|
|
31
|
+
emergency(message: string | Error, data?: ILogData, profile?: string): void;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export { LogLevel, LoggerService };
|
|
35
|
+
export type { ILogData };
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
declare class MergeService {
|
|
2
|
+
mergeEntities<T extends Record<string, any>, R extends Record<string, any>>(baseData: T[], relatedDataMap: Record<string, any[]>, relationships: Record<string, {
|
|
3
|
+
foreignKey: keyof T;
|
|
4
|
+
filters?: Record<string, any>;
|
|
5
|
+
nestedRelationships?: Record<string, {
|
|
6
|
+
foreignKey: keyof R;
|
|
7
|
+
filters?: Record<string, any>;
|
|
8
|
+
}>;
|
|
9
|
+
}>, options?: {
|
|
10
|
+
flatten?: boolean;
|
|
11
|
+
}): Promise<T[]>;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export { MergeService };
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
declare class MessageFormatterService {
|
|
2
|
+
static capitalizeFirstLetter(word: string): string;
|
|
3
|
+
static toLowerCase(word: string): string;
|
|
4
|
+
static formatMessage(template: string, label: string): string;
|
|
5
|
+
static toSingularOrPlural(word: string, count: number): string;
|
|
6
|
+
static prepareMessage(template: string, label: string, capitalize?: boolean): string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export { MessageFormatterService };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { OnModuleInit, OnModuleDestroy } from '@nestjs/common';
|
|
2
|
+
import { ConfigService } from '@nestjs/config';
|
|
3
|
+
import { HealthIndicatorResult } from '@nestjs/terminus';
|
|
4
|
+
import { AllConfigType } from '@infineit-nestjs/types';
|
|
5
|
+
import { PrismaClient, Prisma } from '@prisma/client';
|
|
6
|
+
|
|
7
|
+
declare class PrismaService extends PrismaClient implements OnModuleInit, OnModuleDestroy {
|
|
8
|
+
private readonly configService;
|
|
9
|
+
constructor(configService: ConfigService<AllConfigType>);
|
|
10
|
+
onModuleInit(): Promise<void>;
|
|
11
|
+
onModuleDestroy(): Promise<void>;
|
|
12
|
+
executeRawQuery<T>(queryMethod: Function, ...args: any[]): Promise<T | T[] | null>;
|
|
13
|
+
private getQueryDetails;
|
|
14
|
+
private sanitizeData;
|
|
15
|
+
executeRawQueryOld(queryObj?: any, data?: any, fields?: string[]): Promise<any>;
|
|
16
|
+
executeTransaction(actions: (prisma: Prisma.TransactionClient) => Promise<any>): Promise<any>;
|
|
17
|
+
isHealthy(): Promise<HealthIndicatorResult>;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export { PrismaService };
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@infineit-nestjs/services",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.11",
|
|
4
4
|
"main": "./dist/cjs/index.js",
|
|
5
5
|
"module": "./dist/es/index.mjs",
|
|
6
6
|
"exports": {
|
|
@@ -58,6 +58,7 @@
|
|
|
58
58
|
"reflect-metadata": "^0.2.2",
|
|
59
59
|
"rollup": "^4.34.8",
|
|
60
60
|
"rollup-plugin-dts": "^6.1.1",
|
|
61
|
+
"rollup-plugin-multi-input": "^1.5.0",
|
|
61
62
|
"rollup-plugin-peer-deps-external": "^2.2.4",
|
|
62
63
|
"rollup-plugin-preserve-directives": "^0.4.0",
|
|
63
64
|
"rxjs": "^7.8.2",
|
|
@@ -79,5 +80,5 @@
|
|
|
79
80
|
"publishConfig": {
|
|
80
81
|
"access": "public"
|
|
81
82
|
},
|
|
82
|
-
"gitHead": "
|
|
83
|
+
"gitHead": "00f2ecdac88859957d60b018a6e7118ae6da974b"
|
|
83
84
|
}
|