@squiz/optimization-utils 1.3.0 → 2.0.1
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/CHANGELOG.md +12 -0
- package/dist/event/DomainEvent.d.ts +1 -0
- package/dist/event/DomainEvent.js.map +1 -1
- package/dist/event/DynamoDBEventMapper.d.ts +3 -0
- package/dist/event/DynamoDBEventMapper.js +3 -0
- package/dist/event/DynamoDBEventMapper.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/src/event/DomainEvent.ts +1 -0
- package/src/event/DynamoDBEventMapper.ts +3 -0
- package/src/event/__tests__/DynamoDBEventMapper.spec.ts +8 -0
- package/src/index.ts +1 -1
- package/src/scheduler/__tests__/EventBridgeScheduler.spec.ts +7 -6
- package/dist/logger/LogsLambdaHandler.d.ts +0 -13
- package/dist/logger/LogsLambdaHandler.js +0 -31
- package/dist/logger/LogsLambdaHandler.js.map +0 -1
- package/src/logger/LogsLambdaHandler.ts +0 -43
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# @squiz/optimization-utils
|
|
2
2
|
|
|
3
|
+
## 2.0.1
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- ca7d105: Removed createLogsLambdaHandler function
|
|
8
|
+
|
|
9
|
+
## 2.0.0
|
|
10
|
+
|
|
11
|
+
### Major Changes
|
|
12
|
+
|
|
13
|
+
- abd0e0f: Added EntityId into the DomainEvent interface
|
|
14
|
+
|
|
3
15
|
## 1.3.0
|
|
4
16
|
|
|
5
17
|
### Minor Changes
|
|
@@ -5,6 +5,7 @@ export interface DomainEvent<TData extends Record<string, unknown> = Record<stri
|
|
|
5
5
|
readonly detail: TData;
|
|
6
6
|
readonly time: Date;
|
|
7
7
|
readonly version: string;
|
|
8
|
+
readonly entityId: string;
|
|
8
9
|
}
|
|
9
10
|
export type DomainEventConstructor = new (...any: Array<any>) => DomainEvent;
|
|
10
11
|
export type DomainEventName = string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DomainEvent.js","sourceRoot":"","sources":["../../src/event/DomainEvent.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"DomainEvent.js","sourceRoot":"","sources":["../../src/event/DomainEvent.ts"],"names":[],"mappings":";;AAmBA,gDAMC;AAED,8CAEC;AAmBD,sCAIC;AApDD,4BAA0B;AAa1B,MAAM,mBAAmB,GAAG,MAAM,EAAE,CAAC;AAMrC,SAAgB,kBAAkB,CAChC,IAAqB;IAErB,MAAM,YAAY,GAAG,iBAAiB,EAAE,CAAC;IAEzC,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;AACnD,CAAC;AAED,SAAgB,iBAAiB;IAC/B,OAAO,OAAO,CAAC,WAAW,CAAC,mBAAmB,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC;AAChE,CAAC;AAED,SAAS,iBAAiB,CAAC,WAAmC;IAC5D,MAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAC;IACrC,MAAM,kBAAkB,GAAG,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAEhE,IAAI,kBAAkB,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CACb,kDAAkD,WAAW,CAAC,IAAI,mCAAmC,CACtG,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,cAAc,CACpB,mBAAmB,EACnB,CAAC,GAAG,QAAQ,EAAE,WAAW,CAAC,EAC1B,MAAM,CACP,CAAC;AACJ,CAAC;AAED,SAAgB,aAAa;IAC3B,OAAO,CAAC,MAAM,EAAE,EAAE;QAChB,iBAAiB,CAAC,MAA2C,CAAC,CAAC;IACjE,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -9,6 +9,7 @@ declare const EVENT_DYNAMO_DB_MODEL_SCHEMA: z.ZodObject<{
|
|
|
9
9
|
time: z.ZodString;
|
|
10
10
|
version: z.ZodString;
|
|
11
11
|
ttl: z.ZodNumber;
|
|
12
|
+
entityId: z.ZodString;
|
|
12
13
|
}, "strip", z.ZodTypeAny, {
|
|
13
14
|
eventId: string;
|
|
14
15
|
name: string;
|
|
@@ -18,6 +19,7 @@ declare const EVENT_DYNAMO_DB_MODEL_SCHEMA: z.ZodObject<{
|
|
|
18
19
|
time: string;
|
|
19
20
|
version: string;
|
|
20
21
|
ttl: number;
|
|
22
|
+
entityId: string;
|
|
21
23
|
}, {
|
|
22
24
|
eventId: string;
|
|
23
25
|
name: string;
|
|
@@ -27,6 +29,7 @@ declare const EVENT_DYNAMO_DB_MODEL_SCHEMA: z.ZodObject<{
|
|
|
27
29
|
time: string;
|
|
28
30
|
version: string;
|
|
29
31
|
ttl: number;
|
|
32
|
+
entityId: string;
|
|
30
33
|
}>;
|
|
31
34
|
export type EventDynamoDBModel = z.infer<typeof EVENT_DYNAMO_DB_MODEL_SCHEMA>;
|
|
32
35
|
type EventDynamoMarshalledModel = MarshalledResult<EventDynamoDBModel>;
|
|
@@ -13,6 +13,7 @@ const EVENT_DYNAMO_DB_MODEL_SCHEMA = zod_1.z.object({
|
|
|
13
13
|
time: zod_1.z.string().datetime(),
|
|
14
14
|
version: notEmptyString,
|
|
15
15
|
ttl: zod_1.z.number(),
|
|
16
|
+
entityId: zod_1.z.string(),
|
|
16
17
|
});
|
|
17
18
|
const eventToDynamoDB = (event) => {
|
|
18
19
|
const timestampPlus30Days = (0, DateManipulator_1.DateManipulator)(event.time)
|
|
@@ -26,6 +27,7 @@ const eventToDynamoDB = (event) => {
|
|
|
26
27
|
time: event.time.toISOString(),
|
|
27
28
|
version: event.version,
|
|
28
29
|
ttl: timestampPlus30Days / 1000,
|
|
30
|
+
entityId: event.entityId,
|
|
29
31
|
};
|
|
30
32
|
return (0, util_dynamodb_1.marshall)(dynamoDBModel, {
|
|
31
33
|
removeUndefinedValues: true,
|
|
@@ -49,6 +51,7 @@ const toEventFromPlain = (plainObject) => {
|
|
|
49
51
|
time: new Date(dynamoDBModel.time),
|
|
50
52
|
version: dynamoDBModel.version,
|
|
51
53
|
name: dynamoDBModel.name,
|
|
54
|
+
entityId: dynamoDBModel.entityId,
|
|
52
55
|
});
|
|
53
56
|
};
|
|
54
57
|
exports.toEventFromPlain = toEventFromPlain;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamoDBEventMapper.js","sourceRoot":"","sources":["../../src/event/DynamoDBEventMapper.ts"],"names":[],"mappings":";;;AAAA,+CAAgE;AAChE,6BAAwB;AAExB,0DAA8D;AAE9D,6DAA0D;AAE1D,MAAM,cAAc,GAAG,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACzC,MAAM,4BAA4B,GAAG,OAAC,CAAC,MAAM,CAAC;IAC5C,OAAO,EAAE,cAAc;IACvB,IAAI,EAAE,cAAc;IACpB,MAAM,EAAE,OAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,OAAC,CAAC,GAAG,EAAE,CAAC;IACtC,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC3B,OAAO,EAAE,cAAc;IACvB,GAAG,EAAE,OAAC,CAAC,MAAM,EAAE;
|
|
1
|
+
{"version":3,"file":"DynamoDBEventMapper.js","sourceRoot":"","sources":["../../src/event/DynamoDBEventMapper.ts"],"names":[],"mappings":";;;AAAA,+CAAgE;AAChE,6BAAwB;AAExB,0DAA8D;AAE9D,6DAA0D;AAE1D,MAAM,cAAc,GAAG,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACzC,MAAM,4BAA4B,GAAG,OAAC,CAAC,MAAM,CAAC;IAC5C,OAAO,EAAE,cAAc;IACvB,IAAI,EAAE,cAAc;IACpB,MAAM,EAAE,OAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,OAAC,CAAC,GAAG,EAAE,CAAC;IACtC,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC3B,OAAO,EAAE,cAAc;IACvB,GAAG,EAAE,OAAC,CAAC,MAAM,EAAE;IACf,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE;CACrB,CAAC,CAAC;AAKI,MAAM,eAAe,GAAG,CAC7B,KAAkB,EACU,EAAE;IAC9B,MAAM,mBAAmB,GAAG,IAAA,iCAAe,EAAC,KAAK,CAAC,IAAI,CAAC;SACpD,OAAO,CAAC,EAAE,CAAC;SACX,OAAO,EAAE;SACT,OAAO,EAAE,CAAC;IAEb,MAAM,aAAa,GAAuB;QACxC,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAChD,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE;QAC9B,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,GAAG,EAAE,mBAAmB,GAAG,IAAI;QAC/B,QAAQ,EAAE,KAAK,CAAC,QAAQ;KACzB,CAAC;IAEF,OAAO,IAAA,wBAAQ,EAAC,aAAa,EAAE;QAC7B,qBAAqB,EAAE,IAAI;KAC5B,CAA+B,CAAC;AACnC,CAAC,CAAC;AArBW,QAAA,eAAe,mBAqB1B;AAEK,MAAM,mBAAmB,GAAG,CACjC,UAA0C,EACnC,EAAE;IACT,MAAM,YAAY,GAAG,IAAA,0BAAU,EAAC,UAAU,CAAC,CAAC;IAE5C,OAAO,IAAA,wBAAgB,EAAC,YAAY,CAAC,CAAC;AACxC,CAAC,CAAC;AANW,QAAA,mBAAmB,uBAM9B;AAEK,MAAM,gBAAgB,GAAG,CAC9B,WAAoC,EAC7B,EAAE;IACT,MAAM,aAAa,GAAG,4BAA4B,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,CAC1E,WAAW,CACZ,CAAC;IACF,MAAM,SAAS,GAAG,IAAA,gCAAkB,EAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAEzD,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CACb,yBAAyB,aAAa,CAAC,IAAI,0BAA0B,CACtE,CAAC;IACJ,CAAC;IAED,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,SAAS,CAAC,EAAE,CAAC,EAAE;QACtC,OAAO,EAAE,aAAa,CAAC,OAAO;QAC9B,MAAM,EAAE,aAAa,CAAC,MAAM;QAC5B,IAAI,EAAE,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;QAClC,OAAO,EAAE,aAAa,CAAC,OAAO;QAC9B,IAAI,EAAE,aAAa,CAAC,IAAI;QACxB,QAAQ,EAAE,aAAa,CAAC,QAAQ;KACjC,CAAU,CAAC;AACd,CAAC,CAAC;AAtBW,QAAA,gBAAgB,oBAsB3B"}
|
package/dist/index.d.ts
CHANGED
|
@@ -9,7 +9,7 @@ export * from './logger/SquizRemoteLogger';
|
|
|
9
9
|
export * from './logger/RemoteLogger';
|
|
10
10
|
export * from './logger/LoggerMessage';
|
|
11
11
|
export * from './logger/Logger';
|
|
12
|
-
export * from './logger/
|
|
12
|
+
export * from './logger/LogsHandler';
|
|
13
13
|
export * from './httpClient/HttpRequestBuilder';
|
|
14
14
|
export * from './httpClient/HttpClient';
|
|
15
15
|
export * from './httpClient/FetchHttpClient';
|
package/dist/index.js
CHANGED
|
@@ -25,7 +25,7 @@ __exportStar(require("./logger/SquizRemoteLogger"), exports);
|
|
|
25
25
|
__exportStar(require("./logger/RemoteLogger"), exports);
|
|
26
26
|
__exportStar(require("./logger/LoggerMessage"), exports);
|
|
27
27
|
__exportStar(require("./logger/Logger"), exports);
|
|
28
|
-
__exportStar(require("./logger/
|
|
28
|
+
__exportStar(require("./logger/LogsHandler"), exports);
|
|
29
29
|
__exportStar(require("./httpClient/HttpRequestBuilder"), exports);
|
|
30
30
|
__exportStar(require("./httpClient/HttpClient"), exports);
|
|
31
31
|
__exportStar(require("./httpClient/FetchHttpClient"), exports);
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yDAAuC;AAEvC,gEAA8C;AAE9C,yDAAuC;AACvC,wDAAsC;AAEtC,iDAA+B;AAE/B,wDAAsC;AACtC,mEAAiD;AAEjD,6DAA2C;AAC3C,wDAAsC;AACtC,yDAAuC;AACvC,kDAAgC;AAChC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yDAAuC;AAEvC,gEAA8C;AAE9C,yDAAuC;AACvC,wDAAsC;AAEtC,iDAA+B;AAE/B,wDAAsC;AACtC,mEAAiD;AAEjD,6DAA2C;AAC3C,wDAAsC;AACtC,yDAAuC;AACvC,kDAAgC;AAChC,uDAAqC;AAErC,kEAAgD;AAChD,0DAAwC;AACxC,+DAA6C;AAE7C,8DAA4C;AAE5C,8DAA4C;AAC5C,sDAAoC;AACpC,wDAAsC;AAEtC,yDAAuC;AACvC,uDAAqC;AAErC,+DAA6C;AAE7C,2EAAyD;AACzD,uEAAqD;AAErD,uDAAqC"}
|
package/package.json
CHANGED
package/src/event/DomainEvent.ts
CHANGED
|
@@ -13,6 +13,7 @@ const EVENT_DYNAMO_DB_MODEL_SCHEMA = z.object({
|
|
|
13
13
|
time: z.string().datetime(),
|
|
14
14
|
version: notEmptyString,
|
|
15
15
|
ttl: z.number(),
|
|
16
|
+
entityId: z.string(),
|
|
16
17
|
});
|
|
17
18
|
|
|
18
19
|
export type EventDynamoDBModel = z.infer<typeof EVENT_DYNAMO_DB_MODEL_SCHEMA>;
|
|
@@ -33,6 +34,7 @@ export const eventToDynamoDB = (
|
|
|
33
34
|
time: event.time.toISOString(),
|
|
34
35
|
version: event.version,
|
|
35
36
|
ttl: timestampPlus30Days / 1000,
|
|
37
|
+
entityId: event.entityId,
|
|
36
38
|
};
|
|
37
39
|
|
|
38
40
|
return marshall(dynamoDBModel, {
|
|
@@ -68,5 +70,6 @@ export const toEventFromPlain = <TData extends DomainEvent>(
|
|
|
68
70
|
time: new Date(dynamoDBModel.time),
|
|
69
71
|
version: dynamoDBModel.version,
|
|
70
72
|
name: dynamoDBModel.name,
|
|
73
|
+
entityId: dynamoDBModel.entityId,
|
|
71
74
|
}) as TData;
|
|
72
75
|
};
|
|
@@ -21,6 +21,7 @@ class ExampleEvent implements DomainEvent<{}> {
|
|
|
21
21
|
readonly name!: string;
|
|
22
22
|
readonly time!: Date;
|
|
23
23
|
readonly version!: string;
|
|
24
|
+
readonly entityId: string;
|
|
24
25
|
|
|
25
26
|
constructor(data: Omit<ExampleEvent, 'name'>) {
|
|
26
27
|
this.detail = data.detail;
|
|
@@ -28,6 +29,7 @@ class ExampleEvent implements DomainEvent<{}> {
|
|
|
28
29
|
this.name = ExampleEvent.name;
|
|
29
30
|
this.time = data.time;
|
|
30
31
|
this.version = data.version;
|
|
32
|
+
this.entityId = data.entityId;
|
|
31
33
|
}
|
|
32
34
|
}
|
|
33
35
|
|
|
@@ -37,6 +39,7 @@ const createPlainExampleEvent: () => {
|
|
|
37
39
|
detail: ExampleEventDetail;
|
|
38
40
|
time: string;
|
|
39
41
|
version: string;
|
|
42
|
+
entityId: string;
|
|
40
43
|
} = () => {
|
|
41
44
|
return {
|
|
42
45
|
detail: {
|
|
@@ -48,6 +51,7 @@ const createPlainExampleEvent: () => {
|
|
|
48
51
|
version: faker.number.int().toString(),
|
|
49
52
|
name: ExampleEvent.name,
|
|
50
53
|
ttl: faker.date.past().getTime() / 1000,
|
|
54
|
+
entityId: 'example-id',
|
|
51
55
|
};
|
|
52
56
|
};
|
|
53
57
|
|
|
@@ -63,6 +67,7 @@ describe('toEventEntityFromDynamoDb', () => {
|
|
|
63
67
|
eventId: event.eventId,
|
|
64
68
|
time: new Date(event.time),
|
|
65
69
|
version: event.version,
|
|
70
|
+
entityId: 'example-id',
|
|
66
71
|
}),
|
|
67
72
|
);
|
|
68
73
|
});
|
|
@@ -80,6 +85,7 @@ describe('toEventFromPlain', () => {
|
|
|
80
85
|
eventId: event.eventId,
|
|
81
86
|
time: new Date(event.time),
|
|
82
87
|
version: event.version,
|
|
88
|
+
entityId: 'example-id',
|
|
83
89
|
}),
|
|
84
90
|
);
|
|
85
91
|
});
|
|
@@ -95,6 +101,7 @@ describe('toDynamoDB', () => {
|
|
|
95
101
|
eventId: faker.string.uuid(),
|
|
96
102
|
time: new Date('2020-01-01T00:00:00.000Z'),
|
|
97
103
|
version: faker.number.int().toString(),
|
|
104
|
+
entityId: 'example-id',
|
|
98
105
|
});
|
|
99
106
|
|
|
100
107
|
const result = eventToDynamoDB(event);
|
|
@@ -107,6 +114,7 @@ describe('toDynamoDB', () => {
|
|
|
107
114
|
version: event.version,
|
|
108
115
|
name: 'ExampleEvent',
|
|
109
116
|
ttl: new Date('2020-01-31T00:00:00.000Z').getTime() / 1000,
|
|
117
|
+
entityId: 'example-id',
|
|
110
118
|
} as EventDynamoDBModel),
|
|
111
119
|
);
|
|
112
120
|
});
|
package/src/index.ts
CHANGED
|
@@ -14,7 +14,7 @@ export * from './logger/SquizRemoteLogger';
|
|
|
14
14
|
export * from './logger/RemoteLogger';
|
|
15
15
|
export * from './logger/LoggerMessage';
|
|
16
16
|
export * from './logger/Logger';
|
|
17
|
-
export * from './logger/
|
|
17
|
+
export * from './logger/LogsHandler';
|
|
18
18
|
|
|
19
19
|
export * from './httpClient/HttpRequestBuilder';
|
|
20
20
|
export * from './httpClient/HttpClient';
|
|
@@ -41,6 +41,7 @@ class ExampleEvent implements DomainEvent {
|
|
|
41
41
|
readonly name: string = ExampleEvent.name;
|
|
42
42
|
readonly time: Date = new Date();
|
|
43
43
|
readonly version: string = '1';
|
|
44
|
+
readonly entityId = 'uuid';
|
|
44
45
|
}
|
|
45
46
|
|
|
46
47
|
describe('EventBridgeScheduler', () => {
|
|
@@ -299,12 +300,12 @@ describe('EventBridgeScheduler', () => {
|
|
|
299
300
|
expect.objectContaining({
|
|
300
301
|
Name: expectedScheduleName,
|
|
301
302
|
}),
|
|
302
|
-
)
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
303
|
+
);
|
|
304
|
+
expect(DeleteScheduleCommand).toHaveBeenCalledWith(
|
|
305
|
+
expect.objectContaining({
|
|
306
|
+
Name: expectedScheduleName,
|
|
307
|
+
}),
|
|
308
|
+
);
|
|
308
309
|
});
|
|
309
310
|
});
|
|
310
311
|
});
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { CloudWatchLogsEvent } from 'aws-lambda';
|
|
2
|
-
import { LogsHandler } from './LogsHandler';
|
|
3
|
-
import { Logger } from './Logger';
|
|
4
|
-
import { Container } from 'inversify';
|
|
5
|
-
export declare const CLOUDWATCH_FILTER_PATTERN = "{ ($.level = \"info\" || $.level = \"warn\" || $.level = \"error\") && ($.remote IS TRUE || $.processable IS TRUE) }";
|
|
6
|
-
export type LogsLambdaHandler = (event: CloudWatchLogsEvent) => Promise<{
|
|
7
|
-
status: string;
|
|
8
|
-
}>;
|
|
9
|
-
export declare function createLogsLambdaHandler(instances: {
|
|
10
|
-
logsHandler: LogsHandler;
|
|
11
|
-
logger: Logger;
|
|
12
|
-
}): LogsLambdaHandler;
|
|
13
|
-
export declare function createLogsLambdaHandler(container: Container): LogsLambdaHandler;
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CLOUDWATCH_FILTER_PATTERN = void 0;
|
|
4
|
-
exports.createLogsLambdaHandler = createLogsLambdaHandler;
|
|
5
|
-
const LogsHandler_1 = require("./LogsHandler");
|
|
6
|
-
const Logger_1 = require("./Logger");
|
|
7
|
-
const inversify_1 = require("inversify");
|
|
8
|
-
exports.CLOUDWATCH_FILTER_PATTERN = `{ ($.level = "info" || $.level = "warn" || $.level = "error") && ($.remote IS TRUE || $.processable IS TRUE) }`;
|
|
9
|
-
function createLogsLambdaHandler(opts) {
|
|
10
|
-
let logsHandler;
|
|
11
|
-
let logger;
|
|
12
|
-
if (opts instanceof inversify_1.Container) {
|
|
13
|
-
logsHandler = opts.get(LogsHandler_1.LogsHandler);
|
|
14
|
-
logger = opts.get(Logger_1.Logger);
|
|
15
|
-
}
|
|
16
|
-
else {
|
|
17
|
-
logsHandler = opts.logsHandler;
|
|
18
|
-
logger = opts.logger;
|
|
19
|
-
}
|
|
20
|
-
return async (event) => {
|
|
21
|
-
try {
|
|
22
|
-
await logsHandler.handle(event);
|
|
23
|
-
return { status: 'ok' };
|
|
24
|
-
}
|
|
25
|
-
catch (e) {
|
|
26
|
-
logger.error(e);
|
|
27
|
-
throw e;
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
//# sourceMappingURL=LogsLambdaHandler.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"LogsLambdaHandler.js","sourceRoot":"","sources":["../../src/logger/LogsLambdaHandler.ts"],"names":[],"mappings":";;;AAkBA,0DAwBC;AAzCD,+CAA4C;AAC5C,qCAAkC;AAClC,yCAAsC;AAEzB,QAAA,yBAAyB,GAAG,gHAAgH,CAAC;AAa1J,SAAgB,uBAAuB,CACrC,IAA8D;IAE9D,IAAI,WAAwB,CAAC;IAC7B,IAAI,MAAc,CAAC;IAEnB,IAAI,IAAI,YAAY,qBAAS,EAAE,CAAC;QAC9B,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,yBAAW,CAAC,CAAC;QACpC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,eAAM,CAAC,CAAC;IAC5B,CAAC;SAAM,CAAC;QACN,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QAC/B,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,OAAO,KAAK,EAAE,KAA0B,EAAE,EAAE;QAC1C,IAAI,CAAC;YACH,MAAM,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAEhC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;QAC1B,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAChB,MAAM,CAAC,CAAC;QACV,CAAC;IACH,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import { CloudWatchLogsEvent } from 'aws-lambda';
|
|
2
|
-
import { LogsHandler } from './LogsHandler';
|
|
3
|
-
import { Logger } from './Logger';
|
|
4
|
-
import { Container } from 'inversify';
|
|
5
|
-
|
|
6
|
-
export const CLOUDWATCH_FILTER_PATTERN = `{ ($.level = "info" || $.level = "warn" || $.level = "error") && ($.remote IS TRUE || $.processable IS TRUE) }`;
|
|
7
|
-
|
|
8
|
-
export type LogsLambdaHandler = (
|
|
9
|
-
event: CloudWatchLogsEvent,
|
|
10
|
-
) => Promise<{ status: string }>;
|
|
11
|
-
|
|
12
|
-
export function createLogsLambdaHandler(instances: {
|
|
13
|
-
logsHandler: LogsHandler;
|
|
14
|
-
logger: Logger;
|
|
15
|
-
}): LogsLambdaHandler;
|
|
16
|
-
export function createLogsLambdaHandler(
|
|
17
|
-
container: Container,
|
|
18
|
-
): LogsLambdaHandler;
|
|
19
|
-
export function createLogsLambdaHandler(
|
|
20
|
-
opts: { logsHandler: LogsHandler; logger: Logger } | Container,
|
|
21
|
-
): LogsLambdaHandler {
|
|
22
|
-
let logsHandler: LogsHandler;
|
|
23
|
-
let logger: Logger;
|
|
24
|
-
|
|
25
|
-
if (opts instanceof Container) {
|
|
26
|
-
logsHandler = opts.get(LogsHandler);
|
|
27
|
-
logger = opts.get(Logger);
|
|
28
|
-
} else {
|
|
29
|
-
logsHandler = opts.logsHandler;
|
|
30
|
-
logger = opts.logger;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
return async (event: CloudWatchLogsEvent) => {
|
|
34
|
-
try {
|
|
35
|
-
await logsHandler.handle(event);
|
|
36
|
-
|
|
37
|
-
return { status: 'ok' };
|
|
38
|
-
} catch (e) {
|
|
39
|
-
logger.error(e);
|
|
40
|
-
throw e;
|
|
41
|
-
}
|
|
42
|
-
};
|
|
43
|
-
}
|