@aristid/leav-types 1.4.1-9e3f8604 → 1.4.1-a44cd133
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/apps/core/config/default.d.ts +23 -9
- package/apps/core/config/development.d.ts +0 -4
- package/apps/core/config/test.d.ts +31 -3
- package/apps/core/src/__tests__/e2e/api/e2eUtils.d.ts +4 -0
- package/apps/core/src/__tests__/e2e/api/export/export.test.d.ts +1 -0
- package/apps/core/src/__tests__/e2e/api/mailpitUtils.d.ts +21 -0
- package/apps/core/src/_types/config.d.ts +23 -5
- package/apps/core/src/_types/forms.d.ts +2 -2
- package/apps/core/src/_types/notification.d.ts +51 -0
- package/apps/core/src/_types/userData.d.ts +10 -0
- package/apps/core/src/domain/export/exportDomain.d.ts +3 -1
- package/apps/core/src/domain/logsCollector/logsCollectorDomain.d.ts +3 -3
- package/apps/core/src/domain/notification/channels/emailChannel.d.ts +12 -0
- package/apps/core/src/domain/notification/channels/webSocketChannel.d.ts +6 -0
- package/apps/core/src/domain/notification/index.d.ts +3 -0
- package/apps/core/src/domain/notification/notificationDomain.d.ts +12 -0
- package/apps/core/src/domain/user/userDomain.d.ts +5 -2
- package/apps/core/src/domain/value/valueDomain.d.ts +0 -5
- package/apps/core/src/infra/{elasticSearch/elasticSearchService.d.ts → elasticsearch/elasticsearchService.d.ts} +4 -4
- package/apps/core/src/infra/elasticsearch/index.d.ts +1 -0
- package/apps/core/src/infra/log/logRepo.d.ts +3 -3
- package/libs/logger/src/LoggerCallStack.d.ts +14 -0
- package/libs/logger/src/catchErrorFormatter.d.ts +2 -0
- package/libs/logger/src/config.d.ts +32 -3
- package/libs/logger/src/locationInfoFormatter.d.ts +2 -0
- package/libs/message-broker/src/amqpService.d.ts +2 -2
- package/libs/message-broker/src/types/amqp.d.ts +1 -1
- package/package.json +1 -1
- package/apps/core/src/infra/elasticSearch/index.d.ts +0 -1
- package/libs/logger/src/locationInfoFormatters.d.ts +0 -10
- /package/apps/core/src/infra/{elasticSearch/elasticSearchClient.d.ts → elasticsearch/elasticsearchClient.d.ts} +0 -0
|
@@ -63,6 +63,13 @@ export declare namespace mailer {
|
|
|
63
63
|
export { port_1 as port };
|
|
64
64
|
let secure_1: boolean;
|
|
65
65
|
export { secure_1 as secure };
|
|
66
|
+
export let requireTLS: boolean;
|
|
67
|
+
export namespace from {
|
|
68
|
+
let name_1: string;
|
|
69
|
+
export { name_1 as name };
|
|
70
|
+
let email_2: string;
|
|
71
|
+
export { email_2 as email };
|
|
72
|
+
}
|
|
66
73
|
export namespace auth_1 {
|
|
67
74
|
export let user: string;
|
|
68
75
|
let password_1: string;
|
|
@@ -90,12 +97,6 @@ export declare namespace lang {
|
|
|
90
97
|
let _default: string;
|
|
91
98
|
export { _default as default };
|
|
92
99
|
}
|
|
93
|
-
export declare namespace logs {
|
|
94
|
-
let level: string;
|
|
95
|
-
let transport: string;
|
|
96
|
-
let destinationFile: string;
|
|
97
|
-
let useJsonFormat: boolean;
|
|
98
|
-
}
|
|
99
100
|
export declare namespace permissions {
|
|
100
101
|
let _default_1: boolean;
|
|
101
102
|
export { _default_1 as default };
|
|
@@ -200,6 +201,19 @@ export declare namespace preview {
|
|
|
200
201
|
let directory_3: string;
|
|
201
202
|
export { directory_3 as directory };
|
|
202
203
|
}
|
|
204
|
+
export declare namespace notification {
|
|
205
|
+
let enable_3: boolean;
|
|
206
|
+
export { enable_3 as enable };
|
|
207
|
+
export namespace email_3 {
|
|
208
|
+
let enable_4: boolean;
|
|
209
|
+
export { enable_4 as enable };
|
|
210
|
+
}
|
|
211
|
+
export { email_3 as email };
|
|
212
|
+
export namespace webSocket {
|
|
213
|
+
let enable_5: boolean;
|
|
214
|
+
export { enable_5 as enable };
|
|
215
|
+
}
|
|
216
|
+
}
|
|
203
217
|
export declare namespace applications {
|
|
204
218
|
let rootFolder: string;
|
|
205
219
|
}
|
|
@@ -208,10 +222,10 @@ export declare namespace files {
|
|
|
208
222
|
let originalsPathPrefix: string;
|
|
209
223
|
}
|
|
210
224
|
export declare namespace dbProfiler {
|
|
211
|
-
let
|
|
212
|
-
export {
|
|
225
|
+
let enable_6: boolean;
|
|
226
|
+
export { enable_6 as enable };
|
|
213
227
|
}
|
|
214
|
-
export declare namespace
|
|
228
|
+
export declare namespace elasticsearch {
|
|
215
229
|
export let indexPrefix: string;
|
|
216
230
|
let url_2: string;
|
|
217
231
|
export { url_2 as url };
|
|
@@ -6,6 +6,10 @@ export namespace server {
|
|
|
6
6
|
let password: string;
|
|
7
7
|
let email: string;
|
|
8
8
|
}
|
|
9
|
+
namespace systemUser {
|
|
10
|
+
let email_1: string;
|
|
11
|
+
export { email_1 as email };
|
|
12
|
+
}
|
|
9
13
|
let allowIntrospection: boolean;
|
|
10
14
|
}
|
|
11
15
|
export namespace db {
|
|
@@ -34,19 +38,43 @@ export namespace indexationManager {
|
|
|
34
38
|
export { queues_1 as queues };
|
|
35
39
|
}
|
|
36
40
|
export namespace tasksManager {
|
|
41
|
+
export let checkingInterval: number;
|
|
37
42
|
export namespace queues_2 {
|
|
38
|
-
let
|
|
43
|
+
let execOrders: string;
|
|
44
|
+
let cancelOrders: string;
|
|
39
45
|
}
|
|
40
46
|
export { queues_2 as queues };
|
|
41
47
|
export namespace routingKeys_1 {
|
|
42
|
-
let
|
|
43
|
-
export {
|
|
48
|
+
let execOrders_1: string;
|
|
49
|
+
export { execOrders_1 as execOrders };
|
|
50
|
+
let cancelOrders_1: string;
|
|
51
|
+
export { cancelOrders_1 as cancelOrders };
|
|
44
52
|
}
|
|
45
53
|
export { routingKeys_1 as routingKeys };
|
|
46
54
|
}
|
|
47
55
|
export namespace logs {
|
|
48
56
|
let transport: string;
|
|
49
57
|
}
|
|
58
|
+
export namespace notification {
|
|
59
|
+
export let enable: boolean;
|
|
60
|
+
export namespace email_2 {
|
|
61
|
+
let enable_1: boolean;
|
|
62
|
+
export { enable_1 as enable };
|
|
63
|
+
}
|
|
64
|
+
export { email_2 as email };
|
|
65
|
+
export namespace webSocket {
|
|
66
|
+
let enable_2: boolean;
|
|
67
|
+
export { enable_2 as enable };
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
export namespace mailer {
|
|
71
|
+
namespace from {
|
|
72
|
+
let name_1: string;
|
|
73
|
+
export { name_1 as name };
|
|
74
|
+
let email_3: string;
|
|
75
|
+
export { email_3 as email };
|
|
76
|
+
}
|
|
77
|
+
}
|
|
50
78
|
export let debug: boolean;
|
|
51
79
|
export namespace redis {
|
|
52
80
|
let database: number;
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import type WebSocket from 'ws';
|
|
1
2
|
import type FormData from 'form-data';
|
|
2
3
|
import { type ActionsListConfig } from '_types/actionsList';
|
|
3
4
|
import { type ITreeElement } from '_types/tree';
|
|
@@ -41,3 +42,6 @@ export declare function gqlSaveVersionProfile(profileId: string, label: string,
|
|
|
41
42
|
* Convert object to JSON, escaping quotes to be able to use it in a graphql query
|
|
42
43
|
**/
|
|
43
44
|
export declare function toCleanJSON(obj: {}): string;
|
|
45
|
+
export declare function waitWebSocketMessage<T>(webSocket: WebSocket, acceptMessage: (msg: T) => boolean, { timeoutMs }: {
|
|
46
|
+
timeoutMs: any;
|
|
47
|
+
}): Promise<T>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
interface IMailpitMsgLight {
|
|
2
|
+
From: {
|
|
3
|
+
Name: string;
|
|
4
|
+
Address: string;
|
|
5
|
+
};
|
|
6
|
+
ID: string;
|
|
7
|
+
MessageID: string;
|
|
8
|
+
Read: boolean;
|
|
9
|
+
Size: number;
|
|
10
|
+
Subject: string;
|
|
11
|
+
To: Array<{
|
|
12
|
+
Name: string;
|
|
13
|
+
Address: string;
|
|
14
|
+
}>;
|
|
15
|
+
}
|
|
16
|
+
interface IMailpitMsgFull extends IMailpitMsgLight {
|
|
17
|
+
HTML: string;
|
|
18
|
+
Text: string;
|
|
19
|
+
}
|
|
20
|
+
export declare function waitMailpitMessage(acceptMessage: (msg: IMailpitMsgLight) => boolean): Promise<IMailpitMsgFull>;
|
|
21
|
+
export {};
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { type ILoggerConfig } from '@leav/logger';
|
|
2
1
|
import { type Options } from 'amqplib';
|
|
3
2
|
import { type IKeyValue } from './shared';
|
|
4
3
|
export interface IConfig {
|
|
@@ -10,7 +9,6 @@ export interface IConfig {
|
|
|
10
9
|
auth: IAuth;
|
|
11
10
|
mailer: IMailer;
|
|
12
11
|
lang: ILang;
|
|
13
|
-
logs: ILogs;
|
|
14
12
|
permissions: IPermissions;
|
|
15
13
|
amqp: IAmqp;
|
|
16
14
|
redis: IRedis;
|
|
@@ -18,6 +16,7 @@ export interface IConfig {
|
|
|
18
16
|
indexationManager: IIndexationManager;
|
|
19
17
|
tasksManager: ITasksManager;
|
|
20
18
|
eventsManager: IEventsManager;
|
|
19
|
+
notification: INotificationConfig;
|
|
21
20
|
debug?: boolean;
|
|
22
21
|
env?: string;
|
|
23
22
|
defaultUserId: string;
|
|
@@ -29,7 +28,7 @@ export interface IConfig {
|
|
|
29
28
|
files: IFilesConfig;
|
|
30
29
|
dbProfiler: IDbProfilerConfig;
|
|
31
30
|
instanceId: string;
|
|
32
|
-
|
|
31
|
+
elasticsearch: IElasticsearchConfig;
|
|
33
32
|
logsCollector: ILogsCollector;
|
|
34
33
|
pluginsPath: string[];
|
|
35
34
|
bugsnag: IBugsnag;
|
|
@@ -99,7 +98,18 @@ export interface IAuth {
|
|
|
99
98
|
export interface IMailer {
|
|
100
99
|
host: string;
|
|
101
100
|
port: number;
|
|
101
|
+
/**
|
|
102
|
+
* If true, use SSL/TLS connection (usually port 465). If false, use STARTTLS (usually port 587)
|
|
103
|
+
*/
|
|
102
104
|
secure: boolean;
|
|
105
|
+
/**
|
|
106
|
+
* If true, require TLS for the connection (STARTTLS). Only used if secure is false
|
|
107
|
+
*/
|
|
108
|
+
requireTLS: boolean;
|
|
109
|
+
from: {
|
|
110
|
+
name: string;
|
|
111
|
+
email: string;
|
|
112
|
+
};
|
|
103
113
|
auth: {
|
|
104
114
|
user: string;
|
|
105
115
|
password: string;
|
|
@@ -109,7 +119,6 @@ export interface ILang {
|
|
|
109
119
|
available: string[];
|
|
110
120
|
default: string;
|
|
111
121
|
}
|
|
112
|
-
export type ILogs = ILoggerConfig;
|
|
113
122
|
export interface IPermissions {
|
|
114
123
|
default: boolean;
|
|
115
124
|
enableCache: boolean;
|
|
@@ -225,7 +234,16 @@ export interface IFilesConfig {
|
|
|
225
234
|
export interface IDbProfilerConfig {
|
|
226
235
|
enable: boolean;
|
|
227
236
|
}
|
|
228
|
-
export interface
|
|
237
|
+
export interface INotificationConfig {
|
|
238
|
+
enable: boolean;
|
|
239
|
+
email: {
|
|
240
|
+
enable: boolean;
|
|
241
|
+
};
|
|
242
|
+
webSocket: {
|
|
243
|
+
enable: boolean;
|
|
244
|
+
};
|
|
245
|
+
}
|
|
246
|
+
export interface IElasticsearchConfig {
|
|
229
247
|
indexPrefix: string;
|
|
230
248
|
url: string;
|
|
231
249
|
ilmPolicyName: string;
|
|
@@ -22,8 +22,8 @@ export interface IRecordForm {
|
|
|
22
22
|
sidePanel: IFormSidePanel;
|
|
23
23
|
}
|
|
24
24
|
export declare enum FormElementTypes {
|
|
25
|
-
|
|
26
|
-
|
|
25
|
+
FIELD = "field",
|
|
26
|
+
LAYOUT = "layout"
|
|
27
27
|
}
|
|
28
28
|
export type IFormStrict = Required<IForm>;
|
|
29
29
|
export interface IFormElementsDependency {
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { type IQueryInfos } from './queryInfos';
|
|
2
|
+
export interface INotification {
|
|
3
|
+
/**
|
|
4
|
+
* Timestamp of the notification creation in milliseconds since epoch
|
|
5
|
+
*/
|
|
6
|
+
date: number;
|
|
7
|
+
/**
|
|
8
|
+
* User ID of the notification recipient
|
|
9
|
+
*/
|
|
10
|
+
recipientUserId: string;
|
|
11
|
+
content: INotificationContent;
|
|
12
|
+
}
|
|
13
|
+
export interface INotificationContent {
|
|
14
|
+
level: 'info' | 'warning';
|
|
15
|
+
title: string;
|
|
16
|
+
message: string;
|
|
17
|
+
relatedEntities?: Array<{
|
|
18
|
+
url: string;
|
|
19
|
+
label: string;
|
|
20
|
+
}>;
|
|
21
|
+
attachments?: Array<{
|
|
22
|
+
url: string;
|
|
23
|
+
label: string;
|
|
24
|
+
}>;
|
|
25
|
+
}
|
|
26
|
+
export interface ICreateNotification {
|
|
27
|
+
emitterUserId: string;
|
|
28
|
+
/**
|
|
29
|
+
* Recipients of the notification, need at least one userId or groupId
|
|
30
|
+
*/
|
|
31
|
+
recipients: {
|
|
32
|
+
userIds: string[];
|
|
33
|
+
/**
|
|
34
|
+
* No implementation yet
|
|
35
|
+
*/
|
|
36
|
+
groupIds: string[];
|
|
37
|
+
};
|
|
38
|
+
/**
|
|
39
|
+
* Priority of the notification, may change which channel is used to send it (no yet implemented)
|
|
40
|
+
*/
|
|
41
|
+
priority: 'urgent' | 'normal';
|
|
42
|
+
content: INotificationContent;
|
|
43
|
+
}
|
|
44
|
+
export declare enum NotificationChannels {
|
|
45
|
+
EMAIL = "email",
|
|
46
|
+
WEB_SOCKET = "web_socket"
|
|
47
|
+
}
|
|
48
|
+
export interface INotificationChannel {
|
|
49
|
+
type: NotificationChannels;
|
|
50
|
+
sendNotifications(notifications: INotification[], ctx: IQueryInfos): Promise<void>;
|
|
51
|
+
}
|
|
@@ -2,3 +2,13 @@ export interface IUserData {
|
|
|
2
2
|
global: boolean;
|
|
3
3
|
data: any;
|
|
4
4
|
}
|
|
5
|
+
/**
|
|
6
|
+
* Same idea as IRecordIdentity but for users
|
|
7
|
+
*/
|
|
8
|
+
export interface IUserIdentity {
|
|
9
|
+
id: string;
|
|
10
|
+
/**
|
|
11
|
+
* @throw if user have no email
|
|
12
|
+
*/
|
|
13
|
+
getEmail: () => Promise<string>;
|
|
14
|
+
}
|
|
@@ -11,6 +11,7 @@ import { type IQueryInfos } from '../../_types/queryInfos';
|
|
|
11
11
|
import { type IRecordFilterLight } from '../../_types/record';
|
|
12
12
|
import { type ITaskFuncParams } from '../../_types/tasksManager';
|
|
13
13
|
import { type IValidateHelper } from '../helpers/validate';
|
|
14
|
+
import { type INotificationDomain } from 'domain/notification/notificationDomain';
|
|
14
15
|
export interface IExportParams {
|
|
15
16
|
library: string;
|
|
16
17
|
attributes: string[];
|
|
@@ -39,8 +40,9 @@ export interface IExportDomainDeps {
|
|
|
39
40
|
'core.domain.helpers.validate': IValidateHelper;
|
|
40
41
|
'core.domain.helpers.updateTaskProgress': UpdateTaskProgress;
|
|
41
42
|
'core.domain.eventsManager': IEventsManagerDomain;
|
|
43
|
+
'core.domain.notification': INotificationDomain;
|
|
42
44
|
'core.utils': IUtils;
|
|
43
45
|
translator: i18n;
|
|
44
46
|
config: Config.IConfig;
|
|
45
47
|
}
|
|
46
|
-
export default function ({ config, 'core.domain.record': recordDomain, 'core.domain.helpers.validate': validateHelper, 'core.domain.attribute': attributeDomain, 'core.domain.library': libraryDomain, 'core.domain.tasksManager': tasksManager, 'core.domain.helpers.updateTaskProgress': updateTaskProgress, 'core.domain.eventsManager': eventsManagerDomain, 'core.utils': utils, translator }: IExportDomainDeps): IExportDomain;
|
|
48
|
+
export default function ({ config, 'core.domain.record': recordDomain, 'core.domain.helpers.validate': validateHelper, 'core.domain.attribute': attributeDomain, 'core.domain.library': libraryDomain, 'core.domain.tasksManager': tasksManager, 'core.domain.helpers.updateTaskProgress': updateTaskProgress, 'core.domain.eventsManager': eventsManagerDomain, 'core.domain.notification': notificationDomain, 'core.utils': utils, translator }: IExportDomainDeps): IExportDomain;
|
|
@@ -2,7 +2,7 @@ import { type IAmqpService } from '@leav/message-broker';
|
|
|
2
2
|
import { type ILogger } from '@leav/logger';
|
|
3
3
|
import type * as Config from '_types/config';
|
|
4
4
|
import { type IIndexationService } from '../../infra/indexation/indexationService';
|
|
5
|
-
import { type
|
|
5
|
+
import { type IElasticsearchService } from '../../infra/elasticsearch/elasticsearchService';
|
|
6
6
|
export interface ILogsCollectorDomain {
|
|
7
7
|
init(): Promise<void>;
|
|
8
8
|
}
|
|
@@ -11,6 +11,6 @@ export interface ILogsCollectorDomainDeps {
|
|
|
11
11
|
'core.infra.amqpService': IAmqpService;
|
|
12
12
|
'core.infra.indexation.indexationService': IIndexationService;
|
|
13
13
|
'core.utils.logger': ILogger;
|
|
14
|
-
'core.infra.
|
|
14
|
+
'core.infra.elasticsearch.service': IElasticsearchService;
|
|
15
15
|
}
|
|
16
|
-
export default function ({ config, 'core.infra.amqpService': amqpService, 'core.infra.indexation.indexationService': indexationService, 'core.utils.logger': logger, 'core.infra.
|
|
16
|
+
export default function ({ config, 'core.infra.amqpService': amqpService, 'core.infra.indexation.indexationService': indexationService, 'core.utils.logger': logger, 'core.infra.elasticsearch.service': esService }: ILogsCollectorDomainDeps): ILogsCollectorDomain;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type INotificationChannel } from '../../../_types/notification';
|
|
2
|
+
import { type IMailerService } from 'infra/mailer/mailerService';
|
|
3
|
+
import { type IUserDomain } from 'domain/user/userDomain';
|
|
4
|
+
import { type IGlobalSettingsDomain } from 'domain/globalSettings/globalSettingsDomain';
|
|
5
|
+
import { type IConfig } from '_types/config';
|
|
6
|
+
export interface INotificationByEmailChannelDeps {
|
|
7
|
+
config: IConfig;
|
|
8
|
+
'core.infra.mailer.mailerService': IMailerService;
|
|
9
|
+
'core.domain.globalSettings': IGlobalSettingsDomain;
|
|
10
|
+
'core.domain.user': IUserDomain;
|
|
11
|
+
}
|
|
12
|
+
export default function ({ config, 'core.infra.mailer.mailerService': mailerService, 'core.domain.globalSettings': globalSettingsDomain, 'core.domain.user': userDomain }: INotificationByEmailChannelDeps): INotificationChannel;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { type INotificationChannel } from '../../../_types/notification';
|
|
2
|
+
import { type IEventsManagerDomain } from 'domain/eventsManager/eventsManagerDomain';
|
|
3
|
+
export interface INotificationByWebSocketChannelDeps {
|
|
4
|
+
'core.domain.eventsManager': IEventsManagerDomain;
|
|
5
|
+
}
|
|
6
|
+
export default function ({ 'core.domain.eventsManager': eventsManagerDomain }: INotificationByWebSocketChannelDeps): INotificationChannel;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type IConfig } from '_types/config';
|
|
2
|
+
import { type INotificationChannel, type ICreateNotification } from '_types/notification';
|
|
3
|
+
import { type IQueryInfos } from '_types/queryInfos';
|
|
4
|
+
export interface INotificationDomain {
|
|
5
|
+
createNotification(notification: ICreateNotification, ctx: IQueryInfos): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
export interface INotificationDomainDeps {
|
|
8
|
+
'core.domain.notification.emailChannel': INotificationChannel;
|
|
9
|
+
'core.domain.notification.webSocketChannel': INotificationChannel;
|
|
10
|
+
config: IConfig;
|
|
11
|
+
}
|
|
12
|
+
export default function ({ 'core.domain.notification.emailChannel': emailChannel, 'core.domain.notification.webSocketChannel': webSocketChannel, config }: INotificationDomainDeps): INotificationDomain;
|
|
@@ -6,7 +6,8 @@ import { type IUserDataRepo } from 'infra/userData/userDataRepo';
|
|
|
6
6
|
import { type IUtils } from 'utils/utils';
|
|
7
7
|
import type * as Config from '_types/config';
|
|
8
8
|
import { type IQueryInfos } from '_types/queryInfos';
|
|
9
|
-
import { type IUserData } from '_types/userData';
|
|
9
|
+
import { type IUserIdentity, type IUserData } from '_types/userData';
|
|
10
|
+
import { type IValueDomain } from 'domain/value/valueDomain';
|
|
10
11
|
interface ISaveUserDataParams {
|
|
11
12
|
key: string;
|
|
12
13
|
value: any;
|
|
@@ -15,12 +16,14 @@ interface ISaveUserDataParams {
|
|
|
15
16
|
ctx: IQueryInfos;
|
|
16
17
|
}
|
|
17
18
|
export interface IUserDomain {
|
|
19
|
+
getUserIdentity(userId: string, ctx: IQueryInfos): Promise<IUserIdentity>;
|
|
18
20
|
saveUserData(params: ISaveUserDataParams): Promise<IUserData>;
|
|
19
21
|
getUserData(keys: string[], global: boolean, ctx: IQueryInfos): Promise<IUserData>;
|
|
20
22
|
sendResetPasswordEmail(email: string, token: string, login: string, browser: string, os: string, lang: 'fr' | 'en', ctx: IQueryInfos): Promise<void>;
|
|
21
23
|
}
|
|
22
24
|
export interface IUserDomainDeps {
|
|
23
25
|
config: Config.IConfig;
|
|
26
|
+
'core.domain.value': IValueDomain;
|
|
24
27
|
'core.domain.permissions': IPermissionDomain;
|
|
25
28
|
'core.infra.userData': IUserDataRepo;
|
|
26
29
|
'core.domain.permission': IPermissionDomain;
|
|
@@ -32,5 +35,5 @@ export interface IUserDomainDeps {
|
|
|
32
35
|
export declare enum UserCoreDataKeys {
|
|
33
36
|
CONSULTED_APPS = "applications_consultation"
|
|
34
37
|
}
|
|
35
|
-
export default function ({ config, 'core.infra.userData': userDataRepo, 'core.domain.permission': permissionDomain, 'core.infra.mailer.mailerService': mailerService, 'core.domain.globalSettings': globalSettingsDomain, 'core.utils': utils, translator }: IUserDomainDeps): IUserDomain;
|
|
38
|
+
export default function ({ config, 'core.domain.value': valueDomain, 'core.infra.userData': userDataRepo, 'core.domain.permission': permissionDomain, 'core.infra.mailer.mailerService': mailerService, 'core.domain.globalSettings': globalSettingsDomain, 'core.utils': utils, translator }: IUserDomainDeps): IUserDomain;
|
|
36
39
|
export {};
|
|
@@ -88,11 +88,6 @@ export interface IValueDomain {
|
|
|
88
88
|
ctx: IQueryInfos;
|
|
89
89
|
}): Promise<IValue>;
|
|
90
90
|
runActionsList(params: IRunActionListParams): Promise<IValue[]>;
|
|
91
|
-
runActionsListAndFormatOnValue({ library, value, ctx }: {
|
|
92
|
-
library: string;
|
|
93
|
-
value: IValue;
|
|
94
|
-
ctx: IQueryInfos;
|
|
95
|
-
}): Promise<IValue[]>;
|
|
96
91
|
}
|
|
97
92
|
export interface IValueDomainDeps {
|
|
98
93
|
config: Config.IConfig;
|
|
@@ -15,14 +15,14 @@ interface IElasticsearchServiceSearchParams {
|
|
|
15
15
|
};
|
|
16
16
|
query?: estypes.QueryDslQueryContainer;
|
|
17
17
|
}
|
|
18
|
-
export interface
|
|
18
|
+
export interface IElasticsearchService {
|
|
19
19
|
client: Client;
|
|
20
20
|
search: <T>(params: IElasticsearchServiceSearchParams) => Promise<IElasticsearchServiceSearchResponse<T>>;
|
|
21
21
|
writeData: (indexName: string, data: Log) => Promise<void>;
|
|
22
22
|
}
|
|
23
|
-
export interface
|
|
24
|
-
'core.infra.
|
|
23
|
+
export interface IElasticsearchServiceDeps {
|
|
24
|
+
'core.infra.elasticsearch.client'?: Client;
|
|
25
25
|
config?: IConfig;
|
|
26
26
|
}
|
|
27
|
-
export default function ({ config }:
|
|
27
|
+
export default function ({ config }: IElasticsearchServiceDeps): IElasticsearchService;
|
|
28
28
|
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as service } from './elasticsearchService';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { type
|
|
1
|
+
import { type IElasticsearchService } from 'infra/elasticsearch/elasticsearchService';
|
|
2
2
|
import { type IConfig } from '_types/config';
|
|
3
3
|
import { type ILogFilters, type ILogPagination, type ILogResponse, type ILogSort } from '_types/log';
|
|
4
4
|
import { type IQueryInfos } from '_types/queryInfos';
|
|
@@ -10,8 +10,8 @@ export interface ILogRepo {
|
|
|
10
10
|
}, ctx: IQueryInfos): Promise<ILogResponse>;
|
|
11
11
|
}
|
|
12
12
|
interface IDeps {
|
|
13
|
-
'core.infra.
|
|
13
|
+
'core.infra.elasticsearch.service'?: IElasticsearchService;
|
|
14
14
|
config?: IConfig;
|
|
15
15
|
}
|
|
16
|
-
export default function ({ 'core.infra.
|
|
16
|
+
export default function ({ 'core.infra.elasticsearch.service': esService, config }: IDeps): ILogRepo;
|
|
17
17
|
export {};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
interface ICallerInfo {
|
|
2
|
+
path: string;
|
|
3
|
+
line: string;
|
|
4
|
+
col: string;
|
|
5
|
+
}
|
|
6
|
+
export declare class LoggerCallStack {
|
|
7
|
+
private callerLineIndexInStack;
|
|
8
|
+
getCallStackTrace(): string | null;
|
|
9
|
+
getLocationInfo(): ICallerInfo | null;
|
|
10
|
+
private getStackLines;
|
|
11
|
+
private detectCallLineIndexInStack;
|
|
12
|
+
private callStackTraceLongEnough;
|
|
13
|
+
}
|
|
14
|
+
export {};
|
|
@@ -3,7 +3,7 @@ export interface ILoggerConfig {
|
|
|
3
3
|
* Log level (error, warn, info, log, verbose, debug, silly)
|
|
4
4
|
* @default info
|
|
5
5
|
*/
|
|
6
|
-
level
|
|
6
|
+
level?: string;
|
|
7
7
|
/**
|
|
8
8
|
* If true, disable all logging
|
|
9
9
|
* Default: true if TS_JEST=1 (tests), false otherwise
|
|
@@ -18,7 +18,36 @@ export interface ILoggerConfig {
|
|
|
18
18
|
* Default: false (plain text)
|
|
19
19
|
*/
|
|
20
20
|
useJsonFormat?: boolean;
|
|
21
|
-
|
|
21
|
+
/**
|
|
22
|
+
* If true, add timestamp to each log line, ISO format
|
|
23
|
+
*/
|
|
24
|
+
addTimestamp?: boolean;
|
|
25
|
+
/**
|
|
26
|
+
* If true, add file and line number of the code that called the logger function (error, warn, info, debug, etc.)
|
|
27
|
+
*/
|
|
28
|
+
addLocationInfo?: boolean;
|
|
29
|
+
/**
|
|
30
|
+
* Add those metadata to all logs
|
|
31
|
+
*/
|
|
32
|
+
additionalMeta?: {
|
|
33
|
+
/**
|
|
34
|
+
* any string to identify the application those logs came from
|
|
35
|
+
*/
|
|
36
|
+
app?: string;
|
|
37
|
+
/**
|
|
38
|
+
* any string to identify each client those logs came from
|
|
39
|
+
*/
|
|
40
|
+
client?: string;
|
|
41
|
+
/**
|
|
42
|
+
* environment, like production, development, test, integration
|
|
43
|
+
*/
|
|
44
|
+
env?: string;
|
|
45
|
+
/**
|
|
46
|
+
* application version, maybe semver format
|
|
47
|
+
*/
|
|
48
|
+
version?: string;
|
|
49
|
+
};
|
|
50
|
+
onErrorLog?: (message: string, meta: any, getCallStackTrace: () => string) => void;
|
|
22
51
|
}
|
|
23
52
|
export declare function envToBool(value: string, defaultValue?: boolean): boolean;
|
|
24
|
-
export declare const defaultLoggerConfig: ILoggerConfig
|
|
53
|
+
export declare const defaultLoggerConfig: ILoggerConfig & Required<Omit<ILoggerConfig, 'onErrorLog'>>;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as amqp from 'amqplib';
|
|
2
|
-
import { type IAmqp, type
|
|
2
|
+
import { type IAmqp, type OnMessageFunc } from './types/amqp';
|
|
3
3
|
export interface IAmqpService {
|
|
4
4
|
publisher: {
|
|
5
5
|
connection: amqp.ChannelModel;
|
|
@@ -10,7 +10,7 @@ export interface IAmqpService {
|
|
|
10
10
|
channel: amqp.ConfirmChannel;
|
|
11
11
|
};
|
|
12
12
|
publish(exchange: string, routingKey: string, msg: string, priority?: number): Promise<void>;
|
|
13
|
-
consume(queue: string, routingKey: string, onMessage:
|
|
13
|
+
consume(queue: string, routingKey: string, onMessage: OnMessageFunc, consumerTag?: string): Promise<amqp.Replies.Consume>;
|
|
14
14
|
close(): Promise<void>;
|
|
15
15
|
}
|
|
16
16
|
interface IDeps {
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { default as service } from './elasticSearchService';
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import winston from 'winston';
|
|
2
|
-
interface ICallerInfo {
|
|
3
|
-
path: string;
|
|
4
|
-
line: string;
|
|
5
|
-
col: string;
|
|
6
|
-
}
|
|
7
|
-
export declare function getLocationInfo(): ICallerInfo | null;
|
|
8
|
-
export declare const addLocationInfoInLog: winston.Logform.FormatWrap;
|
|
9
|
-
export declare const mergeLocationInfoInLog: winston.Logform.FormatWrap;
|
|
10
|
-
export {};
|
|
File without changes
|