@dxos/functions 0.8.4-main.3a94e84 → 0.8.4-main.5acf9ea
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/lib/browser/{chunk-3NGCSUEW.mjs → chunk-6PTFLPCO.mjs} +194 -60
- package/dist/lib/browser/chunk-6PTFLPCO.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +13 -15
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +2 -34
- package/dist/lib/browser/testing/index.mjs.map +3 -3
- package/dist/lib/node-esm/{chunk-FJ2MU7TL.mjs → chunk-NYJ2TSXO.mjs} +194 -60
- package/dist/lib/node-esm/chunk-NYJ2TSXO.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +13 -15
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/testing/index.mjs +2 -34
- package/dist/lib/node-esm/testing/index.mjs.map +3 -3
- package/dist/types/src/services/credentials.d.ts +3 -2
- package/dist/types/src/services/credentials.d.ts.map +1 -1
- package/dist/types/src/services/database.d.ts +2 -1
- package/dist/types/src/services/database.d.ts.map +1 -1
- package/dist/types/src/services/event-logger.d.ts +65 -30
- package/dist/types/src/services/event-logger.d.ts.map +1 -1
- package/dist/types/src/services/index.d.ts +2 -1
- package/dist/types/src/services/index.d.ts.map +1 -1
- package/dist/types/src/services/local-function-execution.d.ts +11 -0
- package/dist/types/src/services/local-function-execution.d.ts.map +1 -0
- package/dist/types/src/services/queues.d.ts +3 -2
- package/dist/types/src/services/queues.d.ts.map +1 -1
- package/dist/types/src/services/remote-function-execution-service.d.ts +15 -0
- package/dist/types/src/services/remote-function-execution-service.d.ts.map +1 -0
- package/dist/types/src/services/service-container.d.ts +4 -4
- package/dist/types/src/services/service-container.d.ts.map +1 -1
- package/dist/types/src/services/service-registry.d.ts +1 -1
- package/dist/types/src/services/service-registry.d.ts.map +1 -1
- package/dist/types/src/services/tracing.d.ts +3 -2
- package/dist/types/src/services/tracing.d.ts.map +1 -1
- package/dist/types/src/testing/logger.d.ts +3 -3
- package/dist/types/src/testing/logger.d.ts.map +1 -1
- package/dist/types/src/testing/services.d.ts +6 -17
- package/dist/types/src/testing/services.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +32 -27
- package/src/services/credentials.ts +5 -2
- package/src/services/database.ts +5 -1
- package/src/services/event-logger.ts +67 -36
- package/src/services/index.ts +2 -1
- package/src/services/local-function-execution.ts +70 -0
- package/src/services/queues.ts +5 -2
- package/src/services/{function-call-service.ts → remote-function-execution-service.ts} +7 -5
- package/src/services/service-container.ts +7 -7
- package/src/services/service-registry.ts +4 -1
- package/src/services/tracing.ts +4 -2
- package/src/testing/logger.ts +3 -3
- package/src/testing/services.ts +8 -62
- package/dist/lib/browser/chunk-3NGCSUEW.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-FJ2MU7TL.mjs.map +0 -7
- package/dist/types/src/services/function-call-service.d.ts +0 -16
- package/dist/types/src/services/function-call-service.d.ts.map +0 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// src/services/database.ts
|
|
2
2
|
import { Context, Effect, Layer } from "effect";
|
|
3
|
-
var DatabaseService = class _DatabaseService extends Context.Tag("DatabaseService")() {
|
|
3
|
+
var DatabaseService = class _DatabaseService extends Context.Tag("@dxos/functions/DatabaseService")() {
|
|
4
4
|
static {
|
|
5
5
|
this.notAvailable = Layer.succeed(_DatabaseService, {
|
|
6
6
|
get db() {
|
|
@@ -17,6 +17,11 @@ var DatabaseService = class _DatabaseService extends Context.Tag("DatabaseServic
|
|
|
17
17
|
};
|
|
18
18
|
};
|
|
19
19
|
}
|
|
20
|
+
static {
|
|
21
|
+
this.makeLayer = (db) => {
|
|
22
|
+
return Layer.succeed(_DatabaseService, _DatabaseService.make(db));
|
|
23
|
+
};
|
|
24
|
+
}
|
|
20
25
|
static {
|
|
21
26
|
this.resolve = Effect.fn(function* (dxn) {
|
|
22
27
|
const { db } = yield* _DatabaseService;
|
|
@@ -51,7 +56,7 @@ var DatabaseService = class _DatabaseService extends Context.Tag("DatabaseServic
|
|
|
51
56
|
|
|
52
57
|
// src/services/queues.ts
|
|
53
58
|
import { Context as Context2, Layer as Layer2 } from "effect";
|
|
54
|
-
var QueueService = class _QueueService extends Context2.Tag("QueueService")() {
|
|
59
|
+
var QueueService = class _QueueService extends Context2.Tag("@dxos/functions/QueueService")() {
|
|
55
60
|
static {
|
|
56
61
|
this.notAvailable = Layer2.succeed(_QueueService, {
|
|
57
62
|
queues: {
|
|
@@ -73,13 +78,19 @@ var QueueService = class _QueueService extends Context2.Tag("QueueService")() {
|
|
|
73
78
|
};
|
|
74
79
|
};
|
|
75
80
|
}
|
|
81
|
+
static {
|
|
82
|
+
this.makeLayer = (queues, contextQueue) => Layer2.succeed(_QueueService, _QueueService.make(queues, contextQueue));
|
|
83
|
+
}
|
|
76
84
|
};
|
|
77
|
-
var ContextQueueService = class extends Context2.Tag("ContextQueueService")() {
|
|
85
|
+
var ContextQueueService = class extends Context2.Tag("@dxos/functions/ContextQueueService")() {
|
|
78
86
|
};
|
|
79
87
|
|
|
80
88
|
// src/services/credentials.ts
|
|
81
|
-
import { Context as Context3, Effect as Effect2 } from "effect";
|
|
82
|
-
var CredentialsService = class _CredentialsService extends Context3.Tag("CredentialsService")() {
|
|
89
|
+
import { Context as Context3, Effect as Effect2, Layer as Layer3 } from "effect";
|
|
90
|
+
var CredentialsService = class _CredentialsService extends Context3.Tag("@dxos/functions/CredentialsService")() {
|
|
91
|
+
static {
|
|
92
|
+
this.configuredLayer = (credentials) => Layer3.succeed(_CredentialsService, new ConfiguredCredentialsService(credentials));
|
|
93
|
+
}
|
|
83
94
|
static {
|
|
84
95
|
this.getCredential = (query) => Effect2.gen(function* () {
|
|
85
96
|
const credentials = yield* _CredentialsService;
|
|
@@ -107,12 +118,80 @@ var ConfiguredCredentialsService = class {
|
|
|
107
118
|
}
|
|
108
119
|
};
|
|
109
120
|
|
|
121
|
+
// src/services/tracing.ts
|
|
122
|
+
import { Context as Context4, Effect as Effect3, Layer as Layer4 } from "effect";
|
|
123
|
+
import { AgentStatus } from "@dxos/ai";
|
|
124
|
+
import { Obj } from "@dxos/echo";
|
|
125
|
+
var TracingService = class _TracingService extends Context4.Tag("@dxos/functions/TracingService")() {
|
|
126
|
+
static {
|
|
127
|
+
this.noop = {
|
|
128
|
+
write: () => {
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
static {
|
|
133
|
+
this.layerNoop = Layer4.succeed(_TracingService, _TracingService.noop);
|
|
134
|
+
}
|
|
135
|
+
static {
|
|
136
|
+
this.console = {
|
|
137
|
+
write: (event) => {
|
|
138
|
+
console.log(event);
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
static {
|
|
143
|
+
/**
|
|
144
|
+
* Emit the current human-readable execution status.
|
|
145
|
+
*/
|
|
146
|
+
this.emitStatus = Effect3.fnUntraced(function* (data) {
|
|
147
|
+
const tracing = yield* _TracingService;
|
|
148
|
+
tracing.write(Obj.make(AgentStatus, data));
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
};
|
|
152
|
+
|
|
110
153
|
// src/services/event-logger.ts
|
|
111
|
-
import { Effect as
|
|
154
|
+
import { Effect as Effect4, Context as Context5, Schema, Layer as Layer5 } from "effect";
|
|
155
|
+
import { Obj as Obj2, Type } from "@dxos/echo";
|
|
112
156
|
import { invariant } from "@dxos/invariant";
|
|
113
157
|
import { log, LogLevel } from "@dxos/log";
|
|
114
158
|
var __dxlog_file = "/__w/dxos/dxos/packages/core/functions/src/services/event-logger.ts";
|
|
115
|
-
var
|
|
159
|
+
var ComputeEventPayload = Schema.Union(Schema.Struct({
|
|
160
|
+
type: Schema.Literal("begin-compute"),
|
|
161
|
+
nodeId: Schema.String,
|
|
162
|
+
inputs: Schema.Record({
|
|
163
|
+
key: Schema.String,
|
|
164
|
+
value: Schema.Any
|
|
165
|
+
})
|
|
166
|
+
}), Schema.Struct({
|
|
167
|
+
type: Schema.Literal("end-compute"),
|
|
168
|
+
nodeId: Schema.String,
|
|
169
|
+
outputs: Schema.Record({
|
|
170
|
+
key: Schema.String,
|
|
171
|
+
value: Schema.Any
|
|
172
|
+
})
|
|
173
|
+
}), Schema.Struct({
|
|
174
|
+
type: Schema.Literal("compute-input"),
|
|
175
|
+
nodeId: Schema.String,
|
|
176
|
+
property: Schema.String,
|
|
177
|
+
value: Schema.Any
|
|
178
|
+
}), Schema.Struct({
|
|
179
|
+
type: Schema.Literal("compute-output"),
|
|
180
|
+
nodeId: Schema.String,
|
|
181
|
+
property: Schema.String,
|
|
182
|
+
value: Schema.Any
|
|
183
|
+
}), Schema.Struct({
|
|
184
|
+
type: Schema.Literal("custom"),
|
|
185
|
+
nodeId: Schema.String,
|
|
186
|
+
event: Schema.Any
|
|
187
|
+
}));
|
|
188
|
+
var ComputeEvent = Schema.Struct({
|
|
189
|
+
payload: ComputeEventPayload
|
|
190
|
+
}).pipe(Type.Obj({
|
|
191
|
+
typename: "dxos.org/type/ComputeEvent",
|
|
192
|
+
version: "0.1.0"
|
|
193
|
+
}));
|
|
194
|
+
var ComputeEventLogger = class _ComputeEventLogger extends Context5.Tag("@dxos/functions/ComputeEventLogger")() {
|
|
116
195
|
static {
|
|
117
196
|
this.noop = {
|
|
118
197
|
log: () => {
|
|
@@ -120,9 +199,25 @@ var EventLogger = class extends Context4.Tag("EventLogger")() {
|
|
|
120
199
|
nodeId: void 0
|
|
121
200
|
};
|
|
122
201
|
}
|
|
202
|
+
static {
|
|
203
|
+
/**
|
|
204
|
+
* Implements ComputeEventLogger using TracingService.
|
|
205
|
+
*/
|
|
206
|
+
this.layerFromTracing = Layer5.effect(_ComputeEventLogger, Effect4.gen(function* () {
|
|
207
|
+
const tracing = yield* TracingService;
|
|
208
|
+
return {
|
|
209
|
+
log: (event) => {
|
|
210
|
+
tracing.write(Obj2.make(ComputeEvent, {
|
|
211
|
+
payload: event
|
|
212
|
+
}));
|
|
213
|
+
},
|
|
214
|
+
nodeId: void 0
|
|
215
|
+
};
|
|
216
|
+
}));
|
|
217
|
+
}
|
|
123
218
|
};
|
|
124
|
-
var logCustomEvent = (data) =>
|
|
125
|
-
const logger = yield*
|
|
219
|
+
var logCustomEvent = (data) => Effect4.gen(function* () {
|
|
220
|
+
const logger = yield* ComputeEventLogger;
|
|
126
221
|
if (!logger.nodeId) {
|
|
127
222
|
throw new Error("logCustomEvent must be called within a node compute function");
|
|
128
223
|
}
|
|
@@ -132,12 +227,12 @@ var logCustomEvent = (data) => Effect3.gen(function* () {
|
|
|
132
227
|
event: data
|
|
133
228
|
});
|
|
134
229
|
});
|
|
135
|
-
var createDefectLogger = () =>
|
|
230
|
+
var createDefectLogger = () => Effect4.catchAll((error) => Effect4.gen(function* () {
|
|
136
231
|
log.error("unhandled effect error", {
|
|
137
232
|
error
|
|
138
233
|
}, {
|
|
139
234
|
F: __dxlog_file,
|
|
140
|
-
L:
|
|
235
|
+
L: 93,
|
|
141
236
|
S: this,
|
|
142
237
|
C: (f, a) => f(...a)
|
|
143
238
|
});
|
|
@@ -153,7 +248,7 @@ var createEventLogger = (level, message = "event") => {
|
|
|
153
248
|
}[level];
|
|
154
249
|
invariant(logFunction, void 0, {
|
|
155
250
|
F: __dxlog_file,
|
|
156
|
-
L:
|
|
251
|
+
L: 111,
|
|
157
252
|
S: void 0,
|
|
158
253
|
A: [
|
|
159
254
|
"logFunction",
|
|
@@ -168,9 +263,9 @@ var createEventLogger = (level, message = "event") => {
|
|
|
168
263
|
};
|
|
169
264
|
};
|
|
170
265
|
|
|
171
|
-
// src/services/function-
|
|
172
|
-
import { Context as
|
|
173
|
-
var
|
|
266
|
+
// src/services/remote-function-execution-service.ts
|
|
267
|
+
import { Context as Context6, Layer as Layer6 } from "effect";
|
|
268
|
+
var RemoteFunctionExecutionService = class _RemoteFunctionExecutionService extends Context6.Tag("@dxos/functions/RemoteFunctionExecutionService")() {
|
|
174
269
|
static fromClient(baseUrl, spaceId) {
|
|
175
270
|
return {
|
|
176
271
|
callFunction: async (deployedFunctionId, input) => {
|
|
@@ -202,6 +297,9 @@ var FunctionCallService = class extends Context5.Tag("FunctionCallService")() {
|
|
|
202
297
|
};
|
|
203
298
|
};
|
|
204
299
|
}
|
|
300
|
+
static {
|
|
301
|
+
this.mockLayer = Layer6.succeed(_RemoteFunctionExecutionService, _RemoteFunctionExecutionService.mock());
|
|
302
|
+
}
|
|
205
303
|
};
|
|
206
304
|
var getInvocationUrl = (functionUrl, edgeUrl, options = {}) => {
|
|
207
305
|
const baseUrl = new URL("functions/", edgeUrl);
|
|
@@ -216,45 +314,16 @@ var isSecure = (protocol) => {
|
|
|
216
314
|
return protocol === "https:" || protocol === "wss:";
|
|
217
315
|
};
|
|
218
316
|
|
|
219
|
-
// src/services/tracing.ts
|
|
220
|
-
import { Context as Context6, Effect as Effect4 } from "effect";
|
|
221
|
-
import { AgentStatus } from "@dxos/ai";
|
|
222
|
-
import { Obj } from "@dxos/echo";
|
|
223
|
-
var TracingService = class _TracingService extends Context6.Tag("TracingService")() {
|
|
224
|
-
static {
|
|
225
|
-
this.noop = {
|
|
226
|
-
write: () => {
|
|
227
|
-
}
|
|
228
|
-
};
|
|
229
|
-
}
|
|
230
|
-
static {
|
|
231
|
-
this.console = {
|
|
232
|
-
write: (event) => {
|
|
233
|
-
console.log(event);
|
|
234
|
-
}
|
|
235
|
-
};
|
|
236
|
-
}
|
|
237
|
-
static {
|
|
238
|
-
/**
|
|
239
|
-
* Emit the current human-readable execution status.
|
|
240
|
-
*/
|
|
241
|
-
this.emitStatus = Effect4.fnUntraced(function* (data) {
|
|
242
|
-
const tracing = yield* _TracingService;
|
|
243
|
-
tracing.write(Obj.make(AgentStatus, data));
|
|
244
|
-
});
|
|
245
|
-
}
|
|
246
|
-
};
|
|
247
|
-
|
|
248
317
|
// src/services/service-container.ts
|
|
249
|
-
import { Layer as
|
|
318
|
+
import { Layer as Layer7 } from "effect";
|
|
250
319
|
import { AiService } from "@dxos/ai";
|
|
251
320
|
import { entries } from "@dxos/util";
|
|
252
321
|
var SERVICES = {
|
|
253
322
|
ai: AiService,
|
|
254
323
|
credentials: CredentialsService,
|
|
255
324
|
database: DatabaseService,
|
|
256
|
-
eventLogger:
|
|
257
|
-
functionCallService:
|
|
325
|
+
eventLogger: ComputeEventLogger,
|
|
326
|
+
functionCallService: RemoteFunctionExecutionService,
|
|
258
327
|
queues: QueueService,
|
|
259
328
|
tracing: TracingService
|
|
260
329
|
};
|
|
@@ -299,16 +368,76 @@ var ServiceContainer = class _ServiceContainer {
|
|
|
299
368
|
}
|
|
300
369
|
// TODO(dmaretskyi): `getService` is designed to error at runtime if the service is not available, but layer forces us to provide all services and makes stubs for the ones that are not available.
|
|
301
370
|
createLayer() {
|
|
302
|
-
const ai = this._services.ai != null ?
|
|
303
|
-
const credentials =
|
|
304
|
-
const database = this._services.database != null ?
|
|
305
|
-
const queues = this._services.queues != null ?
|
|
306
|
-
const tracing =
|
|
307
|
-
const eventLogger =
|
|
308
|
-
const functionCallService =
|
|
309
|
-
return
|
|
371
|
+
const ai = this._services.ai != null ? Layer7.succeed(AiService, this._services.ai) : AiService.notAvailable;
|
|
372
|
+
const credentials = Layer7.succeed(CredentialsService, this._services.credentials ?? new ConfiguredCredentialsService());
|
|
373
|
+
const database = this._services.database != null ? Layer7.succeed(DatabaseService, this._services.database) : DatabaseService.notAvailable;
|
|
374
|
+
const queues = this._services.queues != null ? Layer7.succeed(QueueService, this._services.queues) : QueueService.notAvailable;
|
|
375
|
+
const tracing = Layer7.succeed(TracingService, this._services.tracing ?? TracingService.noop);
|
|
376
|
+
const eventLogger = Layer7.succeed(ComputeEventLogger, this._services.eventLogger ?? ComputeEventLogger.noop);
|
|
377
|
+
const functionCallService = Layer7.succeed(RemoteFunctionExecutionService, this._services.functionCallService ?? RemoteFunctionExecutionService.mock());
|
|
378
|
+
return Layer7.mergeAll(ai, credentials, database, queues, tracing, eventLogger, functionCallService);
|
|
379
|
+
}
|
|
380
|
+
};
|
|
381
|
+
|
|
382
|
+
// src/errors.ts
|
|
383
|
+
import { BaseError } from "@dxos/errors";
|
|
384
|
+
var ServiceNotAvailableError = class extends BaseError.extend("SERVICE_NOT_AVAILABLE") {
|
|
385
|
+
constructor(serviceName) {
|
|
386
|
+
super(`Service not available: ${serviceName}`);
|
|
387
|
+
}
|
|
388
|
+
};
|
|
389
|
+
var FunctionError = class extends BaseError.extend("FUNCTION_ERROR") {
|
|
390
|
+
};
|
|
391
|
+
|
|
392
|
+
// src/services/local-function-execution.ts
|
|
393
|
+
import { Context as Context7, Effect as Effect5, Layer as Layer8, Schema as Schema2 } from "effect";
|
|
394
|
+
import { todo } from "@dxos/debug";
|
|
395
|
+
var LocalFunctionExecutionService = class _LocalFunctionExecutionService extends Context7.Tag("@dxos/functions/LocalFunctionExecutionService")() {
|
|
396
|
+
static {
|
|
397
|
+
this.layer = Layer8.succeed(_LocalFunctionExecutionService, {
|
|
398
|
+
invokeFunction: (fnDef, input) => invokeFunction(fnDef, input)
|
|
399
|
+
});
|
|
310
400
|
}
|
|
311
401
|
};
|
|
402
|
+
var invokeFunction = (fnDef, input) => Effect5.gen(function* () {
|
|
403
|
+
const assertInput = fnDef.inputSchema.pipe(Schema2.asserts);
|
|
404
|
+
assertInput(input);
|
|
405
|
+
const context = {
|
|
406
|
+
getService: () => todo(),
|
|
407
|
+
getSpace: async (_spaceId) => {
|
|
408
|
+
throw new Error("Not available. Use the database service instead.");
|
|
409
|
+
},
|
|
410
|
+
space: void 0,
|
|
411
|
+
get ai() {
|
|
412
|
+
throw new Error("Not available. Use the ai service instead.");
|
|
413
|
+
}
|
|
414
|
+
};
|
|
415
|
+
const data = yield* Effect5.gen(function* () {
|
|
416
|
+
const result = fnDef.handler({
|
|
417
|
+
context,
|
|
418
|
+
data: input
|
|
419
|
+
});
|
|
420
|
+
if (Effect5.isEffect(result)) {
|
|
421
|
+
return yield* result.pipe(Effect5.orDie);
|
|
422
|
+
} else if (typeof result === "object" && result !== null && "then" in result && typeof result.then === "function") {
|
|
423
|
+
return yield* Effect5.promise(() => result);
|
|
424
|
+
} else {
|
|
425
|
+
return result;
|
|
426
|
+
}
|
|
427
|
+
}).pipe(Effect5.orDie, Effect5.catchAllDefect((defect) => Effect5.die(new FunctionError("Error running function", {
|
|
428
|
+
context: {
|
|
429
|
+
name: fnDef.name
|
|
430
|
+
},
|
|
431
|
+
cause: defect
|
|
432
|
+
}))));
|
|
433
|
+
const assertOutput = fnDef.outputSchema?.pipe(Schema2.asserts);
|
|
434
|
+
assertOutput(data);
|
|
435
|
+
return data;
|
|
436
|
+
}).pipe(Effect5.withSpan("invokeFunction", {
|
|
437
|
+
attributes: {
|
|
438
|
+
name: fnDef.name
|
|
439
|
+
}
|
|
440
|
+
}));
|
|
312
441
|
|
|
313
442
|
export {
|
|
314
443
|
DatabaseService,
|
|
@@ -316,13 +445,18 @@ export {
|
|
|
316
445
|
ContextQueueService,
|
|
317
446
|
CredentialsService,
|
|
318
447
|
ConfiguredCredentialsService,
|
|
319
|
-
|
|
448
|
+
TracingService,
|
|
449
|
+
ComputeEventPayload,
|
|
450
|
+
ComputeEvent,
|
|
451
|
+
ComputeEventLogger,
|
|
320
452
|
logCustomEvent,
|
|
321
453
|
createDefectLogger,
|
|
322
454
|
createEventLogger,
|
|
323
|
-
|
|
324
|
-
TracingService,
|
|
455
|
+
RemoteFunctionExecutionService,
|
|
325
456
|
SERVICE_TAGS,
|
|
326
|
-
ServiceContainer
|
|
457
|
+
ServiceContainer,
|
|
458
|
+
ServiceNotAvailableError,
|
|
459
|
+
FunctionError,
|
|
460
|
+
LocalFunctionExecutionService
|
|
327
461
|
};
|
|
328
|
-
//# sourceMappingURL=chunk-
|
|
462
|
+
//# sourceMappingURL=chunk-6PTFLPCO.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/services/database.ts", "../../../src/services/queues.ts", "../../../src/services/credentials.ts", "../../../src/services/tracing.ts", "../../../src/services/event-logger.ts", "../../../src/services/remote-function-execution-service.ts", "../../../src/services/service-container.ts", "../../../src/errors.ts", "../../../src/services/local-function-execution.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context, Effect, Layer } from 'effect';\n\nimport type { Filter, Live, Obj, Query, Ref, Relation } from '@dxos/echo';\nimport type { EchoDatabase, OneShotQueryResult, QueryResult } from '@dxos/echo-db';\nimport type { DXN } from '@dxos/keys';\n\nexport class DatabaseService extends Context.Tag('@dxos/functions/DatabaseService')<\n DatabaseService,\n {\n readonly db: EchoDatabase;\n }\n>() {\n static notAvailable = Layer.succeed(DatabaseService, {\n get db(): EchoDatabase {\n throw new Error('Database not available');\n },\n });\n\n static make = (db: EchoDatabase): Context.Tag.Service<DatabaseService> => {\n return {\n get db() {\n return db;\n },\n };\n };\n\n static makeLayer = (db: EchoDatabase): Layer.Layer<DatabaseService> => {\n return Layer.succeed(DatabaseService, DatabaseService.make(db));\n };\n\n static resolve: (dxn: DXN) => Effect.Effect<Obj.Any | Relation.Any, Error, DatabaseService> = Effect.fn(\n function* (dxn) {\n const { db } = yield* DatabaseService;\n return yield* Effect.tryPromise({\n try: () =>\n db.graph.createRefResolver({ context: { space: db.spaceId } }).resolve(dxn) as Promise<\n Obj.Any | Relation.Any\n >,\n catch: (error) => error as Error,\n });\n },\n );\n\n static loadRef: <T>(ref: Ref.Ref<T>) => Effect.Effect<T, never, never> = Effect.fn(function* (ref) {\n return yield* Effect.promise(() => ref.load());\n });\n\n /**\n * Creates a `QueryResult` object that can be subscribed to.\n */\n static query: {\n <Q extends Query.Any>(query: Q): Effect.Effect<QueryResult<Live<Query.Type<Q>>>, never, DatabaseService>;\n <F extends Filter.Any>(filter: F): Effect.Effect<QueryResult<Live<Filter.Type<F>>>, never, DatabaseService>;\n } = (queryOrFilter: Query.Any | Filter.Any) =>\n DatabaseService.pipe(\n Effect.map(({ db }) => db.query(queryOrFilter as any)),\n Effect.withSpan('DatabaseService.query'),\n );\n\n /**\n * Executes the query once and returns the results.\n */\n static runQuery: {\n <Q extends Query.Any>(query: Q): Effect.Effect<OneShotQueryResult<Live<Query.Type<Q>>>, never, DatabaseService>;\n <F extends Filter.Any>(filter: F): Effect.Effect<OneShotQueryResult<Live<Filter.Type<F>>>, never, DatabaseService>;\n } = (queryOrFilter: Query.Any | Filter.Any) =>\n DatabaseService.query(queryOrFilter as any).pipe(\n Effect.flatMap((queryResult) => Effect.promise(() => queryResult.run())),\n );\n}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context, Layer } from 'effect';\n\nimport type { Queue, QueueAPI, QueueFactory } from '@dxos/echo-db';\n\n/**\n * Gives access to all queues.\n */\nexport class QueueService extends Context.Tag('@dxos/functions/QueueService')<\n QueueService,\n {\n /**\n * API to access the queues.\n */\n readonly queues: QueueAPI;\n\n /**\n * The queue that is used to store the context of the current research.\n * @deprecated Use `ContextQueueService` instead.\n */\n readonly contextQueue: Queue | undefined;\n }\n>() {\n static notAvailable = Layer.succeed(QueueService, {\n queues: {\n get(dxn) {\n throw new Error('Queues not available');\n },\n create() {\n throw new Error('Queues not available');\n },\n },\n contextQueue: undefined,\n });\n\n static make = (queues: QueueFactory, contextQueue?: Queue): Context.Tag.Service<QueueService> => {\n return {\n queues,\n contextQueue,\n };\n };\n\n static makeLayer = (queues: QueueFactory, contextQueue?: Queue): Layer.Layer<QueueService> =>\n Layer.succeed(QueueService, QueueService.make(queues, contextQueue));\n}\n\n/**\n * Gives access to a specific queue passed as a context.\n */\nexport class ContextQueueService extends Context.Tag('@dxos/functions/ContextQueueService')<\n ContextQueueService,\n {\n readonly contextQueue: Queue;\n }\n>() {}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context, Effect, Layer } from 'effect';\n\ntype CredentialQuery = {\n service?: string;\n};\n\n// TODO(dmaretskyi): Unify with other apis.\n// packages/sdk/schema/src/common/access-token.ts\nexport type ServiceCredential = {\n service: string;\n\n // TODO(dmaretskyi): Build out.\n apiKey?: string;\n};\n\nexport class CredentialsService extends Context.Tag('@dxos/functions/CredentialsService')<\n CredentialsService,\n {\n /**\n * Query all.\n */\n queryCredentials: (query: CredentialQuery) => Promise<ServiceCredential[]>;\n\n /**\n * Get a single credential.\n * @throws {Error} If no credential is found.\n */\n getCredential: (query: CredentialQuery) => Promise<ServiceCredential>;\n }\n>() {\n static configuredLayer = (credentials: ServiceCredential[]) =>\n Layer.succeed(CredentialsService, new ConfiguredCredentialsService(credentials));\n\n static getCredential = (query: CredentialQuery): Effect.Effect<ServiceCredential, never, CredentialsService> =>\n Effect.gen(function* () {\n const credentials = yield* CredentialsService;\n return yield* Effect.promise(() => credentials.getCredential(query));\n });\n}\n\nexport class ConfiguredCredentialsService implements Context.Tag.Service<CredentialsService> {\n constructor(private readonly credentials: ServiceCredential[] = []) {}\n\n addCredentials(credentials: ServiceCredential[]): ConfiguredCredentialsService {\n this.credentials.push(...credentials);\n return this;\n }\n\n async queryCredentials(query: CredentialQuery): Promise<ServiceCredential[]> {\n return this.credentials.filter((credential) => credential.service === query.service);\n }\n\n async getCredential(query: CredentialQuery): Promise<ServiceCredential> {\n const credential = this.credentials.find((credential) => credential.service === query.service);\n if (!credential) {\n throw new Error(`Credential not found for service: ${query.service}`);\n }\n return credential;\n }\n}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context, Effect, Layer } from 'effect';\n\nimport { AgentStatus } from '@dxos/ai';\nimport { Obj } from '@dxos/echo';\nimport type { AnyEchoObject } from '@dxos/echo-schema';\n\n/**\n * Provides a way for compute primitives (functions, workflows, tools)\n * to emit an execution trace as a series of structured ECHO objects.\n */\nexport class TracingService extends Context.Tag('@dxos/functions/TracingService')<\n TracingService,\n {\n /**\n * Write an event to the tracing queue.\n * @param event - The event to write. Must be an a typed object.\n */\n write(event: AnyEchoObject): void;\n }\n>() {\n static noop: Context.Tag.Service<TracingService> = { write: () => {} };\n\n static layerNoop = Layer.succeed(TracingService, TracingService.noop);\n\n static console: Context.Tag.Service<TracingService> = {\n write: (event) => {\n // eslint-disable-next-line no-console\n console.log(event);\n },\n };\n\n /**\n * Emit the current human-readable execution status.\n */\n static emitStatus: (data: Obj.MakeProps<typeof AgentStatus>) => Effect.Effect<unknown, never, void> =\n Effect.fnUntraced(function* (data) {\n const tracing = yield* TracingService;\n tracing.write(Obj.make(AgentStatus, data));\n });\n}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Effect, Context, Schema, Layer } from 'effect';\n\nimport { Obj, Type } from '@dxos/echo';\nimport { invariant } from '@dxos/invariant';\nimport { log, LogLevel } from '@dxos/log';\n\nimport { TracingService } from './tracing';\n\nexport const ComputeEventPayload = Schema.Union(\n Schema.Struct({\n type: Schema.Literal('begin-compute'),\n nodeId: Schema.String,\n inputs: Schema.Record({ key: Schema.String, value: Schema.Any }),\n }),\n Schema.Struct({\n type: Schema.Literal('end-compute'),\n nodeId: Schema.String,\n outputs: Schema.Record({ key: Schema.String, value: Schema.Any }),\n }),\n Schema.Struct({\n type: Schema.Literal('compute-input'),\n nodeId: Schema.String,\n property: Schema.String,\n value: Schema.Any,\n }),\n Schema.Struct({\n type: Schema.Literal('compute-output'),\n nodeId: Schema.String,\n property: Schema.String,\n value: Schema.Any,\n }),\n Schema.Struct({\n type: Schema.Literal('custom'),\n nodeId: Schema.String,\n event: Schema.Any,\n }),\n);\nexport type ComputeEventPayload = Schema.Schema.Type<typeof ComputeEventPayload>;\n\nexport const ComputeEvent = Schema.Struct({\n payload: ComputeEventPayload,\n}).pipe(Type.Obj({ typename: 'dxos.org/type/ComputeEvent', version: '0.1.0' }));\n\n/**\n * Logs event for the compute workflows.\n */\nexport class ComputeEventLogger extends Context.Tag('@dxos/functions/ComputeEventLogger')<\n ComputeEventLogger,\n { readonly log: (event: ComputeEventPayload) => void; readonly nodeId: string | undefined }\n>() {\n static noop: Context.Tag.Service<ComputeEventLogger> = {\n log: () => {},\n nodeId: undefined,\n };\n\n /**\n * Implements ComputeEventLogger using TracingService.\n */\n static layerFromTracing = Layer.effect(\n ComputeEventLogger,\n Effect.gen(function* () {\n const tracing = yield* TracingService;\n return {\n log: (event: ComputeEventPayload) => {\n tracing.write(Obj.make(ComputeEvent, { payload: event }));\n },\n nodeId: undefined,\n };\n }),\n );\n}\n\nexport const logCustomEvent = (data: any) =>\n Effect.gen(function* () {\n const logger = yield* ComputeEventLogger;\n if (!logger.nodeId) {\n throw new Error('logCustomEvent must be called within a node compute function');\n }\n logger.log({\n type: 'custom',\n nodeId: logger.nodeId,\n event: data,\n });\n });\n\nexport const createDefectLogger = <A, E, R>(): ((self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>) =>\n Effect.catchAll((error) =>\n Effect.gen(function* () {\n log.error('unhandled effect error', { error });\n throw error;\n }),\n );\n\nexport const createEventLogger = (\n level: LogLevel,\n message: string = 'event',\n): Context.Tag.Service<ComputeEventLogger> => {\n const logFunction = (\n {\n [LogLevel.WARN]: log.warn,\n [LogLevel.VERBOSE]: log.verbose,\n [LogLevel.DEBUG]: log.debug,\n [LogLevel.INFO]: log.info,\n [LogLevel.ERROR]: log.error,\n } as any\n )[level];\n invariant(logFunction);\n return {\n log: (event: ComputeEventPayload) => {\n logFunction(message, event);\n },\n nodeId: undefined,\n };\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context, Layer } from 'effect';\n\nimport type { SpaceId } from '@dxos/keys';\n\n/**\n * Allows calling into other functions.\n */\nexport class RemoteFunctionExecutionService extends Context.Tag('@dxos/functions/RemoteFunctionExecutionService')<\n RemoteFunctionExecutionService,\n {\n callFunction(deployedFunctionId: string, input: any, spaceId?: SpaceId): Promise<any>;\n }\n>() {\n static fromClient(baseUrl: string, spaceId: SpaceId): Context.Tag.Service<RemoteFunctionExecutionService> {\n return {\n callFunction: async (deployedFunctionId: string, input: any) => {\n const url = getInvocationUrl(deployedFunctionId, baseUrl, { spaceId });\n const result = await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(input),\n });\n if (result.status >= 300 || result.status < 200) {\n throw new Error('Failed to invoke function', { cause: new Error(`HTTP error: ${await result.text()}`) });\n }\n return await result.json();\n },\n };\n }\n\n static mock = (): Context.Tag.Service<RemoteFunctionExecutionService> => {\n return {\n callFunction: async (deployedFunctionId: string, input: any) => {\n return input;\n },\n };\n };\n\n static mockLayer = Layer.succeed(RemoteFunctionExecutionService, RemoteFunctionExecutionService.mock());\n}\n\n// TODO(dmaretskyi): Reconcile with `getInvocationUrl` in `@dxos/functions/edge`.\nconst getInvocationUrl = (functionUrl: string, edgeUrl: string, options: InvocationOptions = {}) => {\n const baseUrl = new URL('functions/', edgeUrl);\n\n // Leading slashes cause the URL to be treated as an absolute path.\n const relativeUrl = functionUrl.replace(/^\\//, '');\n const url = new URL(`./${relativeUrl}`, baseUrl.toString());\n options.spaceId && url.searchParams.set('spaceId', options.spaceId);\n options.subjectId && url.searchParams.set('subjectId', options.subjectId);\n url.protocol = isSecure(url.protocol) ? 'https' : 'http';\n return url.toString();\n};\n\nconst isSecure = (protocol: string) => {\n return protocol === 'https:' || protocol === 'wss:';\n};\n\ntype InvocationOptions = {\n spaceId?: SpaceId;\n subjectId?: string;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Context, Layer } from 'effect';\n\nimport { AiService } from '@dxos/ai';\nimport { entries } from '@dxos/util';\n\nimport { ConfiguredCredentialsService, CredentialsService } from './credentials';\nimport { DatabaseService } from './database';\nimport { ComputeEventLogger } from './event-logger';\nimport { QueueService } from './queues';\nimport { RemoteFunctionExecutionService } from './remote-function-execution-service';\nimport { TracingService } from './tracing';\n\n// TODO(dmaretskyi): Refactor this module to only rely on tags and not the human-assigned names.\n\n/**\n * List of all services.\n */\nconst SERVICES = {\n ai: AiService,\n credentials: CredentialsService,\n database: DatabaseService,\n eventLogger: ComputeEventLogger,\n functionCallService: RemoteFunctionExecutionService,\n queues: QueueService,\n tracing: TracingService,\n} as const satisfies Record<string, Context.TagClass<any, string, any>>;\n\n/**\n * Mapping of service names to their tags.\n */\nexport type ServiceTagRecord = {\n [K in keyof typeof SERVICES]: (typeof SERVICES)[K] extends { new (_: never): infer T } ? T : never;\n};\n\n/**\n * Mapping of service names to their runtime types.\n */\nexport type ServiceRecord = {\n [K in keyof ServiceTagRecord]: Context.Tag.Service<ServiceTagRecord[K]>;\n};\n\n/**\n * Union of all services tags.\n */\nexport type Services = ServiceTagRecord[keyof ServiceTagRecord];\n\nconst SERVICE_MAPPING: Record<string, keyof ServiceRecord> = Object.fromEntries(\n entries(SERVICES).map(([name, tag]) => [tag.key, name]),\n);\n\nexport const SERVICE_TAGS: Context.Tag<any, any>[] = Object.values(SERVICES);\n\nconst DEFAULT_SERVICES: Partial<ServiceRecord> = {\n tracing: TracingService.noop,\n};\n\n/**\n * @deprecated\n */\nexport class ServiceContainer {\n private _services: Partial<ServiceRecord> = { ...DEFAULT_SERVICES };\n\n /**\n * Set services.\n * @param services - Services to set.\n * @returns The container instance.\n */\n setServices(services: Partial<ServiceRecord>): this {\n this._services = { ...this._services, ...services };\n return this;\n }\n\n getService<Id, T>(tag: Context.Tag<Id, T>): T {\n const serviceKey = SERVICE_MAPPING[tag.key];\n const service = serviceKey != null ? this._services[serviceKey] : undefined;\n if (!service) {\n throw new Error(`Service not available: ${tag.key}`);\n }\n\n return service as T;\n }\n\n clone(): ServiceContainer {\n return new ServiceContainer().setServices({ ...this._services });\n }\n\n // TODO(dmaretskyi): `getService` is designed to error at runtime if the service is not available, but layer forces us to provide all services and makes stubs for the ones that are not available.\n createLayer(): Layer.Layer<Services> {\n const ai = this._services.ai != null ? Layer.succeed(AiService, this._services.ai) : AiService.notAvailable;\n const credentials = Layer.succeed(\n CredentialsService,\n this._services.credentials ?? new ConfiguredCredentialsService(),\n );\n const database =\n this._services.database != null\n ? Layer.succeed(DatabaseService, this._services.database)\n : DatabaseService.notAvailable;\n const queues =\n this._services.queues != null ? Layer.succeed(QueueService, this._services.queues) : QueueService.notAvailable;\n const tracing = Layer.succeed(TracingService, this._services.tracing ?? TracingService.noop);\n const eventLogger = Layer.succeed(ComputeEventLogger, this._services.eventLogger ?? ComputeEventLogger.noop);\n const functionCallService = Layer.succeed(\n RemoteFunctionExecutionService,\n this._services.functionCallService ?? RemoteFunctionExecutionService.mock(),\n );\n\n return Layer.mergeAll(ai, credentials, database, queues, tracing, eventLogger, functionCallService);\n }\n}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { BaseError } from '@dxos/errors';\n\nexport class ServiceNotAvailableError extends BaseError.extend('SERVICE_NOT_AVAILABLE') {\n constructor(serviceName: string) {\n super(`Service not available: ${serviceName}`);\n }\n}\n\nexport class FunctionError extends BaseError.extend('FUNCTION_ERROR') {}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context, Effect, Layer, Schema } from 'effect';\n\nimport { todo } from '@dxos/debug';\n\nimport type { FunctionContext, FunctionDefinition } from '../handler';\nimport type { Services } from './service-container';\nimport { FunctionError } from '../errors';\n\nexport class LocalFunctionExecutionService extends Context.Tag('@dxos/functions/LocalFunctionExecutionService')<\n LocalFunctionExecutionService,\n {\n // TODO(dmaretskyi): This should take function id instead of the definition object.\n // TODO(dmaretskyi): Services should be satisfied from environment rather then bubbled up.\n invokeFunction(fnDef: FunctionDefinition<any, any>, input: unknown): Effect.Effect<unknown, never, Services>;\n }\n>() {\n static layer = Layer.succeed(LocalFunctionExecutionService, {\n invokeFunction: (fnDef, input) => invokeFunction(fnDef, input),\n });\n}\n\nconst invokeFunction = (fnDef: FunctionDefinition<any, any>, input: any): Effect.Effect<unknown, never, Services> =>\n Effect.gen(function* () {\n // Assert input matches schema\n const assertInput = fnDef.inputSchema.pipe(Schema.asserts);\n (assertInput as any)(input);\n\n const context: FunctionContext = {\n getService: () => todo(),\n getSpace: async (_spaceId: any) => {\n throw new Error('Not available. Use the database service instead.');\n },\n space: undefined,\n get ai(): never {\n throw new Error('Not available. Use the ai service instead.');\n },\n };\n\n // TODO(dmaretskyi): This should be delegated to a function invoker service.\n const data = yield* Effect.gen(function* () {\n const result = fnDef.handler({ context, data: input });\n if (Effect.isEffect(result)) {\n return yield* (result as Effect.Effect<unknown, unknown, Services>).pipe(Effect.orDie);\n } else if (\n typeof result === 'object' &&\n result !== null &&\n 'then' in result &&\n typeof result.then === 'function'\n ) {\n return yield* Effect.promise(() => result);\n } else {\n return result;\n }\n }).pipe(\n Effect.orDie,\n Effect.catchAllDefect((defect) =>\n Effect.die(new FunctionError('Error running function', { context: { name: fnDef.name }, cause: defect })),\n ),\n );\n\n // Assert output matches schema\n const assertOutput = fnDef.outputSchema?.pipe(Schema.asserts);\n (assertOutput as any)(data);\n\n return data;\n }).pipe(Effect.withSpan('invokeFunction', { attributes: { name: fnDef.name } }));\n"],
|
|
5
|
+
"mappings": ";AAIA,SAASA,SAASC,QAAQC,aAAa;AAMhC,IAAMC,kBAAN,MAAMA,yBAAwBC,QAAQC,IAAI,iCAAA,EAAA,EAAA;EAM/C;SAAOC,eAAeC,MAAMC,QAAQL,kBAAiB;MACnD,IAAIM,KAAmB;AACrB,cAAM,IAAIC,MAAM,wBAAA;MAClB;IACF,CAAA;;EAEA;SAAOC,OAAO,CAACF,OAAAA;AACb,aAAO;QACL,IAAIA,KAAK;AACP,iBAAOA;QACT;MACF;IACF;;EAEA;SAAOG,YAAY,CAACH,OAAAA;AAClB,aAAOF,MAAMC,QAAQL,kBAAiBA,iBAAgBQ,KAAKF,EAAAA,CAAAA;IAC7D;;EAEA;SAAOI,UAAuFC,OAAOC,GACnG,WAAWC,KAAG;AACZ,YAAM,EAAEP,GAAE,IAAK,OAAON;AACtB,aAAO,OAAOW,OAAOG,WAAW;QAC9BC,KAAK,MACHT,GAAGU,MAAMC,kBAAkB;UAAEC,SAAS;YAAEC,OAAOb,GAAGc;UAAQ;QAAE,CAAA,EAAGV,QAAQG,GAAAA;QAGzEQ,OAAO,CAACC,UAAUA;MACpB,CAAA;IACF,CAAA;;EAGF;SAAOC,UAAkEZ,OAAOC,GAAG,WAAWY,KAAG;AAC/F,aAAO,OAAOb,OAAOc,QAAQ,MAAMD,IAAIE,KAAI,CAAA;IAC7C,CAAA;;EAKA;;;;SAAOC,QAGH,CAACC,kBACH5B,iBAAgB6B,KACdlB,OAAOmB,IAAI,CAAC,EAAExB,GAAE,MAAOA,GAAGqB,MAAMC,aAAAA,CAAAA,GAChCjB,OAAOoB,SAAS,uBAAA,CAAA;;EAMpB;;;;SAAOC,WAGH,CAACJ,kBACH5B,iBAAgB2B,MAAMC,aAAAA,EAAsBC,KAC1ClB,OAAOsB,QAAQ,CAACC,gBAAgBvB,OAAOc,QAAQ,MAAMS,YAAYC,IAAG,CAAA,CAAA,CAAA;;AAE1E;;;ACrEA,SAASC,WAAAA,UAASC,SAAAA,cAAa;AAOxB,IAAMC,eAAN,MAAMA,sBAAqBC,SAAQC,IAAI,8BAAA,EAAA,EAAA;EAe5C;SAAOC,eAAeC,OAAMC,QAAQL,eAAc;MAChDM,QAAQ;QACNC,IAAIC,KAAG;AACL,gBAAM,IAAIC,MAAM,sBAAA;QAClB;QACAC,SAAAA;AACE,gBAAM,IAAID,MAAM,sBAAA;QAClB;MACF;MACAE,cAAcC;IAChB,CAAA;;EAEA;SAAOC,OAAO,CAACP,QAAsBK,iBAAAA;AACnC,aAAO;QACLL;QACAK;MACF;IACF;;EAEA;SAAOG,YAAY,CAACR,QAAsBK,iBACxCP,OAAMC,QAAQL,eAAcA,cAAaa,KAAKP,QAAQK,YAAAA,CAAAA;;AAC1D;AAKO,IAAMI,sBAAN,cAAkCd,SAAQC,IAAI,qCAAA,EAAA,EAAA;AAKhD;;;ACrDL,SAASc,WAAAA,UAASC,UAAAA,SAAQC,SAAAA,cAAa;AAehC,IAAMC,qBAAN,MAAMA,4BAA2BC,SAAQC,IAAI,oCAAA,EAAA,EAAA;EAelD;SAAOC,kBAAkB,CAACC,gBACxBC,OAAMC,QAAQN,qBAAoB,IAAIO,6BAA6BH,WAAAA,CAAAA;;EAErE;SAAOI,gBAAgB,CAACC,UACtBC,QAAOC,IAAI,aAAA;AACT,YAAMP,cAAc,OAAOJ;AAC3B,aAAO,OAAOU,QAAOE,QAAQ,MAAMR,YAAYI,cAAcC,KAAAA,CAAAA;IAC/D,CAAA;;AACJ;AAEO,IAAMF,+BAAN,MAAMA;EACX,YAA6BH,cAAmC,CAAA,GAAI;SAAvCA,cAAAA;EAAwC;EAErES,eAAeT,aAAgE;AAC7E,SAAKA,YAAYU,KAAI,GAAIV,WAAAA;AACzB,WAAO;EACT;EAEA,MAAMW,iBAAiBN,OAAsD;AAC3E,WAAO,KAAKL,YAAYY,OAAO,CAACC,eAAeA,WAAWC,YAAYT,MAAMS,OAAO;EACrF;EAEA,MAAMV,cAAcC,OAAoD;AACtE,UAAMQ,aAAa,KAAKb,YAAYe,KAAK,CAACF,gBAAeA,YAAWC,YAAYT,MAAMS,OAAO;AAC7F,QAAI,CAACD,YAAY;AACf,YAAM,IAAIG,MAAM,qCAAqCX,MAAMS,OAAO,EAAE;IACtE;AACA,WAAOD;EACT;AACF;;;AC3DA,SAASI,WAAAA,UAASC,UAAAA,SAAQC,SAAAA,cAAa;AAEvC,SAASC,mBAAmB;AAC5B,SAASC,WAAW;AAOb,IAAMC,iBAAN,MAAMA,wBAAuBC,SAAQC,IAAI,gCAAA,EAAA,EAAA;EAU9C;SAAOC,OAA4C;MAAEC,OAAO,MAAA;MAAO;IAAE;;EAErE;SAAOC,YAAYC,OAAMC,QAAQP,iBAAgBA,gBAAeG,IAAI;;EAEpE;SAAOK,UAA+C;MACpDJ,OAAO,CAACK,UAAAA;AAEND,gBAAQE,IAAID,KAAAA;MACd;IACF;;EAKA;;;;SAAOE,aACLC,QAAOC,WAAW,WAAWC,MAAI;AAC/B,YAAMC,UAAU,OAAOf;AACvBe,cAAQX,MAAMY,IAAIC,KAAKC,aAAaJ,IAAAA,CAAAA;IACtC,CAAA;;AACJ;;;ACvCA,SAASK,UAAAA,SAAQC,WAAAA,UAASC,QAAQC,SAAAA,cAAa;AAE/C,SAASC,OAAAA,MAAKC,YAAY;AAC1B,SAASC,iBAAiB;AAC1B,SAASC,KAAKC,gBAAgB;;AAIvB,IAAMC,sBAAsBC,OAAOC,MACxCD,OAAOE,OAAO;EACZC,MAAMH,OAAOI,QAAQ,eAAA;EACrBC,QAAQL,OAAOM;EACfC,QAAQP,OAAOQ,OAAO;IAAEC,KAAKT,OAAOM;IAAQI,OAAOV,OAAOW;EAAI,CAAA;AAChE,CAAA,GACAX,OAAOE,OAAO;EACZC,MAAMH,OAAOI,QAAQ,aAAA;EACrBC,QAAQL,OAAOM;EACfM,SAASZ,OAAOQ,OAAO;IAAEC,KAAKT,OAAOM;IAAQI,OAAOV,OAAOW;EAAI,CAAA;AACjE,CAAA,GACAX,OAAOE,OAAO;EACZC,MAAMH,OAAOI,QAAQ,eAAA;EACrBC,QAAQL,OAAOM;EACfO,UAAUb,OAAOM;EACjBI,OAAOV,OAAOW;AAChB,CAAA,GACAX,OAAOE,OAAO;EACZC,MAAMH,OAAOI,QAAQ,gBAAA;EACrBC,QAAQL,OAAOM;EACfO,UAAUb,OAAOM;EACjBI,OAAOV,OAAOW;AAChB,CAAA,GACAX,OAAOE,OAAO;EACZC,MAAMH,OAAOI,QAAQ,QAAA;EACrBC,QAAQL,OAAOM;EACfQ,OAAOd,OAAOW;AAChB,CAAA,CAAA;AAIK,IAAMI,eAAef,OAAOE,OAAO;EACxCc,SAASjB;AACX,CAAA,EAAGkB,KAAKC,KAAKC,IAAI;EAAEC,UAAU;EAA8BC,SAAS;AAAQ,CAAA,CAAA;AAKrE,IAAMC,qBAAN,MAAMA,4BAA2BC,SAAQC,IAAI,oCAAA,EAAA,EAAA;EAIlD;SAAOC,OAAgD;MACrDC,KAAK,MAAA;MAAO;MACZrB,QAAQsB;IACV;;EAKA;;;;SAAOC,mBAAmBC,OAAMC,OAC9BR,qBACAS,QAAOC,IAAI,aAAA;AACT,YAAMC,UAAU,OAAOC;AACvB,aAAO;QACLR,KAAK,CAACZ,UAAAA;AACJmB,kBAAQE,MAAMhB,KAAIiB,KAAKrB,cAAc;YAAEC,SAASF;UAAM,CAAA,CAAA;QACxD;QACAT,QAAQsB;MACV;IACF,CAAA,CAAA;;AAEJ;AAEO,IAAMU,iBAAiB,CAACC,SAC7BP,QAAOC,IAAI,aAAA;AACT,QAAMO,SAAS,OAAOjB;AACtB,MAAI,CAACiB,OAAOlC,QAAQ;AAClB,UAAM,IAAImC,MAAM,8DAAA;EAClB;AACAD,SAAOb,IAAI;IACTvB,MAAM;IACNE,QAAQkC,OAAOlC;IACfS,OAAOwB;EACT,CAAA;AACF,CAAA;AAEK,IAAMG,qBAAqB,MAChCV,QAAOW,SAAS,CAACC,UACfZ,QAAOC,IAAI,aAAA;AACTN,MAAIiB,MAAM,0BAA0B;IAAEA;EAAM,GAAA;;;;;;AAC5C,QAAMA;AACR,CAAA,CAAA;AAGG,IAAMC,oBAAoB,CAC/BC,OACAC,UAAkB,YAAO;AAEzB,QAAMC,cACJ;IACE,CAACC,SAASC,IAAI,GAAGvB,IAAIwB;IACrB,CAACF,SAASG,OAAO,GAAGzB,IAAI0B;IACxB,CAACJ,SAASK,KAAK,GAAG3B,IAAI4B;IACtB,CAACN,SAASO,IAAI,GAAG7B,IAAI8B;IACrB,CAACR,SAASS,KAAK,GAAG/B,IAAIiB;EACxB,EACAE,KAAAA;AACFa,YAAUX,aAAAA,QAAAA;;;;;;;;;AACV,SAAO;IACLrB,KAAK,CAACZ,UAAAA;AACJiC,kBAAYD,SAAShC,KAAAA;IACvB;IACAT,QAAQsB;EACV;AACF;;;ACjHA,SAASgC,WAAAA,UAASC,SAAAA,cAAa;AAOxB,IAAMC,iCAAN,MAAMA,wCAAuCC,SAAQC,IAAI,gDAAA,EAAA,EAAA;EAM9D,OAAOC,WAAWC,SAAiBC,SAAuE;AACxG,WAAO;MACLC,cAAc,OAAOC,oBAA4BC,UAAAA;AAC/C,cAAMC,MAAMC,iBAAiBH,oBAAoBH,SAAS;UAAEC;QAAQ,CAAA;AACpE,cAAMM,SAAS,MAAMC,MAAMH,KAAK;UAC9BI,QAAQ;UACRC,SAAS;YAAE,gBAAgB;UAAmB;UAC9CC,MAAMC,KAAKC,UAAUT,KAAAA;QACvB,CAAA;AACA,YAAIG,OAAOO,UAAU,OAAOP,OAAOO,SAAS,KAAK;AAC/C,gBAAM,IAAIC,MAAM,6BAA6B;YAAEC,OAAO,IAAID,MAAM,eAAe,MAAMR,OAAOU,KAAI,CAAA,EAAI;UAAE,CAAA;QACxG;AACA,eAAO,MAAMV,OAAOW,KAAI;MAC1B;IACF;EACF;EAEA;SAAOC,OAAO,MAAA;AACZ,aAAO;QACLjB,cAAc,OAAOC,oBAA4BC,UAAAA;AAC/C,iBAAOA;QACT;MACF;IACF;;EAEA;SAAOgB,YAAYC,OAAMC,QAAQ1B,iCAAgCA,gCAA+BuB,KAAI,CAAA;;AACtG;AAGA,IAAMb,mBAAmB,CAACiB,aAAqBC,SAAiBC,UAA6B,CAAC,MAAC;AAC7F,QAAMzB,UAAU,IAAI0B,IAAI,cAAcF,OAAAA;AAGtC,QAAMG,cAAcJ,YAAYK,QAAQ,OAAO,EAAA;AAC/C,QAAMvB,MAAM,IAAIqB,IAAI,KAAKC,WAAAA,IAAe3B,QAAQ6B,SAAQ,CAAA;AACxDJ,UAAQxB,WAAWI,IAAIyB,aAAaC,IAAI,WAAWN,QAAQxB,OAAO;AAClEwB,UAAQO,aAAa3B,IAAIyB,aAAaC,IAAI,aAAaN,QAAQO,SAAS;AACxE3B,MAAI4B,WAAWC,SAAS7B,IAAI4B,QAAQ,IAAI,UAAU;AAClD,SAAO5B,IAAIwB,SAAQ;AACrB;AAEA,IAAMK,WAAW,CAACD,aAAAA;AAChB,SAAOA,aAAa,YAAYA,aAAa;AAC/C;;;ACxDA,SAAuBE,SAAAA,cAAa;AAEpC,SAASC,iBAAiB;AAC1B,SAASC,eAAe;AAcxB,IAAMC,WAAW;EACfC,IAAIC;EACJC,aAAaC;EACbC,UAAUC;EACVC,aAAaC;EACbC,qBAAqBC;EACrBC,QAAQC;EACRC,SAASC;AACX;AAqBA,IAAMC,kBAAuDC,OAAOC,YAClEC,QAAQlB,QAAAA,EAAUmB,IAAI,CAAC,CAACC,MAAMC,GAAAA,MAAS;EAACA,IAAIC;EAAKF;CAAK,CAAA;AAGjD,IAAMG,eAAwCP,OAAOQ,OAAOxB,QAAAA;AAEnE,IAAMyB,mBAA2C;EAC/CZ,SAASC,eAAeY;AAC1B;AAKO,IAAMC,mBAAN,MAAMA,kBAAAA;EAAN;AACGC,qBAAoC;MAAE,GAAGH;IAAiB;;;;;;;EAOlEI,YAAYC,UAAwC;AAClD,SAAKF,YAAY;MAAE,GAAG,KAAKA;MAAW,GAAGE;IAAS;AAClD,WAAO;EACT;EAEAC,WAAkBV,KAA4B;AAC5C,UAAMW,aAAajB,gBAAgBM,IAAIC,GAAG;AAC1C,UAAMW,UAAUD,cAAc,OAAO,KAAKJ,UAAUI,UAAAA,IAAcE;AAClE,QAAI,CAACD,SAAS;AACZ,YAAM,IAAIE,MAAM,0BAA0Bd,IAAIC,GAAG,EAAE;IACrD;AAEA,WAAOW;EACT;EAEAG,QAA0B;AACxB,WAAO,IAAIT,kBAAAA,EAAmBE,YAAY;MAAE,GAAG,KAAKD;IAAU,CAAA;EAChE;;EAGAS,cAAqC;AACnC,UAAMpC,KAAK,KAAK2B,UAAU3B,MAAM,OAAOqC,OAAMC,QAAQrC,WAAW,KAAK0B,UAAU3B,EAAE,IAAIC,UAAUsC;AAC/F,UAAMrC,cAAcmC,OAAMC,QACxBnC,oBACA,KAAKwB,UAAUzB,eAAe,IAAIsC,6BAAAA,CAAAA;AAEpC,UAAMpC,WACJ,KAAKuB,UAAUvB,YAAY,OACvBiC,OAAMC,QAAQjC,iBAAiB,KAAKsB,UAAUvB,QAAQ,IACtDC,gBAAgBkC;AACtB,UAAM7B,SACJ,KAAKiB,UAAUjB,UAAU,OAAO2B,OAAMC,QAAQ3B,cAAc,KAAKgB,UAAUjB,MAAM,IAAIC,aAAa4B;AACpG,UAAM3B,UAAUyB,OAAMC,QAAQzB,gBAAgB,KAAKc,UAAUf,WAAWC,eAAeY,IAAI;AAC3F,UAAMnB,cAAc+B,OAAMC,QAAQ/B,oBAAoB,KAAKoB,UAAUrB,eAAeC,mBAAmBkB,IAAI;AAC3G,UAAMjB,sBAAsB6B,OAAMC,QAChC7B,gCACA,KAAKkB,UAAUnB,uBAAuBC,+BAA+BgC,KAAI,CAAA;AAG3E,WAAOJ,OAAMK,SAAS1C,IAAIE,aAAaE,UAAUM,QAAQE,SAASN,aAAaE,mBAAAA;EACjF;AACF;;;AC5GA,SAASmC,iBAAiB;AAEnB,IAAMC,2BAAN,cAAuCC,UAAUC,OAAO,uBAAA,EAAA;EAC7D,YAAYC,aAAqB;AAC/B,UAAM,0BAA0BA,WAAAA,EAAa;EAC/C;AACF;AAEO,IAAMC,gBAAN,cAA4BH,UAAUC,OAAO,gBAAA,EAAA;AAAmB;;;ACRvE,SAASG,WAAAA,UAASC,UAAAA,SAAQC,SAAAA,QAAOC,UAAAA,eAAc;AAE/C,SAASC,YAAY;AAMd,IAAMC,gCAAN,MAAMA,uCAAsCC,SAAQC,IAAI,+CAAA,EAAA,EAAA;EAQ7D;SAAOC,QAAQC,OAAMC,QAAQL,gCAA+B;MAC1DM,gBAAgB,CAACC,OAAOC,UAAUF,eAAeC,OAAOC,KAAAA;IAC1D,CAAA;;AACF;AAEA,IAAMF,iBAAiB,CAACC,OAAqCC,UAC3DC,QAAOC,IAAI,aAAA;AAET,QAAMC,cAAcJ,MAAMK,YAAYC,KAAKC,QAAOC,OAAO;AACxDJ,cAAoBH,KAAAA;AAErB,QAAMQ,UAA2B;IAC/BC,YAAY,MAAMC,KAAAA;IAClBC,UAAU,OAAOC,aAAAA;AACf,YAAM,IAAIC,MAAM,kDAAA;IAClB;IACAC,OAAOC;IACP,IAAIC,KAAY;AACd,YAAM,IAAIH,MAAM,4CAAA;IAClB;EACF;AAGA,QAAMI,OAAO,OAAOhB,QAAOC,IAAI,aAAA;AAC7B,UAAMgB,SAASnB,MAAMoB,QAAQ;MAAEX;MAASS,MAAMjB;IAAM,CAAA;AACpD,QAAIC,QAAOmB,SAASF,MAAAA,GAAS;AAC3B,aAAO,OAAQA,OAAqDb,KAAKJ,QAAOoB,KAAK;IACvF,WACE,OAAOH,WAAW,YAClBA,WAAW,QACX,UAAUA,UACV,OAAOA,OAAOI,SAAS,YACvB;AACA,aAAO,OAAOrB,QAAOsB,QAAQ,MAAML,MAAAA;IACrC,OAAO;AACL,aAAOA;IACT;EACF,CAAA,EAAGb,KACDJ,QAAOoB,OACPpB,QAAOuB,eAAe,CAACC,WACrBxB,QAAOyB,IAAI,IAAIC,cAAc,0BAA0B;IAAEnB,SAAS;MAAEoB,MAAM7B,MAAM6B;IAAK;IAAGC,OAAOJ;EAAO,CAAA,CAAA,CAAA,CAAA;AAK1G,QAAMK,eAAe/B,MAAMgC,cAAc1B,KAAKC,QAAOC,OAAO;AAC3DuB,eAAqBb,IAAAA;AAEtB,SAAOA;AACT,CAAA,EAAGZ,KAAKJ,QAAO+B,SAAS,kBAAkB;EAAEC,YAAY;IAAEL,MAAM7B,MAAM6B;EAAK;AAAE,CAAA,CAAA;",
|
|
6
|
+
"names": ["Context", "Effect", "Layer", "DatabaseService", "Context", "Tag", "notAvailable", "Layer", "succeed", "db", "Error", "make", "makeLayer", "resolve", "Effect", "fn", "dxn", "tryPromise", "try", "graph", "createRefResolver", "context", "space", "spaceId", "catch", "error", "loadRef", "ref", "promise", "load", "query", "queryOrFilter", "pipe", "map", "withSpan", "runQuery", "flatMap", "queryResult", "run", "Context", "Layer", "QueueService", "Context", "Tag", "notAvailable", "Layer", "succeed", "queues", "get", "dxn", "Error", "create", "contextQueue", "undefined", "make", "makeLayer", "ContextQueueService", "Context", "Effect", "Layer", "CredentialsService", "Context", "Tag", "configuredLayer", "credentials", "Layer", "succeed", "ConfiguredCredentialsService", "getCredential", "query", "Effect", "gen", "promise", "addCredentials", "push", "queryCredentials", "filter", "credential", "service", "find", "Error", "Context", "Effect", "Layer", "AgentStatus", "Obj", "TracingService", "Context", "Tag", "noop", "write", "layerNoop", "Layer", "succeed", "console", "event", "log", "emitStatus", "Effect", "fnUntraced", "data", "tracing", "Obj", "make", "AgentStatus", "Effect", "Context", "Schema", "Layer", "Obj", "Type", "invariant", "log", "LogLevel", "ComputeEventPayload", "Schema", "Union", "Struct", "type", "Literal", "nodeId", "String", "inputs", "Record", "key", "value", "Any", "outputs", "property", "event", "ComputeEvent", "payload", "pipe", "Type", "Obj", "typename", "version", "ComputeEventLogger", "Context", "Tag", "noop", "log", "undefined", "layerFromTracing", "Layer", "effect", "Effect", "gen", "tracing", "TracingService", "write", "make", "logCustomEvent", "data", "logger", "Error", "createDefectLogger", "catchAll", "error", "createEventLogger", "level", "message", "logFunction", "LogLevel", "WARN", "warn", "VERBOSE", "verbose", "DEBUG", "debug", "INFO", "info", "ERROR", "invariant", "Context", "Layer", "RemoteFunctionExecutionService", "Context", "Tag", "fromClient", "baseUrl", "spaceId", "callFunction", "deployedFunctionId", "input", "url", "getInvocationUrl", "result", "fetch", "method", "headers", "body", "JSON", "stringify", "status", "Error", "cause", "text", "json", "mock", "mockLayer", "Layer", "succeed", "functionUrl", "edgeUrl", "options", "URL", "relativeUrl", "replace", "toString", "searchParams", "set", "subjectId", "protocol", "isSecure", "Layer", "AiService", "entries", "SERVICES", "ai", "AiService", "credentials", "CredentialsService", "database", "DatabaseService", "eventLogger", "ComputeEventLogger", "functionCallService", "RemoteFunctionExecutionService", "queues", "QueueService", "tracing", "TracingService", "SERVICE_MAPPING", "Object", "fromEntries", "entries", "map", "name", "tag", "key", "SERVICE_TAGS", "values", "DEFAULT_SERVICES", "noop", "ServiceContainer", "_services", "setServices", "services", "getService", "serviceKey", "service", "undefined", "Error", "clone", "createLayer", "Layer", "succeed", "notAvailable", "ConfiguredCredentialsService", "mock", "mergeAll", "BaseError", "ServiceNotAvailableError", "BaseError", "extend", "serviceName", "FunctionError", "Context", "Effect", "Layer", "Schema", "todo", "LocalFunctionExecutionService", "Context", "Tag", "layer", "Layer", "succeed", "invokeFunction", "fnDef", "input", "Effect", "gen", "assertInput", "inputSchema", "pipe", "Schema", "asserts", "context", "getService", "todo", "getSpace", "_spaceId", "Error", "space", "undefined", "ai", "data", "result", "handler", "isEffect", "orDie", "then", "promise", "catchAllDefect", "defect", "die", "FunctionError", "name", "cause", "assertOutput", "outputSchema", "withSpan", "attributes"]
|
|
7
|
+
}
|
|
@@ -1,18 +1,23 @@
|
|
|
1
1
|
import {
|
|
2
|
+
ComputeEvent,
|
|
3
|
+
ComputeEventLogger,
|
|
4
|
+
ComputeEventPayload,
|
|
2
5
|
ConfiguredCredentialsService,
|
|
3
6
|
ContextQueueService,
|
|
4
7
|
CredentialsService,
|
|
5
8
|
DatabaseService,
|
|
6
|
-
|
|
7
|
-
|
|
9
|
+
FunctionError,
|
|
10
|
+
LocalFunctionExecutionService,
|
|
8
11
|
QueueService,
|
|
12
|
+
RemoteFunctionExecutionService,
|
|
9
13
|
SERVICE_TAGS,
|
|
10
14
|
ServiceContainer,
|
|
15
|
+
ServiceNotAvailableError,
|
|
11
16
|
TracingService,
|
|
12
17
|
createDefectLogger,
|
|
13
18
|
createEventLogger,
|
|
14
19
|
logCustomEvent
|
|
15
|
-
} from "./chunk-
|
|
20
|
+
} from "./chunk-6PTFLPCO.mjs";
|
|
16
21
|
|
|
17
22
|
// src/handler.ts
|
|
18
23
|
import { Schema } from "effect";
|
|
@@ -445,26 +450,17 @@ var FunctionExecutor = class {
|
|
|
445
450
|
return data;
|
|
446
451
|
}
|
|
447
452
|
};
|
|
448
|
-
|
|
449
|
-
// src/errors.ts
|
|
450
|
-
import { BaseError } from "@dxos/errors";
|
|
451
|
-
var ServiceNotAvailableError = class extends BaseError.extend("SERVICE_NOT_AVAILABLE") {
|
|
452
|
-
constructor(serviceName) {
|
|
453
|
-
super(`Service not available: ${serviceName}`);
|
|
454
|
-
}
|
|
455
|
-
};
|
|
456
|
-
var FunctionError = class extends BaseError.extend("FUNCTION_ERROR") {
|
|
457
|
-
};
|
|
458
453
|
export {
|
|
454
|
+
ComputeEvent,
|
|
455
|
+
ComputeEventLogger,
|
|
456
|
+
ComputeEventPayload,
|
|
459
457
|
ConfiguredCredentialsService,
|
|
460
458
|
ContextQueueService,
|
|
461
459
|
CredentialsService,
|
|
462
460
|
DatabaseService,
|
|
463
461
|
EmailTriggerOutput,
|
|
464
|
-
EventLogger,
|
|
465
462
|
FUNCTIONS_PRESET_META_KEY,
|
|
466
463
|
FUNCTION_TYPES,
|
|
467
|
-
FunctionCallService,
|
|
468
464
|
FunctionError,
|
|
469
465
|
FunctionExecutor,
|
|
470
466
|
FunctionManifestSchema,
|
|
@@ -475,8 +471,10 @@ export {
|
|
|
475
471
|
InvocationTraceEndEvent,
|
|
476
472
|
InvocationTraceEventType,
|
|
477
473
|
InvocationTraceStartEvent,
|
|
474
|
+
LocalFunctionExecutionService,
|
|
478
475
|
QueueService,
|
|
479
476
|
QueueTriggerOutput,
|
|
477
|
+
RemoteFunctionExecutionService,
|
|
480
478
|
SERVICE_TAGS,
|
|
481
479
|
ScriptType,
|
|
482
480
|
ServiceContainer,
|