@livestore/utils 0.3.0-dev.4 → 0.3.0-dev.40
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/.tsbuildinfo.json +1 -1
- package/dist/Deferred.d.ts.map +1 -1
- package/dist/base64.d.ts.map +1 -1
- package/dist/bun/mod.d.ts +5 -0
- package/dist/bun/mod.d.ts.map +1 -0
- package/dist/bun/mod.js +9 -0
- package/dist/bun/mod.js.map +1 -0
- package/dist/cuid/cuid.browser.d.ts.map +1 -1
- package/dist/cuid/cuid.node.d.ts.map +1 -1
- package/dist/effect/BucketQueue.d.ts +15 -2
- package/dist/effect/BucketQueue.d.ts.map +1 -1
- package/dist/effect/BucketQueue.js +24 -6
- package/dist/effect/BucketQueue.js.map +1 -1
- package/dist/effect/Effect.d.ts +4 -2
- package/dist/effect/Effect.d.ts.map +1 -1
- package/dist/effect/Effect.js +21 -18
- package/dist/effect/Effect.js.map +1 -1
- package/dist/effect/Logger.d.ts +2 -0
- package/dist/effect/Logger.d.ts.map +1 -1
- package/dist/effect/Logger.js +16 -1
- package/dist/effect/Logger.js.map +1 -1
- package/dist/effect/Scheduler.d.ts.map +1 -1
- package/dist/effect/Schema/debug-diff.d.ts.map +1 -1
- package/dist/effect/Schema/index.d.ts +3 -0
- package/dist/effect/Schema/index.d.ts.map +1 -1
- package/dist/effect/Schema/index.js +19 -0
- package/dist/effect/Schema/index.js.map +1 -1
- package/dist/effect/Schema/msgpack.d.ts +1 -1
- package/dist/effect/Schema/msgpack.d.ts.map +1 -1
- package/dist/effect/ServiceContext.d.ts.map +1 -1
- package/dist/effect/Stream.d.ts.map +1 -1
- package/dist/effect/Subscribable.d.ts +76 -0
- package/dist/effect/Subscribable.d.ts.map +1 -0
- package/dist/effect/Subscribable.js +80 -0
- package/dist/effect/Subscribable.js.map +1 -0
- package/dist/effect/TaskTracing.d.ts.map +1 -1
- package/dist/effect/{WebChannel.d.ts → WebChannel/WebChannel.d.ts} +29 -16
- package/dist/effect/WebChannel/WebChannel.d.ts.map +1 -0
- package/dist/effect/WebChannel/WebChannel.js +264 -0
- package/dist/effect/WebChannel/WebChannel.js.map +1 -0
- package/dist/effect/WebChannel/WebChannel.test.d.ts +2 -0
- package/dist/effect/WebChannel/WebChannel.test.d.ts.map +1 -0
- package/dist/effect/WebChannel/WebChannel.test.js +62 -0
- package/dist/effect/WebChannel/WebChannel.test.js.map +1 -0
- package/dist/effect/WebChannel/broadcastChannelWithAck.d.ts +5 -6
- package/dist/effect/WebChannel/broadcastChannelWithAck.d.ts.map +1 -1
- package/dist/effect/WebChannel/broadcastChannelWithAck.js +12 -9
- package/dist/effect/WebChannel/broadcastChannelWithAck.js.map +1 -1
- package/dist/effect/WebChannel/common.d.ts +16 -1
- package/dist/effect/WebChannel/common.d.ts.map +1 -1
- package/dist/effect/WebChannel/common.js +19 -1
- package/dist/effect/WebChannel/common.js.map +1 -1
- package/dist/effect/WebChannel/mod.d.ts +4 -0
- package/dist/effect/WebChannel/mod.d.ts.map +1 -0
- package/dist/effect/WebChannel/mod.js +4 -0
- package/dist/effect/WebChannel/mod.js.map +1 -0
- package/dist/effect/WebLock.d.ts.map +1 -1
- package/dist/effect/WebSocket.d.ts +3 -2
- package/dist/effect/WebSocket.d.ts.map +1 -1
- package/dist/effect/WebSocket.js +45 -19
- package/dist/effect/WebSocket.js.map +1 -1
- package/dist/effect/WebSocket.test.d.ts +2 -0
- package/dist/effect/WebSocket.test.d.ts.map +1 -0
- package/dist/effect/WebSocket.test.js +11 -0
- package/dist/effect/WebSocket.test.js.map +1 -0
- package/dist/effect/index.d.ts +5 -3
- package/dist/effect/index.d.ts.map +1 -1
- package/dist/effect/index.js +8 -5
- package/dist/effect/index.js.map +1 -1
- package/dist/env.d.ts +4 -0
- package/dist/env.d.ts.map +1 -1
- package/dist/env.js +10 -0
- package/dist/env.js.map +1 -1
- package/dist/fast-deep-equal.d.ts.map +1 -1
- package/dist/guards.d.ts.map +1 -1
- package/dist/index.d.ts +6 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/misc.d.ts.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunner.d.ts +0 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunner.d.ts.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunner.js +21 -11
- package/dist/node/ChildProcessRunner/ChildProcessRunner.js.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.d.ts +2 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.d.ts.map +1 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.js +39 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.js.map +1 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/schema.d.ts +75 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/schema.d.ts.map +1 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/schema.js +62 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/schema.js.map +1 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.d.ts +2 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.d.ts.map +1 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.js +42 -0
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.js.map +1 -0
- package/dist/node/ChildProcessRunner/ChildProcessWorker.d.ts +1 -4
- package/dist/node/ChildProcessRunner/ChildProcessWorker.d.ts.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessWorker.js +1 -4
- package/dist/node/ChildProcessRunner/ChildProcessWorker.js.map +1 -1
- package/dist/node/mod.d.ts +4 -16
- package/dist/node/mod.d.ts.map +1 -1
- package/dist/node/mod.js +25 -69
- package/dist/node/mod.js.map +1 -1
- package/dist/object/index.d.ts.map +1 -1
- package/dist/object/omit.d.ts.map +1 -1
- package/dist/object/pick.d.ts.map +1 -1
- package/dist/promise.d.ts.map +1 -1
- package/dist/set.d.ts.map +1 -1
- package/dist/string.d.ts.map +1 -1
- package/dist/time.d.ts.map +1 -1
- package/package.json +59 -51
- package/src/bun/mod.ts +12 -0
- package/src/effect/BucketQueue.ts +33 -6
- package/src/effect/Effect.ts +33 -20
- package/src/effect/Logger.ts +23 -1
- package/src/effect/Schema/index.ts +27 -0
- package/src/effect/Subscribable.ts +155 -0
- package/src/effect/WebChannel/WebChannel.test.ts +106 -0
- package/src/effect/WebChannel/WebChannel.ts +438 -0
- package/src/effect/WebChannel/broadcastChannelWithAck.ts +86 -83
- package/src/effect/WebChannel/common.ts +49 -2
- package/src/effect/WebChannel/mod.ts +3 -0
- package/src/effect/WebSocket.test.ts +15 -0
- package/src/effect/WebSocket.ts +75 -36
- package/src/effect/index.ts +18 -2
- package/src/env.ts +15 -0
- package/src/index.ts +6 -2
- package/src/node/ChildProcessRunner/ChildProcessRunner.ts +40 -29
- package/src/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.ts +52 -0
- package/src/node/ChildProcessRunner/ChildProcessRunnerTest/schema.ts +65 -0
- package/src/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.ts +53 -0
- package/src/node/ChildProcessRunner/ChildProcessWorker.ts +3 -6
- package/src/node/mod.ts +32 -94
- package/dist/effect/WebChannel.d.ts.map +0 -1
- package/dist/effect/WebChannel.js +0 -162
- package/dist/effect/WebChannel.js.map +0 -1
- package/dist/nanoid/index.browser.d.ts +0 -2
- package/dist/nanoid/index.browser.d.ts.map +0 -1
- package/dist/nanoid/index.browser.js +0 -3
- package/dist/nanoid/index.browser.js.map +0 -1
- package/src/effect/WebChannel.ts +0 -290
- package/src/nanoid/index.browser.ts +0 -2
- package/tmp/effect-deferred-repro.ts +0 -29
- package/tmp/effect-semaphore-repro.ts +0 -93
- package/tsconfig.json +0 -10
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import process from 'node:process';
|
|
3
3
|
import { WorkerError } from '@effect/platform/WorkerError';
|
|
4
4
|
import * as Runner from '@effect/platform/WorkerRunner';
|
|
5
|
-
import
|
|
5
|
+
import * as Cause from 'effect/Cause';
|
|
6
6
|
import * as Context from 'effect/Context';
|
|
7
7
|
import * as Deferred from 'effect/Deferred';
|
|
8
8
|
import * as Effect from 'effect/Effect';
|
|
@@ -13,7 +13,7 @@ import * as Runtime from 'effect/Runtime';
|
|
|
13
13
|
import * as Scope from 'effect/Scope';
|
|
14
14
|
const platformRunnerImpl = Runner.PlatformRunner.of({
|
|
15
15
|
[Runner.PlatformRunnerTypeId]: Runner.PlatformRunnerTypeId,
|
|
16
|
-
start() {
|
|
16
|
+
start(closeLatch) {
|
|
17
17
|
return Effect.gen(function* () {
|
|
18
18
|
if (!process.send) {
|
|
19
19
|
return yield* new WorkerError({ reason: 'spawn', cause: new Error('not in a child process') });
|
|
@@ -24,32 +24,42 @@ const platformRunnerImpl = Runner.PlatformRunner.of({
|
|
|
24
24
|
close: () => process.disconnect(),
|
|
25
25
|
};
|
|
26
26
|
const send = (_portId, message, _transfers) => Effect.sync(() => port.postMessage([1, message] /*, transfers as any*/));
|
|
27
|
-
const run =
|
|
28
|
-
const runtime = (yield* Effect.runtime()).pipe(Runtime.updateContext(Context.omit(Scope.Scope)));
|
|
27
|
+
const run = Effect.fnUntraced(function* (handler) {
|
|
28
|
+
const runtime = (yield* Effect.interruptible(Effect.runtime())).pipe(Runtime.updateContext(Context.omit(Scope.Scope)));
|
|
29
29
|
const fiberSet = yield* FiberSet.make();
|
|
30
30
|
const runFork = Runtime.runFork(runtime);
|
|
31
|
+
const onExit = (exit) => {
|
|
32
|
+
if (exit._tag === 'Failure' && !Cause.isInterruptedOnly(exit.cause)) {
|
|
33
|
+
// Deferred.unsafeDone(closeLatch, Exit.die(Cause.squash(exit.cause)))
|
|
34
|
+
Deferred.unsafeDone(closeLatch, Exit.die(exit.cause));
|
|
35
|
+
}
|
|
36
|
+
};
|
|
31
37
|
port.on('message', (message) => {
|
|
38
|
+
// console.log('message', message)
|
|
32
39
|
if (message[0] === 0) {
|
|
33
|
-
|
|
40
|
+
const result = handler(0, message[1]);
|
|
41
|
+
if (Effect.isEffect(result)) {
|
|
42
|
+
const fiber = runFork(result);
|
|
43
|
+
fiber.addObserver(onExit);
|
|
44
|
+
FiberSet.unsafeAdd(fiberSet, fiber);
|
|
45
|
+
}
|
|
34
46
|
}
|
|
35
47
|
else {
|
|
36
|
-
Deferred.unsafeDone(
|
|
48
|
+
Deferred.unsafeDone(closeLatch, Exit.void);
|
|
37
49
|
port.close();
|
|
38
50
|
}
|
|
39
51
|
});
|
|
40
52
|
port.on('messageerror', (cause) => {
|
|
41
|
-
Deferred.unsafeDone(
|
|
53
|
+
Deferred.unsafeDone(closeLatch, new WorkerError({ reason: 'decode', cause }));
|
|
42
54
|
});
|
|
43
55
|
port.on('error', (cause) => {
|
|
44
|
-
Deferred.unsafeDone(
|
|
56
|
+
Deferred.unsafeDone(closeLatch, new WorkerError({ reason: 'unknown', cause }));
|
|
45
57
|
});
|
|
46
58
|
port.postMessage([0]);
|
|
47
|
-
|
|
48
|
-
}).pipe(Effect.scoped));
|
|
59
|
+
});
|
|
49
60
|
return { run, send };
|
|
50
61
|
});
|
|
51
62
|
},
|
|
52
63
|
});
|
|
53
|
-
/** @internal */
|
|
54
64
|
export const layer = Layer.succeed(Runner.PlatformRunner, platformRunnerImpl);
|
|
55
65
|
//# sourceMappingURL=ChildProcessRunner.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChildProcessRunner.js","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessRunner.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,OAAO,OAAO,MAAM,cAAc,CAAA;AAElC,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAA;
|
|
1
|
+
{"version":3,"file":"ChildProcessRunner.js","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessRunner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChildProcessRunner.test.d.ts","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
// import * as WorkerThreads from 'node:worker_threads'
|
|
2
|
+
import * as ChildProcess from 'node:child_process';
|
|
3
|
+
import * as EffectWorker from '@effect/platform/Worker';
|
|
4
|
+
import { assert, describe, it } from '@effect/vitest';
|
|
5
|
+
import { Chunk, Effect, Stream } from 'effect';
|
|
6
|
+
import * as ChildProcessWorker from '../ChildProcessWorker.js';
|
|
7
|
+
import { GetPersonById, GetUserById, InitialMessage, Person, User } from './schema.js';
|
|
8
|
+
const WorkerLive = ChildProcessWorker.layer(() => ChildProcess.fork(new URL('../../../../dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.js', import.meta.url)));
|
|
9
|
+
// const WorkerLive = NodeWorker.layer(
|
|
10
|
+
// () =>
|
|
11
|
+
// new WorkerThreads.Worker(
|
|
12
|
+
// new URL('../../../../dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.js', import.meta.url),
|
|
13
|
+
// ),
|
|
14
|
+
// )
|
|
15
|
+
describe('ChildProcessRunner', { timeout: 10_000 }, () => {
|
|
16
|
+
it('Serialized', () => Effect.gen(function* () {
|
|
17
|
+
const pool = yield* EffectWorker.makePoolSerialized({ size: 1 });
|
|
18
|
+
const people = yield* pool.execute(new GetPersonById({ id: 123 })).pipe(Stream.runCollect);
|
|
19
|
+
assert.deepStrictEqual(Chunk.toReadonlyArray(people), [
|
|
20
|
+
new Person({ id: 123, name: 'test', data: new Uint8Array([1, 2, 3]) }),
|
|
21
|
+
new Person({ id: 123, name: 'ing', data: new Uint8Array([4, 5, 6]) }),
|
|
22
|
+
]);
|
|
23
|
+
}).pipe(Effect.scoped, Effect.provide(WorkerLive), Effect.runPromise));
|
|
24
|
+
it('Serialized with initialMessage', () => Effect.gen(function* () {
|
|
25
|
+
const pool = yield* EffectWorker.makePoolSerialized({
|
|
26
|
+
size: 1,
|
|
27
|
+
initialMessage: () => new InitialMessage({ name: 'custom', data: new Uint8Array([1, 2, 3]) }),
|
|
28
|
+
});
|
|
29
|
+
let user = yield* pool.executeEffect(new GetUserById({ id: 123 }));
|
|
30
|
+
user = yield* pool.executeEffect(new GetUserById({ id: 123 }));
|
|
31
|
+
assert.deepStrictEqual(user, new User({ id: 123, name: 'custom' }));
|
|
32
|
+
const people = yield* pool.execute(new GetPersonById({ id: 123 })).pipe(Stream.runCollect);
|
|
33
|
+
assert.deepStrictEqual(Chunk.toReadonlyArray(people), [
|
|
34
|
+
new Person({ id: 123, name: 'test', data: new Uint8Array([1, 2, 3]) }),
|
|
35
|
+
new Person({ id: 123, name: 'ing', data: new Uint8Array([4, 5, 6]) }),
|
|
36
|
+
]);
|
|
37
|
+
}).pipe(Effect.scoped, Effect.provide(WorkerLive), Effect.runPromise));
|
|
38
|
+
});
|
|
39
|
+
//# sourceMappingURL=ChildProcessRunner.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChildProcessRunner.test.js","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import * as Schema from 'effect/Schema';
|
|
2
|
+
declare const User_base: Schema.Class<User, {
|
|
3
|
+
id: typeof Schema.Number;
|
|
4
|
+
name: typeof Schema.String;
|
|
5
|
+
}, Schema.Struct.Encoded<{
|
|
6
|
+
id: typeof Schema.Number;
|
|
7
|
+
name: typeof Schema.String;
|
|
8
|
+
}>, never, {
|
|
9
|
+
readonly name: string;
|
|
10
|
+
} & {
|
|
11
|
+
readonly id: number;
|
|
12
|
+
}, {}, {}>;
|
|
13
|
+
export declare class User extends User_base {
|
|
14
|
+
}
|
|
15
|
+
declare const GetUserById_base: Schema.TaggedRequestClass<GetUserById, "GetUserById", {
|
|
16
|
+
readonly _tag: Schema.tag<"GetUserById">;
|
|
17
|
+
} & {
|
|
18
|
+
id: typeof Schema.Number;
|
|
19
|
+
}, typeof User, typeof Schema.Never>;
|
|
20
|
+
export declare class GetUserById extends GetUserById_base {
|
|
21
|
+
}
|
|
22
|
+
declare const Person_base: Schema.Class<Person, {
|
|
23
|
+
id: typeof Schema.Number;
|
|
24
|
+
name: typeof Schema.String;
|
|
25
|
+
data: typeof Schema.Uint8Array;
|
|
26
|
+
}, Schema.Struct.Encoded<{
|
|
27
|
+
id: typeof Schema.Number;
|
|
28
|
+
name: typeof Schema.String;
|
|
29
|
+
data: typeof Schema.Uint8Array;
|
|
30
|
+
}>, never, {
|
|
31
|
+
readonly name: string;
|
|
32
|
+
} & {
|
|
33
|
+
readonly id: number;
|
|
34
|
+
} & {
|
|
35
|
+
readonly data: Uint8Array<ArrayBufferLike>;
|
|
36
|
+
}, {}, {}>;
|
|
37
|
+
export declare class Person extends Person_base {
|
|
38
|
+
}
|
|
39
|
+
declare const GetPersonById_base: Schema.TaggedRequestClass<GetPersonById, "GetPersonById", {
|
|
40
|
+
readonly _tag: Schema.tag<"GetPersonById">;
|
|
41
|
+
} & {
|
|
42
|
+
id: typeof Schema.Number;
|
|
43
|
+
}, typeof Person, typeof Schema.Never>;
|
|
44
|
+
export declare class GetPersonById extends GetPersonById_base {
|
|
45
|
+
}
|
|
46
|
+
declare const RunnerInterrupt_base: Schema.TaggedRequestClass<RunnerInterrupt, "RunnerInterrupt", {
|
|
47
|
+
readonly _tag: Schema.tag<"RunnerInterrupt">;
|
|
48
|
+
}, typeof Schema.Void, typeof Schema.Never>;
|
|
49
|
+
export declare class RunnerInterrupt extends RunnerInterrupt_base {
|
|
50
|
+
}
|
|
51
|
+
declare const InitialMessage_base: Schema.TaggedRequestClass<InitialMessage, "InitialMessage", {
|
|
52
|
+
readonly _tag: Schema.tag<"InitialMessage">;
|
|
53
|
+
} & {
|
|
54
|
+
name: typeof Schema.String;
|
|
55
|
+
data: typeof Schema.Uint8Array;
|
|
56
|
+
}, typeof Schema.Void, typeof Schema.Never>;
|
|
57
|
+
export declare class InitialMessage extends InitialMessage_base {
|
|
58
|
+
}
|
|
59
|
+
declare const GetSpan_base: Schema.TaggedRequestClass<GetSpan, "GetSpan", {
|
|
60
|
+
readonly _tag: Schema.tag<"GetSpan">;
|
|
61
|
+
}, Schema.Struct<{
|
|
62
|
+
name: typeof Schema.String;
|
|
63
|
+
traceId: typeof Schema.String;
|
|
64
|
+
spanId: typeof Schema.String;
|
|
65
|
+
parent: Schema.Option<Schema.Struct<{
|
|
66
|
+
traceId: typeof Schema.String;
|
|
67
|
+
spanId: typeof Schema.String;
|
|
68
|
+
}>>;
|
|
69
|
+
}>, typeof Schema.Never>;
|
|
70
|
+
export declare class GetSpan extends GetSpan_base {
|
|
71
|
+
}
|
|
72
|
+
export declare const WorkerMessage: Schema.Union<[typeof GetUserById, typeof GetPersonById, typeof InitialMessage, typeof GetSpan, typeof RunnerInterrupt]>;
|
|
73
|
+
export type WorkerMessage = Schema.Schema.Type<typeof WorkerMessage>;
|
|
74
|
+
export {};
|
|
75
|
+
//# sourceMappingURL=schema.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/schema.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,eAAe,CAAA;;;;;;;;;;;;AAEvC,qBAAa,IAAK,SAAQ,SAGxB;CAAG;;;;;;AAEL,qBAAa,WAAY,SAAQ,gBAM/B;CAAG;;;;;;;;;;;;;;;;AAEL,qBAAa,MAAO,SAAQ,WAK1B;CAAG;;;;;;AAEL,qBAAa,aAAc,SAAQ,kBAMjC;CAAG;;;;AAEL,qBAAa,eAAgB,SAAQ,oBAInC;CAAG;;;;;;;AAEL,qBAAa,cAAe,SAAQ,mBAQlC;CAAG;;;;;;;;;;;;AAEL,qBAAa,OAAQ,SAAQ,YAc3B;CAAG;AAEL,eAAO,MAAM,aAAa,yHAAqF,CAAA;AAC/G,MAAM,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,aAAa,CAAC,CAAA"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
// import * as Transferable from '@effect/platform/Transferable'
|
|
2
|
+
import * as Schema from 'effect/Schema';
|
|
3
|
+
export class User extends Schema.Class('User')({
|
|
4
|
+
id: Schema.Number,
|
|
5
|
+
name: Schema.String,
|
|
6
|
+
}) {
|
|
7
|
+
}
|
|
8
|
+
export class GetUserById extends Schema.TaggedRequest()('GetUserById', {
|
|
9
|
+
failure: Schema.Never,
|
|
10
|
+
success: User,
|
|
11
|
+
payload: {
|
|
12
|
+
id: Schema.Number,
|
|
13
|
+
},
|
|
14
|
+
}) {
|
|
15
|
+
}
|
|
16
|
+
export class Person extends Schema.Class('Person')({
|
|
17
|
+
id: Schema.Number,
|
|
18
|
+
name: Schema.String,
|
|
19
|
+
// data: Transferable.Uint8Array,
|
|
20
|
+
data: Schema.Uint8Array,
|
|
21
|
+
}) {
|
|
22
|
+
}
|
|
23
|
+
export class GetPersonById extends Schema.TaggedRequest()('GetPersonById', {
|
|
24
|
+
failure: Schema.Never,
|
|
25
|
+
success: Person,
|
|
26
|
+
payload: {
|
|
27
|
+
id: Schema.Number,
|
|
28
|
+
},
|
|
29
|
+
}) {
|
|
30
|
+
}
|
|
31
|
+
export class RunnerInterrupt extends Schema.TaggedRequest()('RunnerInterrupt', {
|
|
32
|
+
failure: Schema.Never,
|
|
33
|
+
success: Schema.Void,
|
|
34
|
+
payload: {},
|
|
35
|
+
}) {
|
|
36
|
+
}
|
|
37
|
+
export class InitialMessage extends Schema.TaggedRequest()('InitialMessage', {
|
|
38
|
+
failure: Schema.Never,
|
|
39
|
+
success: Schema.Void,
|
|
40
|
+
payload: {
|
|
41
|
+
name: Schema.String,
|
|
42
|
+
data: Schema.Uint8Array,
|
|
43
|
+
// data: Transferable.Uint8Array,
|
|
44
|
+
},
|
|
45
|
+
}) {
|
|
46
|
+
}
|
|
47
|
+
export class GetSpan extends Schema.TaggedRequest()('GetSpan', {
|
|
48
|
+
failure: Schema.Never,
|
|
49
|
+
success: Schema.Struct({
|
|
50
|
+
name: Schema.String,
|
|
51
|
+
traceId: Schema.String,
|
|
52
|
+
spanId: Schema.String,
|
|
53
|
+
parent: Schema.Option(Schema.Struct({
|
|
54
|
+
traceId: Schema.String,
|
|
55
|
+
spanId: Schema.String,
|
|
56
|
+
})),
|
|
57
|
+
}),
|
|
58
|
+
payload: {},
|
|
59
|
+
}) {
|
|
60
|
+
}
|
|
61
|
+
export const WorkerMessage = Schema.Union(GetUserById, GetPersonById, InitialMessage, GetSpan, RunnerInterrupt);
|
|
62
|
+
//# sourceMappingURL=schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/schema.ts"],"names":[],"mappings":"AAAA,gEAAgE;AAChE,OAAO,KAAK,MAAM,MAAM,eAAe,CAAA;AAEvC,MAAM,OAAO,IAAK,SAAQ,MAAM,CAAC,KAAK,CAAO,MAAM,CAAC,CAAC;IACnD,EAAE,EAAE,MAAM,CAAC,MAAM;IACjB,IAAI,EAAE,MAAM,CAAC,MAAM;CACpB,CAAC;CAAG;AAEL,MAAM,OAAO,WAAY,SAAQ,MAAM,CAAC,aAAa,EAAe,CAAC,aAAa,EAAE;IAClF,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,IAAI;IACb,OAAO,EAAE;QACP,EAAE,EAAE,MAAM,CAAC,MAAM;KAClB;CACF,CAAC;CAAG;AAEL,MAAM,OAAO,MAAO,SAAQ,MAAM,CAAC,KAAK,CAAS,QAAQ,CAAC,CAAC;IACzD,EAAE,EAAE,MAAM,CAAC,MAAM;IACjB,IAAI,EAAE,MAAM,CAAC,MAAM;IACnB,iCAAiC;IACjC,IAAI,EAAE,MAAM,CAAC,UAAU;CACxB,CAAC;CAAG;AAEL,MAAM,OAAO,aAAc,SAAQ,MAAM,CAAC,aAAa,EAAiB,CAAC,eAAe,EAAE;IACxF,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM;IACf,OAAO,EAAE;QACP,EAAE,EAAE,MAAM,CAAC,MAAM;KAClB;CACF,CAAC;CAAG;AAEL,MAAM,OAAO,eAAgB,SAAQ,MAAM,CAAC,aAAa,EAAmB,CAAC,iBAAiB,EAAE;IAC9F,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,IAAI;IACpB,OAAO,EAAE,EAAE;CACZ,CAAC;CAAG;AAEL,MAAM,OAAO,cAAe,SAAQ,MAAM,CAAC,aAAa,EAAkB,CAAC,gBAAgB,EAAE;IAC3F,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,IAAI;IACpB,OAAO,EAAE;QACP,IAAI,EAAE,MAAM,CAAC,MAAM;QACnB,IAAI,EAAE,MAAM,CAAC,UAAU;QACvB,iCAAiC;KAClC;CACF,CAAC;CAAG;AAEL,MAAM,OAAO,OAAQ,SAAQ,MAAM,CAAC,aAAa,EAAW,CAAC,SAAS,EAAE;IACtE,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC;QACrB,IAAI,EAAE,MAAM,CAAC,MAAM;QACnB,OAAO,EAAE,MAAM,CAAC,MAAM;QACtB,MAAM,EAAE,MAAM,CAAC,MAAM;QACrB,MAAM,EAAE,MAAM,CAAC,MAAM,CACnB,MAAM,CAAC,MAAM,CAAC;YACZ,OAAO,EAAE,MAAM,CAAC,MAAM;YACtB,MAAM,EAAE,MAAM,CAAC,MAAM;SACtB,CAAC,CACH;KACF,CAAC;IACF,OAAO,EAAE,EAAE;CACZ,CAAC;CAAG;AAEL,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,WAAW,EAAE,aAAa,EAAE,cAAc,EAAE,OAAO,EAAE,eAAe,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serializedWorker.d.ts","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import * as Runner from '@effect/platform/WorkerRunner';
|
|
2
|
+
import { Context, Effect, Layer, Option, Stream } from 'effect';
|
|
3
|
+
// import { NodeRuntime, NodeWorkerRunner } from '@effect/platform-node'
|
|
4
|
+
import { PlatformNode } from '../../mod.js';
|
|
5
|
+
import * as ChildProcessRunner from '../ChildProcessRunner.js';
|
|
6
|
+
import { Person, User, WorkerMessage } from './schema.js';
|
|
7
|
+
const Name = Context.GenericTag('Name');
|
|
8
|
+
const WorkerLive = Runner.layerSerialized(WorkerMessage, {
|
|
9
|
+
GetPersonById: (req) => {
|
|
10
|
+
return Stream.make(new Person({ id: req.id, name: 'test', data: new Uint8Array([1, 2, 3]) }), new Person({ id: req.id, name: 'ing', data: new Uint8Array([4, 5, 6]) }));
|
|
11
|
+
},
|
|
12
|
+
GetUserById: (req) => Effect.map(Name, (name) => new User({ id: req.id, name })),
|
|
13
|
+
// InitialMessage: (req) => Layer.succeed(Name, req.name),
|
|
14
|
+
InitialMessage: (req) => Effect.gen(function* () {
|
|
15
|
+
yield* Effect.addFinalizer(() => Effect.log('closing worker scope'));
|
|
16
|
+
return Layer.succeed(Name, req.name);
|
|
17
|
+
}).pipe(Layer.unwrapScoped),
|
|
18
|
+
// InitialMessage: (req) =>
|
|
19
|
+
// Layer.scoped(
|
|
20
|
+
// Name,
|
|
21
|
+
// Effect.gen(function* () {
|
|
22
|
+
// yield* Effect.addFinalizer(() => Effect.log('closing worker scope'))
|
|
23
|
+
// return req.name
|
|
24
|
+
// }),
|
|
25
|
+
// ),
|
|
26
|
+
GetSpan: (_) => Effect.gen(function* (_) {
|
|
27
|
+
const span = yield* _(Effect.currentSpan, Effect.orDie);
|
|
28
|
+
return {
|
|
29
|
+
traceId: span.traceId,
|
|
30
|
+
spanId: span.spanId,
|
|
31
|
+
name: span.name,
|
|
32
|
+
parent: Option.map(span.parent, (span) => ({
|
|
33
|
+
traceId: span.traceId,
|
|
34
|
+
spanId: span.spanId,
|
|
35
|
+
})),
|
|
36
|
+
};
|
|
37
|
+
}).pipe(Effect.withSpan('GetSpan')),
|
|
38
|
+
RunnerInterrupt: () => Effect.interrupt,
|
|
39
|
+
}).pipe(Layer.provide(ChildProcessRunner.layer));
|
|
40
|
+
// }).pipe(Layer.provide(PlatformNode.NodeWorkerRunner.layer))
|
|
41
|
+
PlatformNode.NodeRuntime.runMain(Runner.launch(WorkerLive));
|
|
42
|
+
//# sourceMappingURL=serializedWorker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serializedWorker.js","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,7 @@
|
|
|
1
|
-
import type * as ChildProcess from 'node:child_process';
|
|
2
1
|
import * as Worker from '@effect/platform/Worker';
|
|
2
|
+
import type * as ChildProcess from 'child_process';
|
|
3
3
|
import * as Layer from 'effect/Layer';
|
|
4
|
-
/** @internal */
|
|
5
4
|
export declare const layerWorker: Layer.Layer<Worker.PlatformWorker, never, never>;
|
|
6
|
-
/** @internal */
|
|
7
5
|
export declare const layerManager: Layer.Layer<Worker.WorkerManager, never, never>;
|
|
8
|
-
/** @internal */
|
|
9
6
|
export declare const layer: (spawn: (id: number) => ChildProcess.ChildProcess) => Layer.Layer<Worker.Spawner | Worker.WorkerManager, never, never>;
|
|
10
7
|
//# sourceMappingURL=ChildProcessWorker.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChildProcessWorker.d.ts","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessWorker.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"ChildProcessWorker.d.ts","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessWorker.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,MAAM,yBAAyB,CAAA;AAGjD,OAAO,KAAK,KAAK,YAAY,MAAM,eAAe,CAAA;AAIlD,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AAgDrC,eAAO,MAAM,WAAW,kDAA2D,CAAA;AAEnF,eAAO,MAAM,YAAY,iDAAkD,CAAA;AAE3E,eAAO,MAAM,KAAK,GAAI,OAAO,CAAC,EAAE,EAAE,MAAM,KAAK,YAAY,CAAC,YAAY,qEACf,CAAA"}
|
|
@@ -15,7 +15,7 @@ const platformWorkerImpl = Worker.makePlatform()({
|
|
|
15
15
|
return Effect.as(Scope.addFinalizer(scope, Effect.suspend(() => {
|
|
16
16
|
childProcess.send([1]);
|
|
17
17
|
return Deferred.await(exitDeferred);
|
|
18
|
-
}).pipe(Effect.
|
|
18
|
+
}).pipe(Effect.timeout(5000), Effect.interruptible, Effect.catchAllCause(() => Effect.sync(() => childProcess.kill())))), {
|
|
19
19
|
postMessage: (message) => childProcess.send(message),
|
|
20
20
|
on: (event, handler) => childProcess.on(event, handler),
|
|
21
21
|
});
|
|
@@ -37,10 +37,7 @@ const platformWorkerImpl = Worker.makePlatform()({
|
|
|
37
37
|
return Effect.void;
|
|
38
38
|
},
|
|
39
39
|
});
|
|
40
|
-
/** @internal */
|
|
41
40
|
export const layerWorker = Layer.succeed(Worker.PlatformWorker, platformWorkerImpl);
|
|
42
|
-
/** @internal */
|
|
43
41
|
export const layerManager = Layer.provide(Worker.layerManager, layerWorker);
|
|
44
|
-
/** @internal */
|
|
45
42
|
export const layer = (spawn) => Layer.merge(layerManager, Worker.layerSpawner(spawn));
|
|
46
43
|
//# sourceMappingURL=ChildProcessWorker.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChildProcessWorker.js","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessWorker.ts"],"names":[],"mappings":"AAAA,wDAAwD;
|
|
1
|
+
{"version":3,"file":"ChildProcessWorker.js","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessWorker.ts"],"names":[],"mappings":"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"}
|
package/dist/node/mod.d.ts
CHANGED
|
@@ -1,22 +1,10 @@
|
|
|
1
|
-
import type * as otel from '@opentelemetry/api';
|
|
2
1
|
import { Effect, Layer } from 'effect';
|
|
3
|
-
import
|
|
4
|
-
import type { OtelTracer } from '../effect/index.js';
|
|
2
|
+
import { OtelTracer, UnknownError } from '../effect/index.js';
|
|
5
3
|
export * as Cli from '@effect/cli';
|
|
6
|
-
export * as PlatformBun from '@effect/platform-bun';
|
|
7
4
|
export * as PlatformNode from '@effect/platform-node';
|
|
8
|
-
export * as SocketServer from '@effect/
|
|
9
|
-
export * as OtelResource from '@effect/opentelemetry/Resource';
|
|
10
|
-
export { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';
|
|
11
|
-
export { OTLPMetricExporter } from '@opentelemetry/exporter-metrics-otlp-http';
|
|
12
|
-
export * as OtelNodeSdk from '@effect/opentelemetry/NodeSdk';
|
|
5
|
+
export * as SocketServer from '@effect/platform/SocketServer';
|
|
13
6
|
export * as ChildProcessRunner from './ChildProcessRunner/ChildProcessRunner.js';
|
|
14
7
|
export * as ChildProcessWorker from './ChildProcessRunner/ChildProcessWorker.js';
|
|
15
|
-
export declare const
|
|
16
|
-
|
|
17
|
-
rootSpanName?: string;
|
|
18
|
-
skipLogUrl?: boolean;
|
|
19
|
-
}) => Layer.Layer<OtelTracer.OtelTracer | ParentSpan, never, never>;
|
|
20
|
-
export declare const logTraceUiUrlForSpan: (printMsg?: (url: string) => string) => (span: otel.Span) => Effect.Effect<string | undefined, never, never>;
|
|
21
|
-
export declare const getTracingBackendUrl: (span: otel.Span) => Effect.Effect<string | undefined, never, never>;
|
|
8
|
+
export declare const getFreePort: Effect.Effect<number, UnknownError, never>;
|
|
9
|
+
export declare const OtelLiveDummy: Layer.Layer<OtelTracer.OtelTracer>;
|
|
22
10
|
//# sourceMappingURL=mod.d.ts.map
|
package/dist/node/mod.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mod.d.ts","sourceRoot":"","sources":["../../src/node/mod.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"mod.d.ts","sourceRoot":"","sources":["../../src/node/mod.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAA;AAEtC,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AAG7D,OAAO,KAAK,GAAG,MAAM,aAAa,CAAA;AAClC,OAAO,KAAK,YAAY,MAAM,uBAAuB,CAAA;AACrD,OAAO,KAAK,YAAY,MAAM,+BAA+B,CAAA;AAE7D,OAAO,KAAK,kBAAkB,MAAM,4CAA4C,CAAA;AAChF,OAAO,KAAK,kBAAkB,MAAM,4CAA4C,CAAA;AAOhF,eAAO,MAAM,WAAW,4CAuBtB,CAAA;AAEF,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAQ3D,CAAA"}
|
package/dist/node/mod.js
CHANGED
|
@@ -1,83 +1,39 @@
|
|
|
1
|
-
import * as
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import { BatchSpanProcessor } from '@opentelemetry/sdk-trace-base';
|
|
6
|
-
import { Config, Effect, Layer } from 'effect';
|
|
7
|
-
import { tapCauseLogPretty } from '../effect/Effect.js';
|
|
8
|
-
// import { tapCauseLogPretty } from '../effect/Effect.js'
|
|
1
|
+
import * as http from 'node:http';
|
|
2
|
+
import { Effect, Layer } from 'effect';
|
|
3
|
+
import { OtelTracer, UnknownError } from '../effect/index.js';
|
|
4
|
+
import { makeNoopTracer } from '../NoopTracer.js';
|
|
9
5
|
export * as Cli from '@effect/cli';
|
|
10
|
-
export * as PlatformBun from '@effect/platform-bun';
|
|
11
6
|
export * as PlatformNode from '@effect/platform-node';
|
|
12
|
-
export * as SocketServer from '@effect/
|
|
13
|
-
export * as OtelResource from '@effect/opentelemetry/Resource';
|
|
14
|
-
export { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';
|
|
15
|
-
export { OTLPMetricExporter } from '@opentelemetry/exporter-metrics-otlp-http';
|
|
16
|
-
export * as OtelNodeSdk from '@effect/opentelemetry/NodeSdk';
|
|
7
|
+
export * as SocketServer from '@effect/platform/SocketServer';
|
|
17
8
|
export * as ChildProcessRunner from './ChildProcessRunner/ChildProcessRunner.js';
|
|
18
9
|
export * as ChildProcessWorker from './ChildProcessRunner/ChildProcessWorker.js';
|
|
19
10
|
// Enable debug logging for OpenTelemetry
|
|
20
11
|
// otel.diag.setLogger(new otel.DiagConsoleLogger(), otel.DiagLogLevel.ERROR)
|
|
21
12
|
// export const OtelLiveHttp = (args: any): Layer.Layer<never> => Layer.empty
|
|
22
|
-
export const
|
|
23
|
-
const
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
serviceName: serviceName
|
|
27
|
-
? Config.succeed(serviceName)
|
|
28
|
-
: Config.string('OTEL_SERVICE_NAME').pipe(Config.withDefault('overtone-node-utils-default-service')),
|
|
29
|
-
rootSpanName: rootSpanName
|
|
30
|
-
? Config.succeed(rootSpanName)
|
|
31
|
-
: Config.string('OTEL_ROOT_SPAN_NAME').pipe(Config.withDefault('RootSpan')),
|
|
32
|
-
}).pipe(tapCauseLogPretty, Effect.orDie);
|
|
33
|
-
const resource = { serviceName: config.serviceName };
|
|
34
|
-
// METRICS
|
|
35
|
-
const metricExporter = new OTLPMetricExporter({ url: config.exporterUrlMracing });
|
|
36
|
-
const metricReader = new PeriodicExportingMetricReader({
|
|
37
|
-
exporter: metricExporter,
|
|
38
|
-
exportIntervalMillis: 1000,
|
|
13
|
+
export const getFreePort = Effect.async((cb, signal) => {
|
|
14
|
+
const server = http.createServer();
|
|
15
|
+
signal.addEventListener('abort', () => {
|
|
16
|
+
server.close();
|
|
39
17
|
});
|
|
40
|
-
//
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
const RootSpanLive = Layer.span(config.rootSpanName, {
|
|
47
|
-
attributes: { config },
|
|
48
|
-
onEnd: skipLogUrl ? undefined : (span) => logTraceUiUrlForSpan()(span.span),
|
|
49
|
-
});
|
|
50
|
-
return RootSpanLive.pipe(Layer.provideMerge(OtelLive));
|
|
51
|
-
}).pipe(Layer.unwrapEffect);
|
|
52
|
-
export const logTraceUiUrlForSpan = (printMsg) => (span) => getTracingBackendUrl(span).pipe(Effect.tap((url) => {
|
|
53
|
-
if (url === undefined) {
|
|
54
|
-
console.warn('No tracing backend url found');
|
|
55
|
-
}
|
|
56
|
-
else {
|
|
57
|
-
if (printMsg) {
|
|
58
|
-
console.log(printMsg(url));
|
|
18
|
+
// Listen on port 0 to get an available port
|
|
19
|
+
server.listen(0, () => {
|
|
20
|
+
const address = server.address();
|
|
21
|
+
if (address && typeof address === 'object') {
|
|
22
|
+
const port = address.port;
|
|
23
|
+
server.close(() => cb(Effect.succeed(port)));
|
|
59
24
|
}
|
|
60
25
|
else {
|
|
61
|
-
|
|
26
|
+
server.close(() => cb(Effect.fail(new UnknownError({ cause: 'Failed to get a free port' }))));
|
|
62
27
|
}
|
|
63
|
-
}
|
|
64
|
-
}));
|
|
65
|
-
export const getTracingBackendUrl = (span) => Effect.gen(function* () {
|
|
66
|
-
const endpoint = yield* Config.string('TRACING_UI_ENDPOINT').pipe(Config.option, Effect.orDie);
|
|
67
|
-
if (endpoint._tag === 'None')
|
|
68
|
-
return;
|
|
69
|
-
const traceId = span.spanContext().traceId;
|
|
70
|
-
// Grafana + Tempo
|
|
71
|
-
const grafanaEndpoint = endpoint.value;
|
|
72
|
-
const searchParams = new URLSearchParams({
|
|
73
|
-
orgId: '1',
|
|
74
|
-
left: JSON.stringify({
|
|
75
|
-
datasource: 'tempo',
|
|
76
|
-
queries: [{ query: traceId, queryType: 'traceql', refId: 'A' }],
|
|
77
|
-
range: { from: 'now-1h', to: 'now' },
|
|
78
|
-
}),
|
|
79
28
|
});
|
|
80
|
-
//
|
|
81
|
-
|
|
29
|
+
// Error handling in case the server encounters an error
|
|
30
|
+
server.on('error', (err) => {
|
|
31
|
+
server.close(() => cb(Effect.fail(new UnknownError({ cause: err }))));
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
export const OtelLiveDummy = Layer.suspend(() => {
|
|
35
|
+
const OtelTracerLive = Layer.succeed(OtelTracer.OtelTracer, makeNoopTracer());
|
|
36
|
+
const TracingLive = Layer.unwrapEffect(Effect.map(OtelTracer.make, Layer.setTracer)).pipe(Layer.provideMerge(OtelTracerLive));
|
|
37
|
+
return TracingLive;
|
|
82
38
|
});
|
|
83
39
|
//# sourceMappingURL=mod.js.map
|
package/dist/node/mod.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../src/node/mod.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../src/node/mod.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,WAAW,CAAA;AAEjC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAA;AAEtC,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AAC7D,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAEjD,OAAO,KAAK,GAAG,MAAM,aAAa,CAAA;AAClC,OAAO,KAAK,YAAY,MAAM,uBAAuB,CAAA;AACrD,OAAO,KAAK,YAAY,MAAM,+BAA+B,CAAA;AAE7D,OAAO,KAAK,kBAAkB,MAAM,4CAA4C,CAAA;AAChF,OAAO,KAAK,kBAAkB,MAAM,4CAA4C,CAAA;AAEhF,yCAAyC;AACzC,6EAA6E;AAE7E,6EAA6E;AAE7E,MAAM,CAAC,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAuB,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE;IAC3E,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,EAAE,CAAA;IAElC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;QACpC,MAAM,CAAC,KAAK,EAAE,CAAA;IAChB,CAAC,CAAC,CAAA;IAEF,4CAA4C;IAC5C,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE;QACpB,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,EAAE,CAAA;QAEhC,IAAI,OAAO,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAC3C,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAA;YACzB,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAC9C,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,EAAE,KAAK,EAAE,2BAA2B,EAAE,CAAC,CAAC,CAAC,CAAC,CAAA;QAC/F,CAAC;IACH,CAAC,CAAC,CAAA;IAEF,wDAAwD;IACxD,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;QACzB,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAA;IACvE,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,aAAa,GAAuC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;IAClF,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,UAAU,EAAE,cAAc,EAAE,CAAC,CAAA;IAE7E,MAAM,WAAW,GAAG,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CACvF,KAAK,CAAC,YAAY,CAAC,cAAc,CAAC,CACU,CAAA;IAE9C,OAAO,WAAW,CAAA;AACpB,CAAC,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/object/index.ts"],"names":[],"mappings":"AAEA,cAAc,WAAW,CAAA;AACzB,cAAc,WAAW,CAAA;AAEzB,KAAK,aAAa,CAAC,CAAC,SAAS,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,SAAS,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,CAAA;AAE3F,eAAO,MAAM,eAAe,GAAI,IAAI,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,KAAK,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/object/index.ts"],"names":[],"mappings":"AAEA,cAAc,WAAW,CAAA;AACzB,cAAc,WAAW,CAAA;AAEzB,KAAK,aAAa,CAAC,CAAC,SAAS,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,SAAS,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,CAAA;AAE3F,eAAO,MAAM,eAAe,GAAI,IAAI,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,KAAK,EACrE,KAAK,IAAI,EACT,UAAU,CAAC,GAAG,EAAE,MAAM,IAAI,EAAE,GAAG,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,KAAK,KAC7D,GAAG,CAAC,IAAI,MAAM,IAAI,GAAG,KAAK,GAG5B,CAAA;AAED,MAAM,MAAM,OAAO,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;CAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAA;AAEjE,eAAO,MAAM,aAAa,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,KAAK,CAAC,KAAG,OAAO,CAAC,CAAC,CAAsC,CAAA;AAErH,eAAO,MAAM,mBAAmB,GAAI,IAAI,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,KAAK,IAAI,KAAG,GAAG,CAAC,IAAI,MAAM,IAAI,GAAG,CAAC,GAI9F,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"omit.d.ts","sourceRoot":"","sources":["../../src/object/omit.ts"],"names":[],"mappings":"AAKA,uEAAuE;AACvE,eAAO,MAAM,IAAI,GAAI,GAAG,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,IAAI,SAAS,MAAM,GAAG,
|
|
1
|
+
{"version":3,"file":"omit.d.ts","sourceRoot":"","sources":["../../src/object/omit.ts"],"names":[],"mappings":"AAKA,uEAAuE;AACvE,eAAO,MAAM,IAAI,GAAI,GAAG,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,IAAI,SAAS,MAAM,GAAG,EAC1E,KAAK,GAAG,EACR,MAAM,IAAI,EAAE,KACX,IAAI,CAAC,GAAG,EAAE,IAAI,CAOhB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pick.d.ts","sourceRoot":"","sources":["../../src/object/pick.ts"],"names":[],"mappings":"AAAA,KAAK,gBAAgB,CAAC,CAAC,IAAI,WAAW,CAAC;KAAG,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAE,CAAC,CAAA;AACxG,KAAK,WAAW,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,SAAS;CAAE,CAAA;AAC1D,KAAK,YAAY,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAE,CAAA;AACrF,KAAK,WAAW,CAAC,CAAC,IAAI,gBAAgB,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAA;AAE3D,eAAO,MAAM,IAAI,GAAI,GAAG,EAAE,IAAI,SAAS,MAAM,GAAG,
|
|
1
|
+
{"version":3,"file":"pick.d.ts","sourceRoot":"","sources":["../../src/object/pick.ts"],"names":[],"mappings":"AAAA,KAAK,gBAAgB,CAAC,CAAC,IAAI,WAAW,CAAC;KAAG,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAE,CAAC,CAAA;AACxG,KAAK,WAAW,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,SAAS;CAAE,CAAA;AAC1D,KAAK,YAAY,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAE,CAAA;AACrF,KAAK,WAAW,CAAC,CAAC,IAAI,gBAAgB,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAA;AAE3D,eAAO,MAAM,IAAI,GAAI,GAAG,EAAE,IAAI,SAAS,MAAM,GAAG,EAAE,KAAK,GAAG,EAAE,MAAM,IAAI,EAAE,KAAG,WAAW,CAAC,GAAG,CAAC,IAAI,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,GAAE,CAK7G,CAAA;AAED,eAAO,MAAM,aAAa,GAAI,GAAG,EAAE,IAAI,SAAS,MAAM,GAAG,EAAE,KAAK,EAC9D,KAAK,GAAG,EACR,MAAM,IAAI,EAAE,EACZ,WAAW,KAAK,KACf,WAAW,CAAC,GAAG,CAAC,IAAI,IAAI,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAE,CAAC,GAAG,KAUtD,CAAA"}
|
package/dist/promise.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"promise.d.ts","sourceRoot":"","sources":["../src/promise.ts"],"names":[],"mappings":"AAAA,8BAA8B;AAC9B,eAAO,MAAM,UAAU,GAAI,CAAC,EAAE,GAAG,
|
|
1
|
+
{"version":3,"file":"promise.d.ts","sourceRoot":"","sources":["../src/promise.ts"],"names":[],"mappings":"AAAA,8BAA8B;AAC9B,eAAO,MAAM,UAAU,GAAI,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,6CACpE,CAAA;AAE3B,eAAO,MAAM,cAAc,GAAU,CAAC,EAAE,GAAG,EACzC,MAAM,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,EACvB,KAAK,CAAC,EAAE,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,KACjD,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAG7B,CAAA;AAED,eAAO,MAAM,gBAAgB,GAAU,CAAC,EAAE,GAAG,EAC3C,KAAK,CAAC,EAAE,EACR,UAAU,CAAC,EAAE,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,EACvD,QAAQ,CAAC,EAAE,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,MAAM,KACxC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAI7B,CAAA;AAED,eAAO,MAAM,cAAc,GAAU,CAAC,EAAE,GAAG,EACzC,KAAK,CAAC,EAAE,EACR,KAAK,CAAC,EAAE,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,GAAG,CAAC,EAC5C,WAAW,MAAM,KAChB,OAAO,CAAC,GAAG,EAAE,CAgBf,CAAA"}
|
package/dist/set.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"set.d.ts","sourceRoot":"","sources":["../src/set.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,UAAU,GAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"set.d.ts","sourceRoot":"","sources":["../src/set.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,UAAU,GAAI,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,WASjD,CAAA"}
|