summaryrefslogtreecommitdiff
path: root/shared/metrics-8/src/recorder/composite.ts
diff options
context:
space:
mode:
authorrxliuli <rxliuli@gmail.com>2025-11-04 05:03:50 +0800
committerrxliuli <rxliuli@gmail.com>2025-11-04 05:03:50 +0800
commitbce557cc2dc767628bed6aac87301a1be7c5431b (patch)
treeb51a051228d01fe3306cd7626d4a96768aadb944 /shared/metrics-8/src/recorder/composite.ts
init commit
Diffstat (limited to 'shared/metrics-8/src/recorder/composite.ts')
-rw-r--r--shared/metrics-8/src/recorder/composite.ts20
1 files changed, 20 insertions, 0 deletions
diff --git a/shared/metrics-8/src/recorder/composite.ts b/shared/metrics-8/src/recorder/composite.ts
new file mode 100644
index 0000000..6302921
--- /dev/null
+++ b/shared/metrics-8/src/recorder/composite.ts
@@ -0,0 +1,20 @@
+import type { MetricsEventRecorder } from '@jet/engine';
+import type { LintedMetricsEvent } from '@jet/environment/types/metrics';
+import type { Opt } from '@jet/environment/types/optional';
+
+export class CompositeEventRecorder implements MetricsEventRecorder {
+ constructor(private readonly eventRecorders: MetricsEventRecorder[]) {}
+
+ record(event: LintedMetricsEvent, topic: Opt<string>): void {
+ for (const eventRecorder of this.eventRecorders) {
+ eventRecorder.record(event, topic);
+ }
+ }
+
+ async flush(): Promise<number> {
+ const flushed: number[] = await Promise.all(
+ this.eventRecorders.map((recorder) => recorder.flush()),
+ );
+ return Math.max(...flushed);
+ }
+}