@dxos/functions 0.8.4-main.84f28bd → 0.8.4-main.c1de068

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.
Files changed (73) hide show
  1. package/dist/lib/browser/{chunk-54U464M4.mjs → chunk-3NGCSUEW.mjs} +74 -106
  2. package/dist/lib/browser/chunk-3NGCSUEW.mjs.map +7 -0
  3. package/dist/lib/browser/edge/index.mjs.map +1 -1
  4. package/dist/lib/browser/index.mjs +23 -12
  5. package/dist/lib/browser/index.mjs.map +4 -4
  6. package/dist/lib/browser/meta.json +1 -1
  7. package/dist/lib/browser/testing/index.mjs +19 -39
  8. package/dist/lib/browser/testing/index.mjs.map +4 -4
  9. package/dist/lib/node-esm/{chunk-XDSX35BS.mjs → chunk-FJ2MU7TL.mjs} +74 -106
  10. package/dist/lib/node-esm/chunk-FJ2MU7TL.mjs.map +7 -0
  11. package/dist/lib/node-esm/edge/index.mjs.map +1 -1
  12. package/dist/lib/node-esm/index.mjs +23 -12
  13. package/dist/lib/node-esm/index.mjs.map +4 -4
  14. package/dist/lib/node-esm/meta.json +1 -1
  15. package/dist/lib/node-esm/testing/index.mjs +19 -39
  16. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  17. package/dist/types/src/edge/functions.d.ts +1 -1
  18. package/dist/types/src/edge/functions.d.ts.map +1 -1
  19. package/dist/types/src/errors.d.ts +68 -0
  20. package/dist/types/src/errors.d.ts.map +1 -0
  21. package/dist/types/src/handler.d.ts +7 -6
  22. package/dist/types/src/handler.d.ts.map +1 -1
  23. package/dist/types/src/index.d.ts +1 -0
  24. package/dist/types/src/index.d.ts.map +1 -1
  25. package/dist/types/src/schema.d.ts +1 -1
  26. package/dist/types/src/services/credentials.d.ts +2 -1
  27. package/dist/types/src/services/credentials.d.ts.map +1 -1
  28. package/dist/types/src/services/database.d.ts +17 -3
  29. package/dist/types/src/services/database.d.ts.map +1 -1
  30. package/dist/types/src/services/index.d.ts +0 -2
  31. package/dist/types/src/services/index.d.ts.map +1 -1
  32. package/dist/types/src/services/queues.d.ts +13 -1
  33. package/dist/types/src/services/queues.d.ts.map +1 -1
  34. package/dist/types/src/services/service-container.d.ts +26 -16
  35. package/dist/types/src/services/service-container.d.ts.map +1 -1
  36. package/dist/types/src/services/service-registry.d.ts +29 -0
  37. package/dist/types/src/services/service-registry.d.ts.map +1 -0
  38. package/dist/types/src/services/service-registry.test.d.ts +2 -0
  39. package/dist/types/src/services/service-registry.test.d.ts.map +1 -0
  40. package/dist/types/src/services/tracing.d.ts +11 -1
  41. package/dist/types/src/services/tracing.d.ts.map +1 -1
  42. package/dist/types/src/testing/index.d.ts +1 -0
  43. package/dist/types/src/testing/index.d.ts.map +1 -1
  44. package/dist/types/src/testing/layer.d.ts +10 -0
  45. package/dist/types/src/testing/layer.d.ts.map +1 -0
  46. package/dist/types/src/testing/services.d.ts +6 -18
  47. package/dist/types/src/testing/services.d.ts.map +1 -1
  48. package/dist/types/src/types.d.ts +8 -8
  49. package/dist/types/tsconfig.tsbuildinfo +1 -1
  50. package/package.json +25 -23
  51. package/src/edge/functions.ts +1 -1
  52. package/src/errors.ts +13 -0
  53. package/src/handler.ts +23 -16
  54. package/src/index.ts +1 -0
  55. package/src/services/credentials.ts +8 -2
  56. package/src/services/database.ts +27 -7
  57. package/src/services/index.ts +0 -2
  58. package/src/services/queues.ts +15 -2
  59. package/src/services/service-container.ts +37 -51
  60. package/src/services/service-registry.test.ts +42 -0
  61. package/src/services/service-registry.ts +56 -0
  62. package/src/services/tracing.ts +16 -1
  63. package/src/testing/index.ts +1 -0
  64. package/src/testing/layer.ts +31 -0
  65. package/src/testing/services.ts +7 -67
  66. package/dist/lib/browser/chunk-54U464M4.mjs.map +0 -7
  67. package/dist/lib/node-esm/chunk-XDSX35BS.mjs.map +0 -7
  68. package/dist/types/src/services/ai.d.ts +0 -12
  69. package/dist/types/src/services/ai.d.ts.map +0 -1
  70. package/dist/types/src/services/tool-resolver.d.ts +0 -14
  71. package/dist/types/src/services/tool-resolver.d.ts.map +0 -1
  72. package/src/services/ai.ts +0 -32
  73. package/src/services/tool-resolver.ts +0 -31
@@ -1,32 +1,8 @@
1
- // src/services/ai.ts
2
- import { Context, Layer } from "effect";
3
- var AiService = class _AiService extends Context.Tag("AiService")() {
4
- static {
5
- this.make = (client) => {
6
- return {
7
- get client() {
8
- return client;
9
- }
10
- };
11
- };
12
- }
13
- static {
14
- this.makeLayer = (client) => Layer.succeed(_AiService, _AiService.make(client));
15
- }
16
- static {
17
- this.notAvailable = Layer.succeed(_AiService, {
18
- get client() {
19
- throw new Error("AiService not available");
20
- }
21
- });
22
- }
23
- };
24
-
25
1
  // src/services/database.ts
26
- import { Context as Context2, Effect, Layer as Layer2 } from "effect";
27
- var DatabaseService = class _DatabaseService extends Context2.Tag("DatabaseService")() {
2
+ import { Context, Effect, Layer } from "effect";
3
+ var DatabaseService = class _DatabaseService extends Context.Tag("DatabaseService")() {
28
4
  static {
29
- this.notAvailable = Layer2.succeed(_DatabaseService, {
5
+ this.notAvailable = Layer.succeed(_DatabaseService, {
30
6
  get db() {
31
7
  throw new Error("Database not available");
32
8
  }
@@ -56,19 +32,28 @@ var DatabaseService = class _DatabaseService extends Context2.Tag("DatabaseServi
56
32
  }
57
33
  static {
58
34
  this.loadRef = Effect.fn(function* (ref) {
59
- return yield* Effect.tryPromise({
60
- try: () => ref.load(),
61
- catch: (error) => error
62
- });
35
+ return yield* Effect.promise(() => ref.load());
63
36
  });
64
37
  }
38
+ static {
39
+ /**
40
+ * Creates a `QueryResult` object that can be subscribed to.
41
+ */
42
+ this.query = (queryOrFilter) => _DatabaseService.pipe(Effect.map(({ db }) => db.query(queryOrFilter)), Effect.withSpan("DatabaseService.query"));
43
+ }
44
+ static {
45
+ /**
46
+ * Executes the query once and returns the results.
47
+ */
48
+ this.runQuery = (queryOrFilter) => _DatabaseService.query(queryOrFilter).pipe(Effect.flatMap((queryResult) => Effect.promise(() => queryResult.run())));
49
+ }
65
50
  };
66
51
 
67
52
  // src/services/queues.ts
68
- import { Context as Context3, Layer as Layer3 } from "effect";
69
- var QueueService = class _QueueService extends Context3.Tag("QueueService")() {
53
+ import { Context as Context2, Layer as Layer2 } from "effect";
54
+ var QueueService = class _QueueService extends Context2.Tag("QueueService")() {
70
55
  static {
71
- this.notAvailable = Layer3.succeed(_QueueService, {
56
+ this.notAvailable = Layer2.succeed(_QueueService, {
72
57
  queues: {
73
58
  get(dxn) {
74
59
  throw new Error("Queues not available");
@@ -89,10 +74,18 @@ var QueueService = class _QueueService extends Context3.Tag("QueueService")() {
89
74
  };
90
75
  }
91
76
  };
77
+ var ContextQueueService = class extends Context2.Tag("ContextQueueService")() {
78
+ };
92
79
 
93
80
  // src/services/credentials.ts
94
- import { Context as Context4 } from "effect";
95
- var CredentialsService = class extends Context4.Tag("CredentialsService")() {
81
+ import { Context as Context3, Effect as Effect2 } from "effect";
82
+ var CredentialsService = class _CredentialsService extends Context3.Tag("CredentialsService")() {
83
+ static {
84
+ this.getCredential = (query) => Effect2.gen(function* () {
85
+ const credentials = yield* _CredentialsService;
86
+ return yield* Effect2.promise(() => credentials.getCredential(query));
87
+ });
88
+ }
96
89
  };
97
90
  var ConfiguredCredentialsService = class {
98
91
  constructor(credentials = []) {
@@ -115,11 +108,11 @@ var ConfiguredCredentialsService = class {
115
108
  };
116
109
 
117
110
  // src/services/event-logger.ts
118
- import { Effect as Effect2, Context as Context5 } from "effect";
111
+ import { Effect as Effect3, Context as Context4 } from "effect";
119
112
  import { invariant } from "@dxos/invariant";
120
113
  import { log, LogLevel } from "@dxos/log";
121
114
  var __dxlog_file = "/__w/dxos/dxos/packages/core/functions/src/services/event-logger.ts";
122
- var EventLogger = class extends Context5.Tag("EventLogger")() {
115
+ var EventLogger = class extends Context4.Tag("EventLogger")() {
123
116
  static {
124
117
  this.noop = {
125
118
  log: () => {
@@ -128,7 +121,7 @@ var EventLogger = class extends Context5.Tag("EventLogger")() {
128
121
  };
129
122
  }
130
123
  };
131
- var logCustomEvent = (data) => Effect2.gen(function* () {
124
+ var logCustomEvent = (data) => Effect3.gen(function* () {
132
125
  const logger = yield* EventLogger;
133
126
  if (!logger.nodeId) {
134
127
  throw new Error("logCustomEvent must be called within a node compute function");
@@ -139,7 +132,7 @@ var logCustomEvent = (data) => Effect2.gen(function* () {
139
132
  event: data
140
133
  });
141
134
  });
142
- var createDefectLogger = () => Effect2.catchAll((error) => Effect2.gen(function* () {
135
+ var createDefectLogger = () => Effect3.catchAll((error) => Effect3.gen(function* () {
143
136
  log.error("unhandled effect error", {
144
137
  error
145
138
  }, {
@@ -176,8 +169,8 @@ var createEventLogger = (level, message = "event") => {
176
169
  };
177
170
 
178
171
  // src/services/function-call-service.ts
179
- import { Context as Context6 } from "effect";
180
- var FunctionCallService = class extends Context6.Tag("FunctionCallService")() {
172
+ import { Context as Context5 } from "effect";
173
+ var FunctionCallService = class extends Context5.Tag("FunctionCallService")() {
181
174
  static fromClient(baseUrl, spaceId) {
182
175
  return {
183
176
  callFunction: async (deployedFunctionId, input) => {
@@ -223,30 +216,11 @@ var isSecure = (protocol) => {
223
216
  return protocol === "https:" || protocol === "wss:";
224
217
  };
225
218
 
226
- // src/services/tool-resolver.ts
227
- import { Context as Context7 } from "effect";
228
- var ToolResolverService = class extends Context7.Tag("ToolResolverService")() {
229
- static {
230
- this.notAvailable = {
231
- toolResolver: {
232
- resolve: async (id) => {
233
- throw new Error("Tool resolver not available");
234
- }
235
- }
236
- };
237
- }
238
- static {
239
- this.make = (toolResolver) => {
240
- return {
241
- toolResolver
242
- };
243
- };
244
- }
245
- };
246
-
247
219
  // src/services/tracing.ts
248
- import { Context as Context8 } from "effect";
249
- var TracingService = class extends Context8.Tag("TracingService")() {
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")() {
250
224
  static {
251
225
  this.noop = {
252
226
  write: () => {
@@ -260,29 +234,35 @@ var TracingService = class extends Context8.Tag("TracingService")() {
260
234
  }
261
235
  };
262
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
+ }
263
246
  };
264
247
 
265
248
  // src/services/service-container.ts
266
- import { Layer as Layer4 } from "effect";
267
- var SERVICE_MAPPING = {
268
- [AiService.key]: "ai",
269
- [CredentialsService.key]: "credentials",
270
- [DatabaseService.key]: "database",
271
- [EventLogger.key]: "eventLogger",
272
- [FunctionCallService.key]: "functionCallService",
273
- [QueueService.key]: "queues",
274
- [TracingService.key]: "tracing",
275
- [ToolResolverService.key]: "toolResolver"
249
+ import { Layer as Layer3 } from "effect";
250
+ import { AiService } from "@dxos/ai";
251
+ import { entries } from "@dxos/util";
252
+ var SERVICES = {
253
+ ai: AiService,
254
+ credentials: CredentialsService,
255
+ database: DatabaseService,
256
+ eventLogger: EventLogger,
257
+ functionCallService: FunctionCallService,
258
+ queues: QueueService,
259
+ tracing: TracingService
276
260
  };
277
- var SERVICE_TAGS = [
278
- AiService,
279
- CredentialsService,
280
- DatabaseService,
281
- EventLogger,
282
- FunctionCallService,
283
- TracingService,
284
- QueueService
285
- ];
261
+ var SERVICE_MAPPING = Object.fromEntries(entries(SERVICES).map(([name, tag]) => [
262
+ tag.key,
263
+ name
264
+ ]));
265
+ var SERVICE_TAGS = Object.values(SERVICES);
286
266
  var DEFAULT_SERVICES = {
287
267
  tracing: TracingService.noop
288
268
  };
@@ -319,32 +299,21 @@ var ServiceContainer = class _ServiceContainer {
319
299
  }
320
300
  // 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.
321
301
  createLayer() {
322
- const ai = this._services.ai != null ? Layer4.succeed(AiService, this._services.ai) : AiService.notAvailable;
323
- const credentials = Layer4.succeed(CredentialsService, new ConfiguredCredentialsService());
324
- const database = this._services.database != null ? Layer4.succeed(DatabaseService, this._services.database) : DatabaseService.notAvailable;
325
- const queues = this._services.queues != null ? Layer4.succeed(QueueService, this._services.queues) : QueueService.notAvailable;
326
- const tracing = Layer4.succeed(TracingService, this._services.tracing ?? TracingService.noop);
327
- const eventLogger = Layer4.succeed(EventLogger, this._services.eventLogger ?? EventLogger.noop);
328
- const functionCallService = Layer4.succeed(FunctionCallService, this._services.functionCallService ?? FunctionCallService.mock());
329
- const toolResolver = Layer4.succeed(ToolResolverService, this._services.toolResolver ?? ToolResolverService.notAvailable);
330
- return Layer4.mergeAll(
331
- //
332
- ai,
333
- credentials,
334
- database,
335
- queues,
336
- tracing,
337
- eventLogger,
338
- functionCallService,
339
- toolResolver
340
- );
302
+ const ai = this._services.ai != null ? Layer3.succeed(AiService, this._services.ai) : AiService.notAvailable;
303
+ const credentials = Layer3.succeed(CredentialsService, this._services.credentials ?? new ConfiguredCredentialsService());
304
+ const database = this._services.database != null ? Layer3.succeed(DatabaseService, this._services.database) : DatabaseService.notAvailable;
305
+ const queues = this._services.queues != null ? Layer3.succeed(QueueService, this._services.queues) : QueueService.notAvailable;
306
+ const tracing = Layer3.succeed(TracingService, this._services.tracing ?? TracingService.noop);
307
+ const eventLogger = Layer3.succeed(EventLogger, this._services.eventLogger ?? EventLogger.noop);
308
+ const functionCallService = Layer3.succeed(FunctionCallService, this._services.functionCallService ?? FunctionCallService.mock());
309
+ return Layer3.mergeAll(ai, credentials, database, queues, tracing, eventLogger, functionCallService);
341
310
  }
342
311
  };
343
312
 
344
313
  export {
345
- AiService,
346
314
  DatabaseService,
347
315
  QueueService,
316
+ ContextQueueService,
348
317
  CredentialsService,
349
318
  ConfiguredCredentialsService,
350
319
  EventLogger,
@@ -352,9 +321,8 @@ export {
352
321
  createDefectLogger,
353
322
  createEventLogger,
354
323
  FunctionCallService,
355
- ToolResolverService,
356
324
  TracingService,
357
325
  SERVICE_TAGS,
358
326
  ServiceContainer
359
327
  };
360
- //# sourceMappingURL=chunk-54U464M4.mjs.map
328
+ //# sourceMappingURL=chunk-3NGCSUEW.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/event-logger.ts", "../../../src/services/function-call-service.ts", "../../../src/services/tracing.ts", "../../../src/services/service-container.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('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 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('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\n/**\n * Gives access to a specific queue passed as a context.\n */\nexport class ContextQueueService extends Context.Tag('ContextQueueService')<\n ContextQueueService,\n {\n readonly contextQueue: Queue;\n }\n>() {}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context, Effect } 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('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 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 { Effect, Context } from 'effect';\n\nimport { invariant } from '@dxos/invariant';\nimport { log, LogLevel } from '@dxos/log';\n\nexport type ComputeEvent =\n | {\n type: 'begin-compute';\n nodeId: string;\n inputs: Record<string, any>;\n }\n | {\n type: 'end-compute';\n nodeId: string;\n outputs: Record<string, any>;\n }\n | {\n type: 'compute-input';\n nodeId: string;\n property: string;\n value: any;\n }\n | {\n type: 'compute-output';\n nodeId: string;\n property: string;\n value: any;\n }\n | {\n type: 'custom';\n nodeId: string;\n event: any;\n };\n\nexport class EventLogger extends Context.Tag('EventLogger')<\n EventLogger,\n { readonly log: (event: ComputeEvent) => void; readonly nodeId: string | undefined }\n>() {\n static noop: Context.Tag.Service<EventLogger> = {\n log: () => {},\n nodeId: undefined,\n };\n}\n\nexport const logCustomEvent = (data: any) =>\n Effect.gen(function* () {\n const logger = yield* EventLogger;\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 = (level: LogLevel, message: string = 'event'): Context.Tag.Service<EventLogger> => {\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: ComputeEvent) => {\n logFunction(message, event);\n },\n nodeId: undefined,\n };\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context } from 'effect';\n\nimport type { SpaceId } from '@dxos/keys';\n\n/**\n * Allows calling into other functions.\n */\nexport class FunctionCallService extends Context.Tag('FunctionCallService')<\n FunctionCallService,\n {\n callFunction(deployedFunctionId: string, input: any, spaceId?: SpaceId): Promise<any>;\n }\n>() {\n static fromClient(baseUrl: string, spaceId: SpaceId): Context.Tag.Service<FunctionCallService> {\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 = () => {\n return {\n callFunction: async (deployedFunctionId: string, input: any) => {\n return input;\n },\n };\n };\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 { Context, Effect } 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('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 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 { 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 { EventLogger } from './event-logger';\nimport { FunctionCallService } from './function-call-service';\nimport { QueueService } from './queues';\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: EventLogger,\n functionCallService: FunctionCallService,\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(EventLogger, this._services.eventLogger ?? EventLogger.noop);\n const functionCallService = Layer.succeed(\n FunctionCallService,\n this._services.functionCallService ?? FunctionCallService.mock(),\n );\n\n return Layer.mergeAll(ai, credentials, database, queues, tracing, eventLogger, functionCallService);\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["Context", "Effect", "Layer", "DatabaseService", "Context", "Tag", "notAvailable", "Layer", "succeed", "db", "Error", "make", "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", "ContextQueueService", "Context", "Effect", "CredentialsService", "Context", "Tag", "getCredential", "query", "Effect", "gen", "credentials", "promise", "ConfiguredCredentialsService", "addCredentials", "push", "queryCredentials", "filter", "credential", "service", "find", "Error", "Effect", "Context", "invariant", "log", "LogLevel", "EventLogger", "Tag", "noop", "nodeId", "undefined", "logCustomEvent", "data", "gen", "logger", "Error", "type", "event", "createDefectLogger", "catchAll", "error", "createEventLogger", "level", "message", "logFunction", "WARN", "warn", "VERBOSE", "verbose", "DEBUG", "debug", "INFO", "info", "ERROR", "Context", "FunctionCallService", "Context", "Tag", "fromClient", "baseUrl", "spaceId", "callFunction", "deployedFunctionId", "input", "url", "getInvocationUrl", "result", "fetch", "method", "headers", "body", "JSON", "stringify", "status", "Error", "cause", "text", "json", "mock", "functionUrl", "edgeUrl", "options", "URL", "relativeUrl", "replace", "toString", "searchParams", "set", "subjectId", "protocol", "isSecure", "Context", "Effect", "AgentStatus", "Obj", "TracingService", "Context", "Tag", "noop", "write", "console", "event", "log", "emitStatus", "Effect", "fnUntraced", "data", "tracing", "Obj", "make", "AgentStatus", "Layer", "AiService", "entries", "SERVICES", "ai", "AiService", "credentials", "CredentialsService", "database", "DatabaseService", "eventLogger", "EventLogger", "functionCallService", "FunctionCallService", "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"]
7
+ }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/edge/functions.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { type DID } from 'iso-did/types';\n\nimport { type Client } from '@dxos/client';\nimport { createEdgeIdentity } from '@dxos/client/edge';\nimport { EdgeHttpClient } from '@dxos/edge-client';\nimport { invariant } from '@dxos/invariant';\nimport type { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type UploadFunctionResponseBody } from '@dxos/protocols';\n\nexport type UploadWorkerArgs = {\n client: Client;\n source: string;\n version: string;\n name?: string;\n functionId?: string;\n ownerPublicKey: PublicKey;\n};\n\nexport const uploadWorkerFunction = async ({\n client,\n version,\n source,\n name,\n functionId,\n ownerPublicKey,\n}: UploadWorkerArgs): Promise<UploadFunctionResponseBody> => {\n const edgeUrl = client.config.values.runtime?.services?.edge?.url;\n invariant(edgeUrl, 'Edge is not configured.');\n const edgeClient = new EdgeHttpClient(edgeUrl);\n const edgeIdentity = createEdgeIdentity(client);\n edgeClient.setIdentity(edgeIdentity);\n const response = await edgeClient.uploadFunction(\n { functionId },\n { name, version, script: source, ownerPublicKey: ownerPublicKey.toHex() },\n );\n\n // TODO(burdon): Edge service log.\n log.info('Uploaded', {\n identityKey: edgeIdentity.identityKey,\n functionId,\n name,\n source: source.length,\n response,\n });\n\n return response;\n};\n\nexport const incrementSemverPatch = (version: string): string => {\n const [major, minor, patch] = version.split('.');\n const patchNum = Number(patch);\n invariant(!Number.isNaN(patchNum), `Unexpected function version format: ${version}`);\n return [major, minor, String(patchNum + 1)].join('.');\n};\n\n// TODO(burdon): Factor out.\nexport const publicKeyToDid = (key: PublicKey): DID => {\n return `did:key:${key.toHex()}`;\n};\n"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { type DID } from 'iso-did/types';\n\nimport { type Client } from '@dxos/client';\nimport { createEdgeIdentity } from '@dxos/client/edge';\nimport { EdgeHttpClient } from '@dxos/edge-client';\nimport { invariant } from '@dxos/invariant';\nimport { type PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type UploadFunctionResponseBody } from '@dxos/protocols';\n\nexport type UploadWorkerArgs = {\n client: Client;\n source: string;\n version: string;\n name?: string;\n functionId?: string;\n ownerPublicKey: PublicKey;\n};\n\nexport const uploadWorkerFunction = async ({\n client,\n version,\n source,\n name,\n functionId,\n ownerPublicKey,\n}: UploadWorkerArgs): Promise<UploadFunctionResponseBody> => {\n const edgeUrl = client.config.values.runtime?.services?.edge?.url;\n invariant(edgeUrl, 'Edge is not configured.');\n const edgeClient = new EdgeHttpClient(edgeUrl);\n const edgeIdentity = createEdgeIdentity(client);\n edgeClient.setIdentity(edgeIdentity);\n const response = await edgeClient.uploadFunction(\n { functionId },\n { name, version, script: source, ownerPublicKey: ownerPublicKey.toHex() },\n );\n\n // TODO(burdon): Edge service log.\n log.info('Uploaded', {\n identityKey: edgeIdentity.identityKey,\n functionId,\n name,\n source: source.length,\n response,\n });\n\n return response;\n};\n\nexport const incrementSemverPatch = (version: string): string => {\n const [major, minor, patch] = version.split('.');\n const patchNum = Number(patch);\n invariant(!Number.isNaN(patchNum), `Unexpected function version format: ${version}`);\n return [major, minor, String(patchNum + 1)].join('.');\n};\n\n// TODO(burdon): Factor out.\nexport const publicKeyToDid = (key: PublicKey): DID => {\n return `did:key:${key.toHex()}`;\n};\n"],
5
5
  "mappings": ";AAOA,SAASA,0BAA0B;AACnC,SAASC,sBAAsB;AAC/B,SAASC,iBAAiB;AAE1B,SAASC,WAAW;;AAYb,IAAMC,uBAAuB,OAAO,EACzCC,QACAC,SACAC,QACAC,MACAC,YACAC,eAAc,MACG;AACjB,QAAMC,UAAUN,OAAOO,OAAOC,OAAOC,SAASC,UAAUC,MAAMC;AAC9Df,YAAUS,SAAS,2BAAA;;;;;;;;;AACnB,QAAMO,aAAa,IAAIjB,eAAeU,OAAAA;AACtC,QAAMQ,eAAenB,mBAAmBK,MAAAA;AACxCa,aAAWE,YAAYD,YAAAA;AACvB,QAAME,WAAW,MAAMH,WAAWI,eAChC;IAAEb;EAAW,GACb;IAAED;IAAMF;IAASiB,QAAQhB;IAAQG,gBAAgBA,eAAec,MAAK;EAAG,CAAA;AAI1ErB,MAAIsB,KAAK,YAAY;IACnBC,aAAaP,aAAaO;IAC1BjB;IACAD;IACAD,QAAQA,OAAOoB;IACfN;EACF,GAAA;;;;;;AAEA,SAAOA;AACT;AAEO,IAAMO,uBAAuB,CAACtB,YAAAA;AACnC,QAAM,CAACuB,OAAOC,OAAOC,KAAAA,IAASzB,QAAQ0B,MAAM,GAAA;AAC5C,QAAMC,WAAWC,OAAOH,KAAAA;AACxB7B,YAAU,CAACgC,OAAOC,MAAMF,QAAAA,GAAW,uCAAuC3B,OAAAA,IAAS;;;;;;;;;AACnF,SAAO;IAACuB;IAAOC;IAAOM,OAAOH,WAAW,CAAA;IAAII,KAAK,GAAA;AACnD;AAGO,IAAMC,iBAAiB,CAACC,QAAAA;AAC7B,SAAO,WAAWA,IAAIf,MAAK,CAAA;AAC7B;",
6
6
  "names": ["createEdgeIdentity", "EdgeHttpClient", "invariant", "log", "uploadWorkerFunction", "client", "version", "source", "name", "functionId", "ownerPublicKey", "edgeUrl", "config", "values", "runtime", "services", "edge", "url", "edgeClient", "edgeIdentity", "setIdentity", "response", "uploadFunction", "script", "toHex", "info", "identityKey", "length", "incrementSemverPatch", "major", "minor", "patch", "split", "patchNum", "Number", "isNaN", "String", "join", "publicKeyToDid", "key"]
7
7
  }
@@ -1,6 +1,6 @@
1
1
  import {
2
- AiService,
3
2
  ConfiguredCredentialsService,
3
+ ContextQueueService,
4
4
  CredentialsService,
5
5
  DatabaseService,
6
6
  EventLogger,
@@ -8,27 +8,27 @@ import {
8
8
  QueueService,
9
9
  SERVICE_TAGS,
10
10
  ServiceContainer,
11
- ToolResolverService,
12
11
  TracingService,
13
12
  createDefectLogger,
14
13
  createEventLogger,
15
14
  logCustomEvent
16
- } from "./chunk-54U464M4.mjs";
15
+ } from "./chunk-3NGCSUEW.mjs";
17
16
 
18
17
  // src/handler.ts
19
18
  import { Schema } from "effect";
20
- var defineFunction = (params) => {
21
- if (!Schema.isSchema(params.inputSchema)) {
19
+ var defineFunction = ({ name, description, inputSchema, outputSchema = Schema.Any, handler }) => {
20
+ if (!Schema.isSchema(inputSchema)) {
22
21
  throw new Error("Input schema must be a valid schema");
23
22
  }
24
- if (typeof params.handler !== "function") {
23
+ if (typeof handler !== "function") {
25
24
  throw new Error("Handler must be a function");
26
25
  }
27
26
  return {
28
- description: params.description,
29
- inputSchema: params.inputSchema,
30
- outputSchema: params.outputSchema ?? Schema.Any,
31
- handler: params.handler
27
+ name,
28
+ description,
29
+ inputSchema,
30
+ outputSchema,
31
+ handler
32
32
  };
33
33
  };
34
34
 
@@ -445,9 +445,19 @@ var FunctionExecutor = class {
445
445
  return data;
446
446
  }
447
447
  };
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
+ };
448
458
  export {
449
- AiService,
450
459
  ConfiguredCredentialsService,
460
+ ContextQueueService,
451
461
  CredentialsService,
452
462
  DatabaseService,
453
463
  EmailTriggerOutput,
@@ -455,6 +465,7 @@ export {
455
465
  FUNCTIONS_PRESET_META_KEY,
456
466
  FUNCTION_TYPES,
457
467
  FunctionCallService,
468
+ FunctionError,
458
469
  FunctionExecutor,
459
470
  FunctionManifestSchema,
460
471
  FunctionTrigger,
@@ -469,9 +480,9 @@ export {
469
480
  SERVICE_TAGS,
470
481
  ScriptType,
471
482
  ServiceContainer,
483
+ ServiceNotAvailableError,
472
484
  SubscriptionTriggerOutput,
473
485
  TimerTriggerOutput,
474
- ToolResolverService,
475
486
  TraceEvent,
476
487
  TraceEventException,
477
488
  TraceEventLog,
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../src/handler.ts", "../../../src/schema.ts", "../../../src/trace.ts", "../../../src/types.ts", "../../../src/url.ts", "../../../src/executor/executor.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Schema, type Context, type Effect } from 'effect';\n\nimport { type AiServiceClient } from '@dxos/ai';\n// import { type Space } from '@dxos/client/echo';\nimport type { EchoDatabase } from '@dxos/echo-db';\nimport { type HasId } from '@dxos/echo-schema';\nimport { type SpaceId, type DXN } from '@dxos/keys';\nimport { type QueryResult } from '@dxos/protocols';\n\nimport type { Services } from './services';\n\n// TODO(burdon): Model after http request. Ref Lambda/OpenFaaS.\n// https://docs.aws.amazon.com/lambda/latest/dg/typescript-handler.html\n// https://www.serverless.com/framework/docs/providers/aws/guide/serverless.yml/#functions\n// https://www.npmjs.com/package/aws-lambda\n\n/**\n * Function handler.\n */\nexport type FunctionHandler<TData = {}, TOutput = any> = (params: {\n /**\n * Services and context available to the function.\n */\n context: FunctionContext;\n\n /**\n * Data passed as the input to the function.\n * Must match the function's input schema.\n * This will be the payload from the trigger or other data passed into the function in a workflow.\n */\n data: TData;\n}) => TOutput | Promise<TOutput> | Effect.Effect<TOutput, any, Services>;\n\n/**\n * Function context.\n */\nexport interface FunctionContext {\n /**\n * Resolves a service available to the function.\n * @throws if the service is not available.\n */\n getService: <T extends Context.Tag<any, any>>(tag: T) => Context.Tag.Service<T>;\n\n getSpace: (spaceId: SpaceId) => Promise<SpaceAPI>;\n\n /**\n * Space from which the function was invoked.\n */\n space: SpaceAPI | undefined;\n\n ai: AiServiceClient;\n}\n\nexport interface FunctionContextAi {\n // TODO(dmaretskyi): Refer to cloudflare AI docs for more comprehensive typedefs.\n run(model: string, inputs: any, options?: any): Promise<any>;\n}\n\n//\n// API.\n//\n\n// TODO(dmaretskyi): Temporary API to get the queues working.\n// TODO(dmaretskyi): To be replaced with integrating queues into echo.\nexport interface QueuesAPI {\n queryQueue(queue: DXN, options?: {}): Promise<QueryResult>;\n insertIntoQueue(queue: DXN, objects: HasId[]): Promise<void>;\n}\n\n/**\n * Space interface available to functions.\n */\nexport interface SpaceAPI {\n get id(): SpaceId;\n\n get db(): EchoDatabase;\n\n // TODO(dmaretskyi): Align with echo api --- queues.get(id).append(items);\n get queues(): QueuesAPI;\n}\n\n// TODO(wittjosiah): Queues are incompatible.\nconst __assertFunctionSpaceIsCompatibleWithTheClientSpace = () => {\n // const _: SpaceAPI = {} as Space;\n};\n\nexport type FunctionDefinition<T = {}, O = any> = {\n description?: string;\n inputSchema: Schema.Schema<T, any>;\n outputSchema?: Schema.Schema<O, any>;\n handler: FunctionHandler<T, O>;\n};\n\n// TODO(dmaretskyi): Bind input type to function handler.\nexport const defineFunction = <T, O>(params: FunctionDefinition<T, O>): FunctionDefinition<T, O> => {\n if (!Schema.isSchema(params.inputSchema)) {\n throw new Error('Input schema must be a valid schema');\n }\n if (typeof params.handler !== 'function') {\n throw new Error('Handler must be a function');\n }\n\n return {\n description: params.description,\n inputSchema: params.inputSchema,\n outputSchema: params.outputSchema ?? Schema.Any,\n handler: params.handler,\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { Type } from '@dxos/echo';\nimport { JsonSchemaType, LabelAnnotation, Ref } from '@dxos/echo-schema';\nimport { DataType } from '@dxos/schema';\n\n/**\n * Source script.\n */\nexport const ScriptType = Schema.Struct({\n name: Schema.optional(Schema.String),\n description: Schema.optional(Schema.String),\n // TODO(burdon): Change to hash of deployed content.\n // Whether source has changed since last deploy.\n changed: Schema.optional(Schema.Boolean),\n source: Ref(DataType.Text),\n}).pipe(\n Type.Obj({\n typename: 'dxos.org/type/Script',\n version: '0.1.0',\n }),\n LabelAnnotation.set(['name']),\n);\n\nexport interface ScriptType extends Schema.Schema.Type<typeof ScriptType> {}\n\n/**\n * Function deployment.\n */\nexport const FunctionType = Schema.Struct({\n // TODO(burdon): Rename to id/uri?\n name: Schema.NonEmptyString,\n version: Schema.String,\n\n description: Schema.optional(Schema.String),\n\n // Reference to a source script if it exists within ECHO.\n // TODO(burdon): Don't ref ScriptType directly (core).\n source: Schema.optional(Ref(ScriptType)),\n\n inputSchema: Schema.optional(JsonSchemaType),\n outputSchema: Schema.optional(JsonSchemaType),\n\n // Local binding to a function name.\n binding: Schema.optional(Schema.String),\n}).pipe(\n Type.Obj({\n typename: 'dxos.org/type/Function',\n version: '0.1.0',\n }),\n LabelAnnotation.set(['name']),\n);\nexport interface FunctionType extends Schema.Schema.Type<typeof FunctionType> {}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { Type, type Ref } from '@dxos/echo';\nimport { Queue } from '@dxos/echo-db';\nimport { ObjectId } from '@dxos/echo-schema';\nimport { log } from '@dxos/log';\n\nimport { FunctionTrigger, type FunctionTriggerType } from './types';\n\nexport enum InvocationOutcome {\n SUCCESS = 'success',\n FAILURE = 'failure',\n PENDING = 'pending',\n}\n\n// TODO(burdon): Convert to extensible discriminated union of EDGE events.\nexport enum InvocationTraceEventType {\n START = 'start',\n END = 'end',\n}\n\nexport const TraceEventException = Schema.Struct({\n timestampMs: Schema.Number,\n message: Schema.String,\n name: Schema.String,\n stack: Schema.optional(Schema.String),\n});\nexport type TraceEventException = Schema.Schema.Type<typeof TraceEventException>;\n\nexport const InvocationTraceStartEvent = Schema.Struct({\n /**\n * Queue message id.\n */\n id: ObjectId,\n type: Schema.Literal(InvocationTraceEventType.START),\n /**\n * Invocation id, the same for invocation start and end events.\n */\n invocationId: ObjectId,\n /**\n * Event generation time.\n */\n timestampMs: Schema.Number,\n /**\n * Data passed to function / workflow as an argument.\n */\n // TODO(burdon): Input schema?\n input: Schema.Object,\n /**\n * Queue for function/workflow invocation events.\n */\n invocationTraceQueue: Type.Ref(Queue),\n /**\n * DXN of the invoked function/workflow.\n */\n invocationTarget: Type.Ref(Type.Expando),\n /**\n * Present for automatic invocations.\n */\n trigger: Schema.optional(Type.Ref(FunctionTrigger)),\n}).pipe(Type.Obj({ typename: 'dxos.org/type/InvocationTraceStart', version: '0.1.0' }));\n\nexport type InvocationTraceStartEvent = Schema.Schema.Type<typeof InvocationTraceStartEvent>;\n\nexport const InvocationTraceEndEvent = Schema.Struct({\n /**\n * Trace event id.\n */\n id: ObjectId,\n type: Schema.Literal(InvocationTraceEventType.END),\n /**\n * Invocation id, will be the same for invocation start and end.\n */\n invocationId: ObjectId,\n /**\n * Event generation time.\n */\n // TODO(burdon): Remove ms suffix.\n timestampMs: Schema.Number,\n outcome: Schema.Enums(InvocationOutcome),\n exception: Schema.optional(TraceEventException),\n}).pipe(Type.Obj({ typename: 'dxos.org/type/InvocationTraceEnd', version: '0.1.0' }));\n\nexport type InvocationTraceEndEvent = Schema.Schema.Type<typeof InvocationTraceEndEvent>;\n\nexport type InvocationTraceEvent = InvocationTraceStartEvent | InvocationTraceEndEvent;\n\nexport const TraceEventLog = Schema.Struct({\n timestampMs: Schema.Number,\n level: Schema.String,\n message: Schema.String,\n context: Schema.optional(Schema.Object),\n});\n\nexport const TraceEvent = Schema.Struct({\n id: ObjectId,\n // TODO(burdon): Need enum/numeric result (not string).\n outcome: Schema.String,\n truncated: Schema.Boolean,\n /**\n * Time when the event was persisted.\n */\n ingestionTimestampMs: Schema.Number,\n logs: Schema.Array(TraceEventLog),\n exceptions: Schema.Array(TraceEventException),\n}).pipe(Type.Obj({ typename: 'dxos.org/type/TraceEvent', version: '0.1.0' }));\n\nexport type TraceEvent = Schema.Schema.Type<typeof TraceEvent>;\n\n/**\n * InvocationTrace event format.\n * This is the combined format of InvocationTraceStartEvent and InvocationTraceEndEvents for UI consumption.\n */\nexport type InvocationSpan = {\n id: string;\n timestampMs: number;\n outcome: InvocationOutcome;\n input: object;\n durationMs: number;\n invocationTraceQueue: Ref.Ref<Queue>;\n invocationTarget: Ref.Ref<Type.Expando>;\n trigger?: Ref.Ref<FunctionTriggerType>;\n exception?: TraceEventException;\n};\n\nexport const createInvocationSpans = (items?: InvocationTraceEvent[]): InvocationSpan[] => {\n if (!items) {\n return [];\n }\n\n const eventsByInvocationId = new Map<string, { start?: InvocationTraceStartEvent; end?: InvocationTraceEndEvent }>();\n for (const event of items) {\n if (!('invocationId' in event)) {\n // Skip legacy format entries.\n continue;\n }\n\n const invocationId = event.invocationId;\n const entry = eventsByInvocationId.get(invocationId) || { start: undefined, end: undefined };\n if (event.type === InvocationTraceEventType.START) {\n entry.start = event as InvocationTraceStartEvent;\n } else if (event.type === InvocationTraceEventType.END) {\n entry.end = event as InvocationTraceEndEvent;\n }\n\n eventsByInvocationId.set(invocationId, entry);\n }\n\n const now = Date.now();\n const result: InvocationSpan[] = [];\n\n // Create spans for each invocation\n for (const [invocationId, { start, end }] of eventsByInvocationId.entries()) {\n if (!start) {\n // No start event, can't create a meaningful span\n log.warn('found end event without matching start', { invocationId });\n continue;\n }\n\n const isInProgress = end === undefined;\n\n result.push({\n id: invocationId,\n timestampMs: start.timestampMs,\n durationMs: isInProgress ? now - start.timestampMs : end!.timestampMs - start.timestampMs,\n outcome: end?.outcome ?? InvocationOutcome.PENDING,\n exception: end?.exception,\n input: start.input,\n invocationTraceQueue: start.invocationTraceQueue,\n invocationTarget: start.invocationTarget,\n trigger: start.trigger,\n });\n }\n\n return result;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Schema, SchemaAST } from 'effect';\n\nimport { Expando, OptionsAnnotationId, TypedObject, Ref, RawObject } from '@dxos/echo-schema';\nimport { DXN } from '@dxos/keys';\n\nimport { FunctionType } from './schema';\n\n/**\n * Type discriminator for TriggerType.\n * Every spec has a type field of type TriggerKind that we can use to understand which type we're working with.\n * https://www.typescriptlang.org/docs/handbook/2/narrowing.html#discriminated-unions\n */\nexport enum TriggerKind {\n Timer = 'timer',\n Webhook = 'webhook',\n Subscription = 'subscription',\n Email = 'email',\n Queue = 'queue',\n}\n\nconst kindLiteralAnnotations = { title: 'Kind' };\n\n/**\n * Cron timer.\n */\nconst TimerTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Timer).annotations(kindLiteralAnnotations),\n cron: Schema.String.annotations({\n title: 'Cron',\n [SchemaAST.ExamplesAnnotationId]: ['0 0 * * *'],\n }),\n}).pipe(Schema.mutable);\nexport type TimerTrigger = Schema.Schema.Type<typeof TimerTriggerSchema>;\n\nconst EmailTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Email).annotations(kindLiteralAnnotations),\n}).pipe(Schema.mutable);\nexport type EmailTrigger = Schema.Schema.Type<typeof EmailTriggerSchema>;\n\nconst QueueTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Queue).annotations(kindLiteralAnnotations),\n queue: DXN.Schema,\n}).pipe(Schema.mutable);\nexport type QueueTrigger = Schema.Schema.Type<typeof QueueTriggerSchema>;\n\n/**\n * Webhook.\n */\nconst WebhookTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Webhook).annotations(kindLiteralAnnotations),\n method: Schema.optional(\n Schema.String.annotations({\n title: 'Method',\n [OptionsAnnotationId]: ['GET', 'POST'],\n }),\n ),\n port: Schema.optional(\n Schema.Number.annotations({\n title: 'Port',\n }),\n ),\n}).pipe(Schema.mutable);\nexport type WebhookTrigger = Schema.Schema.Type<typeof WebhookTriggerSchema>;\n\n// TODO(burdon): Use ECHO definition (from https://github.com/dxos/dxos/pull/8233).\nconst QuerySchema = Schema.Struct({\n type: Schema.optional(Schema.String.annotations({ title: 'Type' })),\n props: Schema.optional(Schema.Record({ key: Schema.String, value: Schema.Any })),\n}).annotations({ title: 'Query' });\n\n/**\n * Subscription.\n */\nconst SubscriptionTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Subscription).annotations(kindLiteralAnnotations),\n // TODO(burdon): Define query DSL (from ECHO). Reconcile with Table.Query.\n filter: QuerySchema,\n options: Schema.optional(\n Schema.Struct({\n // Watch changes to object (not just creation).\n deep: Schema.optional(Schema.Boolean.annotations({ title: 'Nested' })),\n // Debounce changes (delay in ms).\n delay: Schema.optional(Schema.Number.annotations({ title: 'Delay' })),\n }).annotations({ title: 'Options' }),\n ),\n}).pipe(Schema.mutable);\nexport type SubscriptionTrigger = Schema.Schema.Type<typeof SubscriptionTriggerSchema>;\n\n/**\n * Trigger schema (discriminated union).\n */\nexport const TriggerSchema = Schema.Union(\n TimerTriggerSchema,\n WebhookTriggerSchema,\n SubscriptionTriggerSchema,\n EmailTriggerSchema,\n QueueTriggerSchema,\n).annotations({\n title: 'Trigger',\n});\nexport type TriggerType = Schema.Schema.Type<typeof TriggerSchema>;\n\nexport type EventType =\n | EmailTriggerOutput\n | WebhookTriggerOutput\n | QueueTriggerOutput\n | SubscriptionTriggerOutput\n | TimerTriggerOutput;\n\n// TODO(burdon): Reuse trigger schema from @dxos/functions (TriggerType).\nexport const EmailTriggerOutput = Schema.mutable(\n Schema.Struct({\n from: Schema.String,\n to: Schema.String,\n subject: Schema.String,\n created: Schema.String,\n body: Schema.String,\n }),\n);\nexport type EmailTriggerOutput = Schema.Schema.Type<typeof EmailTriggerOutput>;\n\nexport const WebhookTriggerOutput = Schema.mutable(\n Schema.Struct({\n url: Schema.String,\n method: Schema.Literal('GET', 'POST'),\n headers: Schema.Record({ key: Schema.String, value: Schema.String }),\n bodyText: Schema.String,\n }),\n);\nexport type WebhookTriggerOutput = Schema.Schema.Type<typeof WebhookTriggerOutput>;\n\nexport const QueueTriggerOutput = Schema.mutable(\n Schema.Struct({\n queue: DXN.Schema,\n item: Schema.Any,\n cursor: Schema.String,\n }),\n);\nexport type QueueTriggerOutput = Schema.Schema.Type<typeof QueueTriggerOutput>;\n\nexport const SubscriptionTriggerOutput = Schema.mutable(\n Schema.Struct({ type: Schema.String, changedObjectId: Schema.String }),\n);\nexport type SubscriptionTriggerOutput = Schema.Schema.Type<typeof SubscriptionTriggerOutput>;\n\nexport const TimerTriggerOutput = Schema.mutable(Schema.Struct({ tick: Schema.Number }));\nexport type TimerTriggerOutput = Schema.Schema.Type<typeof TimerTriggerOutput>;\n\n/**\n * Function trigger.\n * Function is invoked with the `payload` passed as input data.\n * The event that triggers the function is available in the function context.\n */\nexport const FunctionTriggerSchema = Schema.Struct({\n /**\n * Function or workflow to invoke.\n */\n // TODO(dmaretskyi): Can be a Ref(FunctionType) or Ref(ComputeGraphType).\n function: Schema.optional(Ref(Expando).annotations({ title: 'Function' })),\n\n /**\n * Only used for workflowSchema.\n * Specifies the input node in the circuit.\n * @deprecated Remove and enforce a single input node in all compute graphSchema.\n */\n inputNodeId: Schema.optional(Schema.String.annotations({ title: 'Input Node ID' })),\n\n enabled: Schema.optional(Schema.Boolean.annotations({ title: 'Enabled' })),\n\n spec: Schema.optional(TriggerSchema),\n\n /**\n * Passed as the input data to the function.\n * Must match the function's input schema.\n *\n * @example\n * {\n * item: '{{$.trigger.event}}',\n * instructions: 'Summarize and perform entity-extraction'\n * mailbox: { '/': 'dxn:echo:AAA:ZZZ' }\n * }\n */\n input: Schema.optional(Schema.mutable(Schema.Record({ key: Schema.String, value: Schema.Any }))),\n});\n\nexport type FunctionTriggerType = Schema.Schema.Type<typeof FunctionTriggerSchema>;\n\n/**\n * Function trigger.\n */\nexport class FunctionTrigger extends TypedObject({\n typename: 'dxos.org/type/FunctionTrigger',\n version: '0.2.0',\n})(FunctionTriggerSchema.fields) {}\n\n// TODO(wittjosiah): Remove?\n\n/**\n * Function manifest file.\n */\nexport const FunctionManifestSchema = Schema.Struct({\n functions: Schema.optional(Schema.mutable(Schema.Array(RawObject(FunctionType)))),\n triggers: Schema.optional(Schema.mutable(Schema.Array(RawObject(FunctionTrigger)))),\n});\nexport type FunctionManifest = Schema.Schema.Type<typeof FunctionManifestSchema>;\n\nexport const FUNCTION_TYPES = [FunctionType, FunctionTrigger];\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type ObjectMeta } from '@dxos/echo-schema';\nimport { type SpaceId } from '@dxos/keys';\n\n// TODO: use URL scheme for source?\nconst FUNCTIONS_META_KEY = 'dxos.org/service/function';\n\nexport const FUNCTIONS_PRESET_META_KEY = 'dxos.org/service/function-preset';\n\nconst isSecure = (protocol: string) => {\n return protocol === 'https:' || protocol === 'wss:';\n};\n\nexport const getUserFunctionUrlInMetadata = (meta: ObjectMeta) => {\n return meta.keys.find((key) => key.source === FUNCTIONS_META_KEY)?.id;\n};\n\nexport const setUserFunctionUrlInMetadata = (meta: ObjectMeta, functionUrl: string) => {\n const key = meta.keys.find((key) => key.source === FUNCTIONS_META_KEY);\n if (key) {\n if (key.id !== functionUrl) {\n throw new Error('Metadata mismatch');\n }\n } else {\n meta.keys.push({ source: FUNCTIONS_META_KEY, id: functionUrl });\n }\n};\n\n/**\n * NOTE: functionId is backend ID, not ECHO object id.\n */\nexport const makeFunctionUrl = (fn: { functionId: string }) => `/${fn.functionId}`;\n\nexport const 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\nexport type InvocationOptions = {\n spaceId?: SpaceId;\n subjectId?: string;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Effect, Schema } from 'effect';\n\nimport type { SpaceId } from '@dxos/client/echo';\nimport { runAndForwardErrors } from '@dxos/effect';\n\nimport type { FunctionContext, FunctionDefinition } from '../handler';\nimport type { ServiceContainer, Services } from '../services';\n\nexport class FunctionExecutor {\n constructor(private readonly _services: ServiceContainer) {}\n\n // TODO(dmaretskyi): Invocation context: queue, space, etc...\n async invoke<F extends FunctionDefinition<any, any>>(\n fnDef: F,\n input: F extends FunctionDefinition<infer I, infer _O> ? I : never,\n ): Promise<F extends FunctionDefinition<infer _I, infer O> ? O : never> {\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: this._services.getService.bind(this._services),\n getSpace: async (_spaceId: SpaceId) => {\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 const result = fnDef.handler({ context, data: input });\n\n let data: unknown;\n if (Effect.isEffect(result)) {\n data = await (result as Effect.Effect<unknown, unknown, Services>).pipe(\n Effect.provide(this._services.createLayer()),\n runAndForwardErrors,\n );\n } else {\n data = await result;\n }\n\n // Assert output matches schema\n const assertOutput = fnDef.outputSchema?.pipe(Schema.asserts);\n (assertOutput as any)(data);\n\n return data as any;\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["Schema", "defineFunction", "params", "Schema", "isSchema", "inputSchema", "Error", "handler", "description", "outputSchema", "Any", "Schema", "Type", "JsonSchemaType", "LabelAnnotation", "Ref", "DataType", "ScriptType", "Schema", "Struct", "name", "optional", "String", "description", "changed", "Boolean", "source", "Ref", "DataType", "Text", "pipe", "Type", "Obj", "typename", "version", "LabelAnnotation", "set", "FunctionType", "NonEmptyString", "inputSchema", "JsonSchemaType", "outputSchema", "binding", "Schema", "Type", "Queue", "ObjectId", "log", "Schema", "SchemaAST", "Expando", "OptionsAnnotationId", "TypedObject", "Ref", "RawObject", "DXN", "TriggerKind", "kindLiteralAnnotations", "title", "TimerTriggerSchema", "Schema", "Struct", "kind", "Literal", "annotations", "cron", "String", "SchemaAST", "ExamplesAnnotationId", "pipe", "mutable", "EmailTriggerSchema", "QueueTriggerSchema", "queue", "DXN", "WebhookTriggerSchema", "method", "optional", "OptionsAnnotationId", "port", "Number", "QuerySchema", "type", "props", "Record", "key", "value", "Any", "SubscriptionTriggerSchema", "filter", "options", "deep", "Boolean", "delay", "TriggerSchema", "Union", "EmailTriggerOutput", "from", "to", "subject", "created", "body", "WebhookTriggerOutput", "url", "headers", "bodyText", "QueueTriggerOutput", "item", "cursor", "SubscriptionTriggerOutput", "changedObjectId", "TimerTriggerOutput", "tick", "FunctionTriggerSchema", "function", "Ref", "Expando", "inputNodeId", "enabled", "spec", "input", "FunctionTrigger", "TypedObject", "typename", "version", "fields", "FunctionManifestSchema", "functions", "Array", "RawObject", "FunctionType", "triggers", "FUNCTION_TYPES", "InvocationOutcome", "InvocationTraceEventType", "TraceEventException", "Schema", "Struct", "timestampMs", "Number", "message", "String", "name", "stack", "optional", "InvocationTraceStartEvent", "id", "ObjectId", "type", "Literal", "invocationId", "input", "Object", "invocationTraceQueue", "Type", "Ref", "Queue", "invocationTarget", "Expando", "trigger", "FunctionTrigger", "pipe", "Obj", "typename", "version", "InvocationTraceEndEvent", "outcome", "Enums", "exception", "TraceEventLog", "level", "context", "TraceEvent", "truncated", "Boolean", "ingestionTimestampMs", "logs", "Array", "exceptions", "createInvocationSpans", "items", "eventsByInvocationId", "Map", "event", "entry", "get", "start", "undefined", "end", "set", "now", "Date", "result", "entries", "log", "warn", "isInProgress", "push", "durationMs", "FUNCTIONS_META_KEY", "FUNCTIONS_PRESET_META_KEY", "isSecure", "protocol", "getUserFunctionUrlInMetadata", "meta", "keys", "find", "key", "source", "id", "setUserFunctionUrlInMetadata", "functionUrl", "Error", "push", "makeFunctionUrl", "fn", "functionId", "getInvocationUrl", "edgeUrl", "options", "baseUrl", "URL", "relativeUrl", "replace", "url", "toString", "spaceId", "searchParams", "set", "subjectId", "Effect", "Schema", "runAndForwardErrors", "FunctionExecutor", "_services", "invoke", "fnDef", "input", "assertInput", "inputSchema", "pipe", "Schema", "asserts", "context", "getService", "bind", "getSpace", "_spaceId", "Error", "space", "undefined", "ai", "result", "handler", "data", "Effect", "isEffect", "provide", "createLayer", "runAndForwardErrors", "assertOutput", "outputSchema"]
3
+ "sources": ["../../../src/handler.ts", "../../../src/schema.ts", "../../../src/trace.ts", "../../../src/types.ts", "../../../src/url.ts", "../../../src/executor/executor.ts", "../../../src/errors.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Schema, type Context, type Effect } from 'effect';\n\nimport { type AiServiceClient } from '@dxos/ai';\n// import { type Space } from '@dxos/client/echo';\nimport type { EchoDatabase } from '@dxos/echo-db';\nimport { type HasId } from '@dxos/echo-schema';\nimport { type SpaceId, type DXN } from '@dxos/keys';\nimport { type QueryResult } from '@dxos/protocols';\n\nimport type { Services } from './services';\n\n// TODO(burdon): Model after http request. Ref Lambda/OpenFaaS.\n// https://docs.aws.amazon.com/lambda/latest/dg/typescript-handler.html\n// https://www.serverless.com/framework/docs/providers/aws/guide/serverless.yml/#functions\n// https://www.npmjs.com/package/aws-lambda\n\n/**\n * Function handler.\n */\nexport type FunctionHandler<TData = {}, TOutput = any> = (params: {\n /**\n * Services and context available to the function.\n */\n context: FunctionContext;\n\n /**\n * Data passed as the input to the function.\n * Must match the function's input schema.\n * This will be the payload from the trigger or other data passed into the function in a workflow.\n */\n data: TData;\n}) => TOutput | Promise<TOutput> | Effect.Effect<TOutput, any, Services>;\n\n/**\n * Function context.\n */\nexport interface FunctionContext {\n /**\n * Space from which the function was invoked.\n */\n space: SpaceAPI | undefined;\n\n ai: AiServiceClient;\n\n /**\n * Resolves a service available to the function.\n * @throws if the service is not available.\n */\n getService: <T extends Context.Tag<any, any>>(tag: T) => Context.Tag.Service<T>;\n\n getSpace: (spaceId: SpaceId) => Promise<SpaceAPI>;\n}\n\nexport interface FunctionContextAi {\n // TODO(dmaretskyi): Refer to cloudflare AI docs for more comprehensive typedefs.\n run(model: string, inputs: any, options?: any): Promise<any>;\n}\n\n//\n// API.\n//\n\n// TODO(dmaretskyi): Temporary API to get the queues working.\n// TODO(dmaretskyi): To be replaced with integrating queues into echo.\nexport interface QueuesAPI {\n queryQueue(queue: DXN, options?: {}): Promise<QueryResult>;\n insertIntoQueue(queue: DXN, objects: HasId[]): Promise<void>;\n}\n\n/**\n * Space interface available to functions.\n */\nexport interface SpaceAPI {\n get id(): SpaceId;\n get db(): EchoDatabase;\n\n // TODO(dmaretskyi): Align with echo api: queues.get(id).append(items);\n get queues(): QueuesAPI;\n}\n\n// TODO(wittjosiah): Queues are incompatible.\nconst __assertFunctionSpaceIsCompatibleWithTheClientSpace = () => {\n // const _: SpaceAPI = {} as Space;\n};\n\nexport type FunctionDefinition<T = {}, O = any> = {\n name: string;\n description?: string;\n inputSchema: Schema.Schema<T, any>;\n outputSchema?: Schema.Schema<O, any>;\n handler: FunctionHandler<T, O>;\n};\n\n// TODO(dmaretskyi): Bind input type to function handler.\nexport const defineFunction = <T, O>({\n name,\n description,\n inputSchema,\n outputSchema = Schema.Any,\n handler,\n}: FunctionDefinition<T, O>): FunctionDefinition<T, O> => {\n if (!Schema.isSchema(inputSchema)) {\n throw new Error('Input schema must be a valid schema');\n }\n if (typeof handler !== 'function') {\n throw new Error('Handler must be a function');\n }\n\n return {\n name,\n description,\n inputSchema,\n outputSchema,\n handler,\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { Type } from '@dxos/echo';\nimport { JsonSchemaType, LabelAnnotation, Ref } from '@dxos/echo-schema';\nimport { DataType } from '@dxos/schema';\n\n/**\n * Source script.\n */\nexport const ScriptType = Schema.Struct({\n name: Schema.optional(Schema.String),\n description: Schema.optional(Schema.String),\n // TODO(burdon): Change to hash of deployed content.\n // Whether source has changed since last deploy.\n changed: Schema.optional(Schema.Boolean),\n source: Ref(DataType.Text),\n}).pipe(\n Type.Obj({\n typename: 'dxos.org/type/Script',\n version: '0.1.0',\n }),\n LabelAnnotation.set(['name']),\n);\n\nexport interface ScriptType extends Schema.Schema.Type<typeof ScriptType> {}\n\n/**\n * Function deployment.\n */\nexport const FunctionType = Schema.Struct({\n // TODO(burdon): Rename to id/uri?\n name: Schema.NonEmptyString,\n version: Schema.String,\n\n description: Schema.optional(Schema.String),\n\n // Reference to a source script if it exists within ECHO.\n // TODO(burdon): Don't ref ScriptType directly (core).\n source: Schema.optional(Ref(ScriptType)),\n\n inputSchema: Schema.optional(JsonSchemaType),\n outputSchema: Schema.optional(JsonSchemaType),\n\n // Local binding to a function name.\n binding: Schema.optional(Schema.String),\n}).pipe(\n Type.Obj({\n typename: 'dxos.org/type/Function',\n version: '0.1.0',\n }),\n LabelAnnotation.set(['name']),\n);\nexport interface FunctionType extends Schema.Schema.Type<typeof FunctionType> {}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { Type, type Ref } from '@dxos/echo';\nimport { Queue } from '@dxos/echo-db';\nimport { ObjectId } from '@dxos/echo-schema';\nimport { log } from '@dxos/log';\n\nimport { FunctionTrigger, type FunctionTriggerType } from './types';\n\nexport enum InvocationOutcome {\n SUCCESS = 'success',\n FAILURE = 'failure',\n PENDING = 'pending',\n}\n\n// TODO(burdon): Convert to extensible discriminated union of EDGE events.\nexport enum InvocationTraceEventType {\n START = 'start',\n END = 'end',\n}\n\nexport const TraceEventException = Schema.Struct({\n timestampMs: Schema.Number,\n message: Schema.String,\n name: Schema.String,\n stack: Schema.optional(Schema.String),\n});\nexport type TraceEventException = Schema.Schema.Type<typeof TraceEventException>;\n\nexport const InvocationTraceStartEvent = Schema.Struct({\n /**\n * Queue message id.\n */\n id: ObjectId,\n type: Schema.Literal(InvocationTraceEventType.START),\n /**\n * Invocation id, the same for invocation start and end events.\n */\n invocationId: ObjectId,\n /**\n * Event generation time.\n */\n timestampMs: Schema.Number,\n /**\n * Data passed to function / workflow as an argument.\n */\n // TODO(burdon): Input schema?\n input: Schema.Object,\n /**\n * Queue for function/workflow invocation events.\n */\n invocationTraceQueue: Type.Ref(Queue),\n /**\n * DXN of the invoked function/workflow.\n */\n invocationTarget: Type.Ref(Type.Expando),\n /**\n * Present for automatic invocations.\n */\n trigger: Schema.optional(Type.Ref(FunctionTrigger)),\n}).pipe(Type.Obj({ typename: 'dxos.org/type/InvocationTraceStart', version: '0.1.0' }));\n\nexport type InvocationTraceStartEvent = Schema.Schema.Type<typeof InvocationTraceStartEvent>;\n\nexport const InvocationTraceEndEvent = Schema.Struct({\n /**\n * Trace event id.\n */\n id: ObjectId,\n type: Schema.Literal(InvocationTraceEventType.END),\n /**\n * Invocation id, will be the same for invocation start and end.\n */\n invocationId: ObjectId,\n /**\n * Event generation time.\n */\n // TODO(burdon): Remove ms suffix.\n timestampMs: Schema.Number,\n outcome: Schema.Enums(InvocationOutcome),\n exception: Schema.optional(TraceEventException),\n}).pipe(Type.Obj({ typename: 'dxos.org/type/InvocationTraceEnd', version: '0.1.0' }));\n\nexport type InvocationTraceEndEvent = Schema.Schema.Type<typeof InvocationTraceEndEvent>;\n\nexport type InvocationTraceEvent = InvocationTraceStartEvent | InvocationTraceEndEvent;\n\nexport const TraceEventLog = Schema.Struct({\n timestampMs: Schema.Number,\n level: Schema.String,\n message: Schema.String,\n context: Schema.optional(Schema.Object),\n});\n\nexport const TraceEvent = Schema.Struct({\n id: ObjectId,\n // TODO(burdon): Need enum/numeric result (not string).\n outcome: Schema.String,\n truncated: Schema.Boolean,\n /**\n * Time when the event was persisted.\n */\n ingestionTimestampMs: Schema.Number,\n logs: Schema.Array(TraceEventLog),\n exceptions: Schema.Array(TraceEventException),\n}).pipe(Type.Obj({ typename: 'dxos.org/type/TraceEvent', version: '0.1.0' }));\n\nexport type TraceEvent = Schema.Schema.Type<typeof TraceEvent>;\n\n/**\n * InvocationTrace event format.\n * This is the combined format of InvocationTraceStartEvent and InvocationTraceEndEvents for UI consumption.\n */\nexport type InvocationSpan = {\n id: string;\n timestampMs: number;\n outcome: InvocationOutcome;\n input: object;\n durationMs: number;\n invocationTraceQueue: Ref.Ref<Queue>;\n invocationTarget: Ref.Ref<Type.Expando>;\n trigger?: Ref.Ref<FunctionTriggerType>;\n exception?: TraceEventException;\n};\n\nexport const createInvocationSpans = (items?: InvocationTraceEvent[]): InvocationSpan[] => {\n if (!items) {\n return [];\n }\n\n const eventsByInvocationId = new Map<string, { start?: InvocationTraceStartEvent; end?: InvocationTraceEndEvent }>();\n for (const event of items) {\n if (!('invocationId' in event)) {\n // Skip legacy format entries.\n continue;\n }\n\n const invocationId = event.invocationId;\n const entry = eventsByInvocationId.get(invocationId) || { start: undefined, end: undefined };\n if (event.type === InvocationTraceEventType.START) {\n entry.start = event as InvocationTraceStartEvent;\n } else if (event.type === InvocationTraceEventType.END) {\n entry.end = event as InvocationTraceEndEvent;\n }\n\n eventsByInvocationId.set(invocationId, entry);\n }\n\n const now = Date.now();\n const result: InvocationSpan[] = [];\n\n // Create spans for each invocation\n for (const [invocationId, { start, end }] of eventsByInvocationId.entries()) {\n if (!start) {\n // No start event, can't create a meaningful span\n log.warn('found end event without matching start', { invocationId });\n continue;\n }\n\n const isInProgress = end === undefined;\n\n result.push({\n id: invocationId,\n timestampMs: start.timestampMs,\n durationMs: isInProgress ? now - start.timestampMs : end!.timestampMs - start.timestampMs,\n outcome: end?.outcome ?? InvocationOutcome.PENDING,\n exception: end?.exception,\n input: start.input,\n invocationTraceQueue: start.invocationTraceQueue,\n invocationTarget: start.invocationTarget,\n trigger: start.trigger,\n });\n }\n\n return result;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Schema, SchemaAST } from 'effect';\n\nimport { Expando, OptionsAnnotationId, TypedObject, Ref, RawObject } from '@dxos/echo-schema';\nimport { DXN } from '@dxos/keys';\n\nimport { FunctionType } from './schema';\n\n/**\n * Type discriminator for TriggerType.\n * Every spec has a type field of type TriggerKind that we can use to understand which type we're working with.\n * https://www.typescriptlang.org/docs/handbook/2/narrowing.html#discriminated-unions\n */\nexport enum TriggerKind {\n Timer = 'timer',\n Webhook = 'webhook',\n Subscription = 'subscription',\n Email = 'email',\n Queue = 'queue',\n}\n\nconst kindLiteralAnnotations = { title: 'Kind' };\n\n/**\n * Cron timer.\n */\nconst TimerTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Timer).annotations(kindLiteralAnnotations),\n cron: Schema.String.annotations({\n title: 'Cron',\n [SchemaAST.ExamplesAnnotationId]: ['0 0 * * *'],\n }),\n}).pipe(Schema.mutable);\nexport type TimerTrigger = Schema.Schema.Type<typeof TimerTriggerSchema>;\n\nconst EmailTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Email).annotations(kindLiteralAnnotations),\n}).pipe(Schema.mutable);\nexport type EmailTrigger = Schema.Schema.Type<typeof EmailTriggerSchema>;\n\nconst QueueTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Queue).annotations(kindLiteralAnnotations),\n queue: DXN.Schema,\n}).pipe(Schema.mutable);\nexport type QueueTrigger = Schema.Schema.Type<typeof QueueTriggerSchema>;\n\n/**\n * Webhook.\n */\nconst WebhookTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Webhook).annotations(kindLiteralAnnotations),\n method: Schema.optional(\n Schema.String.annotations({\n title: 'Method',\n [OptionsAnnotationId]: ['GET', 'POST'],\n }),\n ),\n port: Schema.optional(\n Schema.Number.annotations({\n title: 'Port',\n }),\n ),\n}).pipe(Schema.mutable);\nexport type WebhookTrigger = Schema.Schema.Type<typeof WebhookTriggerSchema>;\n\n// TODO(burdon): Use ECHO definition (from https://github.com/dxos/dxos/pull/8233).\nconst QuerySchema = Schema.Struct({\n type: Schema.optional(Schema.String.annotations({ title: 'Type' })),\n props: Schema.optional(Schema.Record({ key: Schema.String, value: Schema.Any })),\n}).annotations({ title: 'Query' });\n\n/**\n * Subscription.\n */\nconst SubscriptionTriggerSchema = Schema.Struct({\n kind: Schema.Literal(TriggerKind.Subscription).annotations(kindLiteralAnnotations),\n // TODO(burdon): Define query DSL (from ECHO). Reconcile with Table.Query.\n filter: QuerySchema,\n options: Schema.optional(\n Schema.Struct({\n // Watch changes to object (not just creation).\n deep: Schema.optional(Schema.Boolean.annotations({ title: 'Nested' })),\n // Debounce changes (delay in ms).\n delay: Schema.optional(Schema.Number.annotations({ title: 'Delay' })),\n }).annotations({ title: 'Options' }),\n ),\n}).pipe(Schema.mutable);\nexport type SubscriptionTrigger = Schema.Schema.Type<typeof SubscriptionTriggerSchema>;\n\n/**\n * Trigger schema (discriminated union).\n */\nexport const TriggerSchema = Schema.Union(\n TimerTriggerSchema,\n WebhookTriggerSchema,\n SubscriptionTriggerSchema,\n EmailTriggerSchema,\n QueueTriggerSchema,\n).annotations({\n title: 'Trigger',\n});\nexport type TriggerType = Schema.Schema.Type<typeof TriggerSchema>;\n\nexport type EventType =\n | EmailTriggerOutput\n | WebhookTriggerOutput\n | QueueTriggerOutput\n | SubscriptionTriggerOutput\n | TimerTriggerOutput;\n\n// TODO(burdon): Reuse trigger schema from @dxos/functions (TriggerType).\nexport const EmailTriggerOutput = Schema.mutable(\n Schema.Struct({\n from: Schema.String,\n to: Schema.String,\n subject: Schema.String,\n created: Schema.String,\n body: Schema.String,\n }),\n);\nexport type EmailTriggerOutput = Schema.Schema.Type<typeof EmailTriggerOutput>;\n\nexport const WebhookTriggerOutput = Schema.mutable(\n Schema.Struct({\n url: Schema.String,\n method: Schema.Literal('GET', 'POST'),\n headers: Schema.Record({ key: Schema.String, value: Schema.String }),\n bodyText: Schema.String,\n }),\n);\nexport type WebhookTriggerOutput = Schema.Schema.Type<typeof WebhookTriggerOutput>;\n\nexport const QueueTriggerOutput = Schema.mutable(\n Schema.Struct({\n queue: DXN.Schema,\n item: Schema.Any,\n cursor: Schema.String,\n }),\n);\nexport type QueueTriggerOutput = Schema.Schema.Type<typeof QueueTriggerOutput>;\n\nexport const SubscriptionTriggerOutput = Schema.mutable(\n Schema.Struct({ type: Schema.String, changedObjectId: Schema.String }),\n);\nexport type SubscriptionTriggerOutput = Schema.Schema.Type<typeof SubscriptionTriggerOutput>;\n\nexport const TimerTriggerOutput = Schema.mutable(Schema.Struct({ tick: Schema.Number }));\nexport type TimerTriggerOutput = Schema.Schema.Type<typeof TimerTriggerOutput>;\n\n/**\n * Function trigger.\n * Function is invoked with the `payload` passed as input data.\n * The event that triggers the function is available in the function context.\n */\nexport const FunctionTriggerSchema = Schema.Struct({\n /**\n * Function or workflow to invoke.\n */\n // TODO(dmaretskyi): Can be a Ref(FunctionType) or Ref(ComputeGraphType).\n function: Schema.optional(Ref(Expando).annotations({ title: 'Function' })),\n\n /**\n * Only used for workflowSchema.\n * Specifies the input node in the circuit.\n * @deprecated Remove and enforce a single input node in all compute graphSchema.\n */\n inputNodeId: Schema.optional(Schema.String.annotations({ title: 'Input Node ID' })),\n\n enabled: Schema.optional(Schema.Boolean.annotations({ title: 'Enabled' })),\n\n spec: Schema.optional(TriggerSchema),\n\n /**\n * Passed as the input data to the function.\n * Must match the function's input schema.\n *\n * @example\n * {\n * item: '{{$.trigger.event}}',\n * instructions: 'Summarize and perform entity-extraction'\n * mailbox: { '/': 'dxn:echo:AAA:ZZZ' }\n * }\n */\n input: Schema.optional(Schema.mutable(Schema.Record({ key: Schema.String, value: Schema.Any }))),\n});\n\nexport type FunctionTriggerType = Schema.Schema.Type<typeof FunctionTriggerSchema>;\n\n/**\n * Function trigger.\n */\nexport class FunctionTrigger extends TypedObject({\n typename: 'dxos.org/type/FunctionTrigger',\n version: '0.2.0',\n})(FunctionTriggerSchema.fields) {}\n\n// TODO(wittjosiah): Remove?\n\n/**\n * Function manifest file.\n */\nexport const FunctionManifestSchema = Schema.Struct({\n functions: Schema.optional(Schema.mutable(Schema.Array(RawObject(FunctionType)))),\n triggers: Schema.optional(Schema.mutable(Schema.Array(RawObject(FunctionTrigger)))),\n});\nexport type FunctionManifest = Schema.Schema.Type<typeof FunctionManifestSchema>;\n\nexport const FUNCTION_TYPES = [FunctionType, FunctionTrigger];\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type ObjectMeta } from '@dxos/echo-schema';\nimport { type SpaceId } from '@dxos/keys';\n\n// TODO: use URL scheme for source?\nconst FUNCTIONS_META_KEY = 'dxos.org/service/function';\n\nexport const FUNCTIONS_PRESET_META_KEY = 'dxos.org/service/function-preset';\n\nconst isSecure = (protocol: string) => {\n return protocol === 'https:' || protocol === 'wss:';\n};\n\nexport const getUserFunctionUrlInMetadata = (meta: ObjectMeta) => {\n return meta.keys.find((key) => key.source === FUNCTIONS_META_KEY)?.id;\n};\n\nexport const setUserFunctionUrlInMetadata = (meta: ObjectMeta, functionUrl: string) => {\n const key = meta.keys.find((key) => key.source === FUNCTIONS_META_KEY);\n if (key) {\n if (key.id !== functionUrl) {\n throw new Error('Metadata mismatch');\n }\n } else {\n meta.keys.push({ source: FUNCTIONS_META_KEY, id: functionUrl });\n }\n};\n\n/**\n * NOTE: functionId is backend ID, not ECHO object id.\n */\nexport const makeFunctionUrl = (fn: { functionId: string }) => `/${fn.functionId}`;\n\nexport const 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\nexport type InvocationOptions = {\n spaceId?: SpaceId;\n subjectId?: string;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Effect, Schema } from 'effect';\n\nimport type { SpaceId } from '@dxos/client/echo';\nimport { runAndForwardErrors } from '@dxos/effect';\n\nimport type { FunctionContext, FunctionDefinition } from '../handler';\nimport type { ServiceContainer, Services } from '../services';\n\nexport class FunctionExecutor {\n constructor(private readonly _services: ServiceContainer) {}\n\n // TODO(dmaretskyi): Invocation context: queue, space, etc...\n async invoke<F extends FunctionDefinition<any, any>>(\n fnDef: F,\n input: F extends FunctionDefinition<infer I, infer _O> ? I : never,\n ): Promise<F extends FunctionDefinition<infer _I, infer O> ? O : never> {\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: this._services.getService.bind(this._services),\n getSpace: async (_spaceId: SpaceId) => {\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 const result = fnDef.handler({ context, data: input });\n\n let data: unknown;\n if (Effect.isEffect(result)) {\n data = await (result as Effect.Effect<unknown, unknown, Services>).pipe(\n Effect.provide(this._services.createLayer()),\n runAndForwardErrors,\n );\n } else {\n data = await result;\n }\n\n // Assert output matches schema\n const assertOutput = fnDef.outputSchema?.pipe(Schema.asserts);\n (assertOutput as any)(data);\n\n return data as any;\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"],
5
+ "mappings": "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",
6
+ "names": ["Schema", "defineFunction", "name", "description", "inputSchema", "outputSchema", "Schema", "Any", "handler", "isSchema", "Error", "Schema", "Type", "JsonSchemaType", "LabelAnnotation", "Ref", "DataType", "ScriptType", "Schema", "Struct", "name", "optional", "String", "description", "changed", "Boolean", "source", "Ref", "DataType", "Text", "pipe", "Type", "Obj", "typename", "version", "LabelAnnotation", "set", "FunctionType", "NonEmptyString", "inputSchema", "JsonSchemaType", "outputSchema", "binding", "Schema", "Type", "Queue", "ObjectId", "log", "Schema", "SchemaAST", "Expando", "OptionsAnnotationId", "TypedObject", "Ref", "RawObject", "DXN", "TriggerKind", "kindLiteralAnnotations", "title", "TimerTriggerSchema", "Schema", "Struct", "kind", "Literal", "annotations", "cron", "String", "SchemaAST", "ExamplesAnnotationId", "pipe", "mutable", "EmailTriggerSchema", "QueueTriggerSchema", "queue", "DXN", "WebhookTriggerSchema", "method", "optional", "OptionsAnnotationId", "port", "Number", "QuerySchema", "type", "props", "Record", "key", "value", "Any", "SubscriptionTriggerSchema", "filter", "options", "deep", "Boolean", "delay", "TriggerSchema", "Union", "EmailTriggerOutput", "from", "to", "subject", "created", "body", "WebhookTriggerOutput", "url", "headers", "bodyText", "QueueTriggerOutput", "item", "cursor", "SubscriptionTriggerOutput", "changedObjectId", "TimerTriggerOutput", "tick", "FunctionTriggerSchema", "function", "Ref", "Expando", "inputNodeId", "enabled", "spec", "input", "FunctionTrigger", "TypedObject", "typename", "version", "fields", "FunctionManifestSchema", "functions", "Array", "RawObject", "FunctionType", "triggers", "FUNCTION_TYPES", "InvocationOutcome", "InvocationTraceEventType", "TraceEventException", "Schema", "Struct", "timestampMs", "Number", "message", "String", "name", "stack", "optional", "InvocationTraceStartEvent", "id", "ObjectId", "type", "Literal", "invocationId", "input", "Object", "invocationTraceQueue", "Type", "Ref", "Queue", "invocationTarget", "Expando", "trigger", "FunctionTrigger", "pipe", "Obj", "typename", "version", "InvocationTraceEndEvent", "outcome", "Enums", "exception", "TraceEventLog", "level", "context", "TraceEvent", "truncated", "Boolean", "ingestionTimestampMs", "logs", "Array", "exceptions", "createInvocationSpans", "items", "eventsByInvocationId", "Map", "event", "entry", "get", "start", "undefined", "end", "set", "now", "Date", "result", "entries", "log", "warn", "isInProgress", "push", "durationMs", "FUNCTIONS_META_KEY", "FUNCTIONS_PRESET_META_KEY", "isSecure", "protocol", "getUserFunctionUrlInMetadata", "meta", "keys", "find", "key", "source", "id", "setUserFunctionUrlInMetadata", "functionUrl", "Error", "push", "makeFunctionUrl", "fn", "functionId", "getInvocationUrl", "edgeUrl", "options", "baseUrl", "URL", "relativeUrl", "replace", "url", "toString", "spaceId", "searchParams", "set", "subjectId", "Effect", "Schema", "runAndForwardErrors", "FunctionExecutor", "_services", "invoke", "fnDef", "input", "assertInput", "inputSchema", "pipe", "Schema", "asserts", "context", "getService", "bind", "getSpace", "_spaceId", "Error", "space", "undefined", "ai", "result", "handler", "data", "Effect", "isEffect", "provide", "createLayer", "runAndForwardErrors", "assertOutput", "outputSchema", "BaseError", "ServiceNotAvailableError", "BaseError", "extend", "serviceName", "FunctionError"]
7
7
  }