@effect-app/infra 4.0.0-beta.210 → 4.0.0-beta.211
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 +8 -0
- package/dist/Model/Repository/internal/internal.d.ts.map +1 -1
- package/dist/Model/Repository/internal/internal.js +51 -21
- package/dist/Store/Cosmos.js +10 -10
- package/dist/Store/Disk.d.ts +1 -1
- package/dist/Store/Disk.js +7 -7
- package/dist/Store/Memory.js +9 -9
- package/dist/Store/SQL/Pg.js +9 -9
- package/dist/Store/SQL.js +18 -18
- package/dist/adapters/ServiceBus.d.ts.map +1 -1
- package/dist/adapters/ServiceBus.js +14 -8
- package/dist/otel.d.ts +10 -1
- package/dist/otel.d.ts.map +1 -1
- package/dist/otel.js +10 -1
- package/package.json +2 -2
- package/src/Model/Repository/internal/internal.ts +70 -25
- package/src/Store/Cosmos.ts +10 -10
- package/src/Store/Disk.ts +7 -7
- package/src/Store/Memory.ts +9 -9
- package/src/Store/SQL/Pg.ts +9 -9
- package/src/Store/SQL.ts +17 -17
- package/src/adapters/ServiceBus.ts +23 -15
- package/src/otel.ts +11 -0
|
@@ -3,18 +3,17 @@ import { type OperationOptionsBase, type ProcessErrorArgs, ServiceBusClient, typ
|
|
|
3
3
|
import { Cause, Context, Effect, Exit, FiberSet, Layer, type Scope } from "effect-app"
|
|
4
4
|
import { InfraLogger } from "../logger.js"
|
|
5
5
|
|
|
6
|
-
const
|
|
6
|
+
const logged = (name: string) => <A, E, R>(self: Effect.Effect<A, E, R>) =>
|
|
7
7
|
Effect.logInfo(name).pipe(
|
|
8
8
|
Effect.andThen(self),
|
|
9
9
|
Effect.tap(Effect.logInfo(name + " done")),
|
|
10
|
-
Effect.withLogSpan(name)
|
|
11
|
-
Effect.withSpan(name)
|
|
10
|
+
Effect.withLogSpan(name)
|
|
12
11
|
)
|
|
13
12
|
|
|
14
13
|
function makeClient(url: string) {
|
|
15
14
|
return Effect.acquireRelease(
|
|
16
|
-
Effect.sync(() => new ServiceBusClient(url)).pipe(
|
|
17
|
-
(client) => Effect.promise(() => client.close()).pipe(
|
|
15
|
+
Effect.sync(() => new ServiceBusClient(url)).pipe(logged("ServiceBus.client.create")),
|
|
16
|
+
(client) => Effect.promise(() => client.close()).pipe(logged("ServiceBus.client.close"))
|
|
18
17
|
)
|
|
19
18
|
}
|
|
20
19
|
|
|
@@ -29,9 +28,9 @@ const makeSender_ = Effect.fnUntraced(function*(queueName: string) {
|
|
|
29
28
|
|
|
30
29
|
return yield* Effect.acquireRelease(
|
|
31
30
|
Effect.sync(() => serviceBusClient.createSender(queueName)).pipe(
|
|
32
|
-
|
|
31
|
+
logged(`ServiceBus.sender.create ${queueName}`)
|
|
33
32
|
),
|
|
34
|
-
(sender) => Effect.promise(() => sender.close()).pipe(
|
|
33
|
+
(sender) => Effect.promise(() => sender.close()).pipe(logged(`ServiceBus.sender.close ${queueName}`))
|
|
35
34
|
)
|
|
36
35
|
})
|
|
37
36
|
|
|
@@ -73,20 +72,24 @@ const makeReceiver = Effect.fnUntraced(function*(name: string) {
|
|
|
73
72
|
|
|
74
73
|
const makeReceiver = Effect.fnUntraced(
|
|
75
74
|
function*(queueName: string, waitTillEmpty: Effect.Effect<void>, sessionId?: string) {
|
|
75
|
+
const annotate = sessionId !== undefined
|
|
76
|
+
? Effect.annotateLogs({ "messaging.session.id": sessionId })
|
|
77
|
+
: <A, E, R>(self: Effect.Effect<A, E, R>): Effect.Effect<A, E, R> => self
|
|
76
78
|
return yield* Effect.acquireRelease(
|
|
77
79
|
(sessionId
|
|
78
80
|
? Effect.promise(() => serviceBusClient.acceptSession(queueName, sessionId))
|
|
79
81
|
: Effect.sync(() => serviceBusClient.createReceiver(queueName)))
|
|
80
|
-
.pipe(
|
|
82
|
+
.pipe(logged(`ServiceBus.receiver.create ${queueName}`), annotate),
|
|
81
83
|
(r) =>
|
|
82
84
|
waitTillEmpty.pipe(
|
|
83
|
-
|
|
85
|
+
logged(`ServiceBus.receiver.waitTillEmpty ${queueName}`),
|
|
84
86
|
Effect.andThen(
|
|
85
87
|
Effect.promise(() => r.close()).pipe(
|
|
86
|
-
|
|
88
|
+
logged(`ServiceBus.receiver.close ${queueName}`)
|
|
87
89
|
)
|
|
88
90
|
),
|
|
89
|
-
|
|
91
|
+
logged(`ServiceBus.receiver.release ${queueName}`),
|
|
92
|
+
annotate
|
|
90
93
|
)
|
|
91
94
|
)
|
|
92
95
|
}
|
|
@@ -131,6 +134,9 @@ const makeReceiver = Effect.fnUntraced(function*(name: string) {
|
|
|
131
134
|
})
|
|
132
135
|
)
|
|
133
136
|
|
|
137
|
+
const annotate = sessionId !== undefined
|
|
138
|
+
? Effect.annotateLogs({ "messaging.session.id": sessionId })
|
|
139
|
+
: <A, E, R>(self: Effect.Effect<A, E, R>): Effect.Effect<A, E, R> => self
|
|
134
140
|
yield* Effect.acquireRelease(
|
|
135
141
|
Effect
|
|
136
142
|
.sync(() => {
|
|
@@ -141,18 +147,20 @@ const makeReceiver = Effect.fnUntraced(function*(name: string) {
|
|
|
141
147
|
hndlr
|
|
142
148
|
.processError(err)
|
|
143
149
|
.pipe(
|
|
144
|
-
Effect.catchCause((cause) => Effect.logError(
|
|
150
|
+
Effect.catchCause((cause) => Effect.logError("ServiceBus Error", cause)),
|
|
151
|
+
annotate
|
|
145
152
|
)
|
|
146
153
|
),
|
|
147
|
-
processMessage: (msg) => runEffect(hndlr.processMessage(msg))
|
|
154
|
+
processMessage: (msg) => runEffect(hndlr.processMessage(msg).pipe(annotate))
|
|
148
155
|
// DO NOT CATCH ERRORS here as they should return to the queue!
|
|
149
156
|
})
|
|
150
157
|
return { close: Effect.promise(() => s.close()) }
|
|
151
158
|
})
|
|
152
|
-
.pipe(
|
|
159
|
+
.pipe(logged("ServiceBus.subscription.create"), annotate),
|
|
153
160
|
(subscription) =>
|
|
154
161
|
subscription.close.pipe(
|
|
155
|
-
|
|
162
|
+
logged("ServiceBus.subscription.close"),
|
|
163
|
+
annotate
|
|
156
164
|
)
|
|
157
165
|
) as Effect.Effect<void, never, Scope.Scope> // wth is going on here
|
|
158
166
|
})
|
package/src/otel.ts
CHANGED
|
@@ -59,6 +59,17 @@ export const withDbSpan = (a: DbSpanOptions) =>
|
|
|
59
59
|
{ captureStackTrace: false }
|
|
60
60
|
)
|
|
61
61
|
|
|
62
|
+
/**
|
|
63
|
+
* Annotate the current span with OTel-semconv database attributes.
|
|
64
|
+
*
|
|
65
|
+
* Use when the caller already owns the span (e.g. a repository) and the
|
|
66
|
+
* adapter should only contribute db.* semconv attrs without opening a child.
|
|
67
|
+
* Annotates before running so attrs persist even on failure.
|
|
68
|
+
* No-op if there is no current span.
|
|
69
|
+
*/
|
|
70
|
+
export const annotateDb = (a: DbSpanOptions) => <A, E, R>(self: Effect.Effect<A, E, R>): Effect.Effect<A, E, R> =>
|
|
71
|
+
Effect.flatMap(Effect.annotateCurrentSpan(dbAttributes(a)), () => self)
|
|
72
|
+
|
|
62
73
|
/** Annotate the current span with response metrics from a DB call. */
|
|
63
74
|
export const annotateDbResponse = (m: {
|
|
64
75
|
readonly returnedRows?: number | undefined
|