@mereb/shared-packages 0.0.37 → 0.0.39
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/events/envelope.d.ts +25 -0
- package/dist/events/envelope.d.ts.map +1 -0
- package/dist/events/envelope.js +26 -0
- package/dist/events/publisher.d.ts +11 -0
- package/dist/events/publisher.d.ts.map +1 -0
- package/dist/events/publisher.js +25 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/logger.d.ts +11 -0
- package/dist/logger.d.ts.map +1 -1
- package/dist/logger.js +32 -18
- package/package.json +1 -1
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export interface IntegrationEventEnvelope<TData = unknown> {
|
|
2
|
+
event_id: string;
|
|
3
|
+
event_type: string;
|
|
4
|
+
occurred_at: string;
|
|
5
|
+
producer: string;
|
|
6
|
+
version: number;
|
|
7
|
+
correlation_id?: string;
|
|
8
|
+
causation_id?: string;
|
|
9
|
+
tenant_id?: string;
|
|
10
|
+
data: TData;
|
|
11
|
+
}
|
|
12
|
+
export interface CreateIntegrationEventEnvelopeInput<TData> {
|
|
13
|
+
eventType: string;
|
|
14
|
+
producer: string;
|
|
15
|
+
data: TData;
|
|
16
|
+
version?: number;
|
|
17
|
+
eventId?: string;
|
|
18
|
+
occurredAt?: Date | string;
|
|
19
|
+
correlationId?: string;
|
|
20
|
+
causationId?: string;
|
|
21
|
+
tenantId?: string;
|
|
22
|
+
}
|
|
23
|
+
export declare function createIntegrationEventEnvelope<TData>(input: CreateIntegrationEventEnvelopeInput<TData>): IntegrationEventEnvelope<TData>;
|
|
24
|
+
export declare function serializeIntegrationEventEnvelope<TData>(envelope: IntegrationEventEnvelope<TData>): string;
|
|
25
|
+
//# sourceMappingURL=envelope.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"envelope.d.ts","sourceRoot":"","sources":["../../src/events/envelope.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,wBAAwB,CAAC,KAAK,GAAG,OAAO;IACvD,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,KAAK,CAAC;CACb;AAED,MAAM,WAAW,mCAAmC,CAAC,KAAK;IACxD,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,KAAK,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,IAAI,GAAG,MAAM,CAAC;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAcD,wBAAgB,8BAA8B,CAAC,KAAK,EAClD,KAAK,EAAE,mCAAmC,CAAC,KAAK,CAAC,GAChD,wBAAwB,CAAC,KAAK,CAAC,CAYjC;AAED,wBAAgB,iCAAiC,CAAC,KAAK,EACrD,QAAQ,EAAE,wBAAwB,CAAC,KAAK,CAAC,GACxC,MAAM,CAER"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { randomUUID } from 'node:crypto';
|
|
2
|
+
function toIsoString(value) {
|
|
3
|
+
if (!value) {
|
|
4
|
+
return new Date().toISOString();
|
|
5
|
+
}
|
|
6
|
+
if (typeof value === 'string') {
|
|
7
|
+
return value;
|
|
8
|
+
}
|
|
9
|
+
return value.toISOString();
|
|
10
|
+
}
|
|
11
|
+
export function createIntegrationEventEnvelope(input) {
|
|
12
|
+
return {
|
|
13
|
+
event_id: input.eventId ?? randomUUID(),
|
|
14
|
+
event_type: input.eventType,
|
|
15
|
+
occurred_at: toIsoString(input.occurredAt),
|
|
16
|
+
producer: input.producer,
|
|
17
|
+
version: input.version ?? 1,
|
|
18
|
+
...(input.correlationId ? { correlation_id: input.correlationId } : {}),
|
|
19
|
+
...(input.causationId ? { causation_id: input.causationId } : {}),
|
|
20
|
+
...(input.tenantId ? { tenant_id: input.tenantId } : {}),
|
|
21
|
+
data: input.data
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
export function serializeIntegrationEventEnvelope(envelope) {
|
|
25
|
+
return JSON.stringify(envelope);
|
|
26
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { KafkaConfig } from 'kafkajs';
|
|
2
|
+
import type { IntegrationEventEnvelope } from './envelope.js';
|
|
3
|
+
export interface PublishIntegrationEventOptions {
|
|
4
|
+
key?: string;
|
|
5
|
+
}
|
|
6
|
+
export interface IntegrationEventPublisher {
|
|
7
|
+
publish<TData>(topic: string, envelope: IntegrationEventEnvelope<TData>, options?: PublishIntegrationEventOptions): Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
export declare function createNoopIntegrationEventPublisher(): IntegrationEventPublisher;
|
|
10
|
+
export declare function createKafkaIntegrationEventPublisher(config: KafkaConfig): IntegrationEventPublisher;
|
|
11
|
+
//# sourceMappingURL=publisher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"publisher.d.ts","sourceRoot":"","sources":["../../src/events/publisher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,eAAe,CAAC;AAI9D,MAAM,WAAW,8BAA8B;IAC7C,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,yBAAyB;IACxC,OAAO,CAAC,KAAK,EACX,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,wBAAwB,CAAC,KAAK,CAAC,EACzC,OAAO,CAAC,EAAE,8BAA8B,GACvC,OAAO,CAAC,IAAI,CAAC,CAAC;CAClB;AAED,wBAAgB,mCAAmC,IAAI,yBAAyB,CAM/E;AAED,wBAAgB,oCAAoC,CAClD,MAAM,EAAE,WAAW,GAClB,yBAAyB,CAmB3B"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { serializeIntegrationEventEnvelope } from './envelope.js';
|
|
2
|
+
import { getProducer } from '../messaging/kafka.js';
|
|
3
|
+
export function createNoopIntegrationEventPublisher() {
|
|
4
|
+
return {
|
|
5
|
+
async publish() {
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
export function createKafkaIntegrationEventPublisher(config) {
|
|
11
|
+
return {
|
|
12
|
+
async publish(topic, envelope, options) {
|
|
13
|
+
const producer = await getProducer(config);
|
|
14
|
+
await producer.send({
|
|
15
|
+
topic,
|
|
16
|
+
messages: [
|
|
17
|
+
{
|
|
18
|
+
key: options?.key,
|
|
19
|
+
value: serializeIntegrationEventEnvelope(envelope)
|
|
20
|
+
}
|
|
21
|
+
]
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
export * from './auth/jwks.js';
|
|
2
2
|
export * from './cache/redis.js';
|
|
3
3
|
export * from './config/env.js';
|
|
4
|
+
export * from './events/envelope.js';
|
|
5
|
+
export * from './events/publisher.js';
|
|
4
6
|
export * from './logger.js';
|
|
7
|
+
export { createFastifyLoggerOptions } from './logger.js';
|
|
5
8
|
export type { Logger } from 'pino';
|
|
6
9
|
export * from './messaging/kafka.js';
|
|
7
10
|
export * from './observability/otel.js';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,aAAa,CAAC;AAC5B,YAAY,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,eAAe,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,sBAAsB,CAAC;AACrC,cAAc,uBAAuB,CAAC;AACtC,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;AACzD,YAAY,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,eAAe,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
export * from './auth/jwks.js';
|
|
2
2
|
export * from './cache/redis.js';
|
|
3
3
|
export * from './config/env.js';
|
|
4
|
+
export * from './events/envelope.js';
|
|
5
|
+
export * from './events/publisher.js';
|
|
4
6
|
export * from './logger.js';
|
|
7
|
+
export { createFastifyLoggerOptions } from './logger.js';
|
|
5
8
|
export * from './messaging/kafka.js';
|
|
6
9
|
export * from './observability/otel.js';
|
|
7
10
|
export * from './media/s3.js';
|
package/dist/logger.d.ts
CHANGED
|
@@ -1,3 +1,14 @@
|
|
|
1
1
|
import pino from 'pino';
|
|
2
|
+
type TransportTarget = {
|
|
3
|
+
target: string;
|
|
4
|
+
level?: pino.LevelWithSilentOrString;
|
|
5
|
+
options?: Record<string, unknown>;
|
|
6
|
+
};
|
|
7
|
+
export declare function createFastifyLoggerOptions(name: string): pino.LoggerOptions & {
|
|
8
|
+
transport?: {
|
|
9
|
+
targets: TransportTarget[];
|
|
10
|
+
};
|
|
11
|
+
};
|
|
2
12
|
export declare function createLogger(name: string): pino.Logger;
|
|
13
|
+
export {};
|
|
3
14
|
//# sourceMappingURL=logger.d.ts.map
|
package/dist/logger.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AAWxB,KAAK,eAAe,GAAG;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,IAAI,CAAC,uBAAuB,CAAC;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACrC,CAAC;AA6EF,wBAAgB,0BAA0B,CACtC,IAAI,EAAE,MAAM,GACb,IAAI,CAAC,aAAa,GAAG;IAAC,SAAS,CAAC,EAAE;QAAC,OAAO,EAAE,eAAe,EAAE,CAAA;KAAC,CAAA;CAAC,CAUjE;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC,MAAM,CAWtD"}
|
package/dist/logger.js
CHANGED
|
@@ -27,8 +27,8 @@ function resolveSplunkConfig(name) {
|
|
|
27
27
|
source: name
|
|
28
28
|
};
|
|
29
29
|
}
|
|
30
|
-
|
|
31
|
-
const
|
|
30
|
+
function buildTransportTargets(name) {
|
|
31
|
+
const targets = [];
|
|
32
32
|
const splunkConfig = resolveSplunkConfig(name);
|
|
33
33
|
const baseLevel = process.env.LOG_LEVEL ?? 'info';
|
|
34
34
|
const isProd = process.env.NODE_ENV === 'production';
|
|
@@ -36,14 +36,18 @@ export function createLogger(name) {
|
|
|
36
36
|
console.warn('Splunk token missing; HEC logging disabled');
|
|
37
37
|
}
|
|
38
38
|
if (isProd) {
|
|
39
|
-
|
|
39
|
+
targets.push({
|
|
40
|
+
target: 'pino/file',
|
|
41
|
+
options: { destination: 1 },
|
|
42
|
+
level: baseLevel
|
|
43
|
+
});
|
|
40
44
|
}
|
|
41
45
|
else {
|
|
42
|
-
|
|
46
|
+
targets.push({
|
|
43
47
|
target: 'pino-pretty',
|
|
44
|
-
options: { translateTime: 'SYS:standard' }
|
|
48
|
+
options: { translateTime: 'SYS:standard' },
|
|
49
|
+
level: baseLevel
|
|
45
50
|
});
|
|
46
|
-
transports.push({ stream: pretty });
|
|
47
51
|
}
|
|
48
52
|
if (splunkConfig) {
|
|
49
53
|
const transportPath = join(dirname(fileURLToPath(import.meta.url)), 'transports', 'splunk-transport.js');
|
|
@@ -52,21 +56,31 @@ export function createLogger(name) {
|
|
|
52
56
|
index: splunkConfig.index,
|
|
53
57
|
source: splunkConfig.source
|
|
54
58
|
});
|
|
55
|
-
|
|
59
|
+
targets.push({
|
|
56
60
|
target: transportPath,
|
|
57
61
|
level: 'info',
|
|
58
62
|
options: splunkConfig
|
|
59
63
|
});
|
|
60
|
-
transports.push({ stream: splunkStream, level: 'info' });
|
|
61
64
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
65
|
+
return targets;
|
|
66
|
+
}
|
|
67
|
+
export function createFastifyLoggerOptions(name) {
|
|
68
|
+
const baseLevel = process.env.LOG_LEVEL ?? 'info';
|
|
69
|
+
const targets = buildTransportTargets(name);
|
|
70
|
+
if (!targets.length) {
|
|
71
|
+
return { level: baseLevel };
|
|
72
|
+
}
|
|
73
|
+
return {
|
|
74
|
+
level: baseLevel,
|
|
75
|
+
transport: { targets }
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
export function createLogger(name) {
|
|
79
|
+
const baseLevel = process.env.LOG_LEVEL ?? 'info';
|
|
80
|
+
const targets = buildTransportTargets(name);
|
|
81
|
+
if (!targets.length) {
|
|
82
|
+
return pino({ name, level: baseLevel });
|
|
83
|
+
}
|
|
84
|
+
const transport = pino.transport({ targets });
|
|
85
|
+
return pino({ name, level: baseLevel }, transport);
|
|
72
86
|
}
|