@dxos/functions 0.8.4-main.5acf9ea → 0.8.4-main.5ea62a8

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 (100) hide show
  1. package/dist/lib/browser/bundler/index.mjs +54 -38
  2. package/dist/lib/browser/bundler/index.mjs.map +3 -3
  3. package/dist/lib/browser/chunk-7NQ77AIQ.mjs +618 -0
  4. package/dist/lib/browser/chunk-7NQ77AIQ.mjs.map +7 -0
  5. package/dist/lib/browser/edge/index.mjs +20 -8
  6. package/dist/lib/browser/edge/index.mjs.map +3 -3
  7. package/dist/lib/browser/index.mjs +141 -77
  8. package/dist/lib/browser/index.mjs.map +4 -4
  9. package/dist/lib/browser/meta.json +1 -1
  10. package/dist/lib/browser/testing/index.mjs +68 -5
  11. package/dist/lib/browser/testing/index.mjs.map +3 -3
  12. package/dist/lib/node-esm/bundler/index.mjs +54 -38
  13. package/dist/lib/node-esm/bundler/index.mjs.map +3 -3
  14. package/dist/lib/node-esm/chunk-KCGC6QQT.mjs +620 -0
  15. package/dist/lib/node-esm/chunk-KCGC6QQT.mjs.map +7 -0
  16. package/dist/lib/node-esm/edge/index.mjs +20 -8
  17. package/dist/lib/node-esm/edge/index.mjs.map +3 -3
  18. package/dist/lib/node-esm/index.mjs +141 -77
  19. package/dist/lib/node-esm/index.mjs.map +4 -4
  20. package/dist/lib/node-esm/meta.json +1 -1
  21. package/dist/lib/node-esm/testing/index.mjs +68 -5
  22. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  23. package/dist/types/src/bundler/bundler.d.ts +11 -12
  24. package/dist/types/src/bundler/bundler.d.ts.map +1 -1
  25. package/dist/types/src/edge/functions.d.ts +3 -2
  26. package/dist/types/src/edge/functions.d.ts.map +1 -1
  27. package/dist/types/src/errors.d.ts +10 -8
  28. package/dist/types/src/errors.d.ts.map +1 -1
  29. package/dist/types/src/examples/fib.d.ts +7 -0
  30. package/dist/types/src/examples/fib.d.ts.map +1 -0
  31. package/dist/types/src/examples/reply.d.ts +3 -0
  32. package/dist/types/src/examples/reply.d.ts.map +1 -0
  33. package/dist/types/src/examples/sleep.d.ts +5 -0
  34. package/dist/types/src/examples/sleep.d.ts.map +1 -0
  35. package/dist/types/src/executor/executor.d.ts +4 -1
  36. package/dist/types/src/executor/executor.d.ts.map +1 -1
  37. package/dist/types/src/handler.d.ts +10 -7
  38. package/dist/types/src/handler.d.ts.map +1 -1
  39. package/dist/types/src/schema.d.ts +7 -2
  40. package/dist/types/src/schema.d.ts.map +1 -1
  41. package/dist/types/src/services/credentials.d.ts +15 -3
  42. package/dist/types/src/services/credentials.d.ts.map +1 -1
  43. package/dist/types/src/services/database.d.ts +74 -6
  44. package/dist/types/src/services/database.d.ts.map +1 -1
  45. package/dist/types/src/services/event-logger.d.ts +1 -1
  46. package/dist/types/src/services/event-logger.d.ts.map +1 -1
  47. package/dist/types/src/services/local-function-execution.d.ts +2 -1
  48. package/dist/types/src/services/local-function-execution.d.ts.map +1 -1
  49. package/dist/types/src/services/queues.d.ts +18 -5
  50. package/dist/types/src/services/queues.d.ts.map +1 -1
  51. package/dist/types/src/services/remote-function-execution-service.d.ts.map +1 -1
  52. package/dist/types/src/services/service-container.d.ts +1 -1
  53. package/dist/types/src/services/service-container.d.ts.map +1 -1
  54. package/dist/types/src/services/service-registry.d.ts.map +1 -1
  55. package/dist/types/src/services/tracing.d.ts +33 -3
  56. package/dist/types/src/services/tracing.d.ts.map +1 -1
  57. package/dist/types/src/testing/layer.d.ts +6 -2
  58. package/dist/types/src/testing/layer.d.ts.map +1 -1
  59. package/dist/types/src/testing/logger.d.ts.map +1 -1
  60. package/dist/types/src/testing/persist-database.test.d.ts +2 -0
  61. package/dist/types/src/testing/persist-database.test.d.ts.map +1 -0
  62. package/dist/types/src/testing/services.d.ts +1 -1
  63. package/dist/types/src/testing/services.d.ts.map +1 -1
  64. package/dist/types/src/trace.d.ts +34 -8
  65. package/dist/types/src/trace.d.ts.map +1 -1
  66. package/dist/types/src/types.d.ts +141 -224
  67. package/dist/types/src/types.d.ts.map +1 -1
  68. package/dist/types/src/url.d.ts +10 -6
  69. package/dist/types/src/url.d.ts.map +1 -1
  70. package/dist/types/tsconfig.tsbuildinfo +1 -1
  71. package/package.json +40 -39
  72. package/src/bundler/bundler.test.ts +8 -9
  73. package/src/bundler/bundler.ts +32 -33
  74. package/src/edge/functions.ts +8 -5
  75. package/src/examples/fib.ts +30 -0
  76. package/src/examples/reply.ts +18 -0
  77. package/src/examples/sleep.ts +22 -0
  78. package/src/executor/executor.ts +9 -9
  79. package/src/handler.ts +12 -10
  80. package/src/schema.ts +11 -0
  81. package/src/services/credentials.ts +78 -5
  82. package/src/services/database.ts +114 -18
  83. package/src/services/event-logger.ts +2 -2
  84. package/src/services/local-function-execution.ts +20 -13
  85. package/src/services/queues.ts +29 -10
  86. package/src/services/remote-function-execution-service.ts +2 -22
  87. package/src/services/service-container.ts +4 -3
  88. package/src/services/service-registry.ts +1 -1
  89. package/src/services/tracing.ts +95 -5
  90. package/src/testing/layer.ts +69 -3
  91. package/src/testing/logger.ts +1 -1
  92. package/src/testing/persist-database.test.ts +87 -0
  93. package/src/testing/services.ts +2 -1
  94. package/src/trace.ts +5 -7
  95. package/src/types.ts +17 -25
  96. package/src/url.ts +13 -10
  97. package/dist/lib/browser/chunk-6PTFLPCO.mjs +0 -462
  98. package/dist/lib/browser/chunk-6PTFLPCO.mjs.map +0 -7
  99. package/dist/lib/node-esm/chunk-NYJ2TSXO.mjs +0 -464
  100. package/dist/lib/node-esm/chunk-NYJ2TSXO.mjs.map +0 -7
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/url.ts", "../../../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"],
4
+ "sourcesContent": ["//\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?\nexport const 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\n/**\n * NOTE: functionId is backend ID, not ECHO object id.\n */\nexport const getUserFunctionIdInMetadata = (meta: ObjectMeta) => {\n return meta.keys.find((key) => key.source === FUNCTIONS_META_KEY)?.id;\n};\n\n/**\n * NOTE: functionId is backend ID, not ECHO object id.\n */\nexport const setUserFunctionIdInMetadata = (meta: ObjectMeta, functionId: string) => {\n const key = meta.keys.find((key) => key.source === FUNCTIONS_META_KEY);\n if (key) {\n if (key.id !== functionId) {\n throw new Error('Metadata mismatch');\n }\n } else {\n meta.keys.push({ source: FUNCTIONS_META_KEY, id: functionId });\n }\n};\n\n/**\n * NOTE: functionId is backend ID, not ECHO object id.\n */\nexport const getInvocationUrl = (functionId: 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 url = new URL(`./${functionId}`, 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 { Context, Effect, Layer, Option, type Schema } from 'effect';\n\nimport { type Filter, type Live, Obj, type Query, type Ref, type Relation, type Type } from '@dxos/echo';\nimport type { EchoDatabase, FlushOptions, OneShotQueryResult, QueryResult, SchemaRegistryQuery } from '@dxos/echo-db';\nimport type { SchemaRegistryPreparedQuery } from '@dxos/echo-db';\nimport type { EchoSchema } from '@dxos/echo-schema';\nimport { promiseWithCauseCapture } from '@dxos/effect';\nimport { BaseError } from '@dxos/errors';\nimport { invariant } from '@dxos/invariant';\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 layer = (db: EchoDatabase): Layer.Layer<DatabaseService> => {\n return Layer.succeed(DatabaseService, DatabaseService.make(db));\n };\n\n /**\n * Resolves an object by its DXN.\n */\n static resolve: {\n // No type check.\n (dxn: DXN): Effect.Effect<Obj.Any | Relation.Any, never, DatabaseService>;\n // Check matches schema.\n <S extends Type.Obj.Any | Type.Relation.Any>(\n dxn: DXN,\n schema: S,\n ): Effect.Effect<Schema.Schema.Type<S>, ObjectNotFoundError, DatabaseService>;\n } = (<S extends Type.Obj.Any | Type.Relation.Any>(\n dxn: DXN,\n schema?: S,\n ): Effect.Effect<Schema.Schema.Type<S>, ObjectNotFoundError, DatabaseService> =>\n Effect.gen(function* () {\n const { db } = yield* DatabaseService;\n const object = yield* promiseWithCauseCapture(() =>\n db.graph\n .createRefResolver({\n context: {\n space: db.spaceId,\n },\n })\n .resolve(dxn),\n );\n\n if (!object) {\n return yield* Effect.fail(new ObjectNotFoundError({ dxn }));\n }\n invariant(!schema || Obj.instanceOf(schema, object), 'Object type mismatch.');\n return object as any;\n })) as any;\n\n /**\n * Loads an object reference.\n */\n static load: <T>(ref: Ref.Ref<T>) => Effect.Effect<T, ObjectNotFoundError, never> = Effect.fn(function* (ref) {\n const object = yield* promiseWithCauseCapture(() => ref.tryLoad());\n if (!object) {\n return yield* Effect.fail(new ObjectNotFoundError({ dxn: ref.dxn }));\n }\n return object;\n });\n\n /**\n * Loads an object reference option.\n */\n // TODO(burdon): Option?\n static loadOption: <T>(ref: Ref.Ref<T>) => Effect.Effect<Option.Option<T>, never, never> = Effect.fn(function* (ref) {\n const object = yield* DatabaseService.load(ref).pipe(\n Effect.catchTag('OBJECT_NOT_FOUND', () => Effect.succeed(undefined)),\n );\n return Option.fromNullable(object);\n });\n\n // TODO(burdon): Can we create a proxy for the following methods on EchoDatabase? Use @inheritDoc?\n // TODO(burdon): Figure out how to chain query().run();\n\n /**\n * @link EchoDatabase.add\n */\n static add = <T extends Obj.Any | Relation.Any>(obj: T): Effect.Effect<T, never, DatabaseService> =>\n DatabaseService.pipe(Effect.map(({ db }) => db.add(obj)));\n\n /**\n * @link EchoDatabase.remove\n */\n static remove = <T extends Obj.Any | Relation.Any>(obj: T): Effect.Effect<void, never, DatabaseService> =>\n DatabaseService.pipe(Effect.map(({ db }) => db.remove(obj)));\n\n /**\n * @link EchoDatabase.flush\n */\n static flush = (opts?: FlushOptions) =>\n DatabaseService.pipe(Effect.flatMap(({ db }) => promiseWithCauseCapture(() => db.flush(opts))));\n\n /**\n * @link EchoDatabase.getObjectById\n */\n static getObjectById = <T extends Obj.Any | Relation.Any>(\n id: string,\n ): Effect.Effect<Live<T> | undefined, never, DatabaseService> => {\n return DatabaseService.pipe(Effect.map(({ db }) => db.getObjectById(id)));\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) => promiseWithCauseCapture(() => queryResult.run())),\n );\n\n static schemaQuery = <Q extends SchemaRegistryQuery>(\n query: Q,\n ): Effect.Effect<SchemaRegistryPreparedQuery<EchoSchema>, never, DatabaseService> =>\n DatabaseService.pipe(\n Effect.map(({ db }) => db.schemaRegistry.query(query)),\n Effect.withSpan('DatabaseService.schemaQuery'),\n );\n\n static runSchemaQuery = <Q extends SchemaRegistryQuery>(\n query: Q,\n ): Effect.Effect<EchoSchema[], never, DatabaseService> =>\n DatabaseService.schemaQuery(query).pipe(\n Effect.flatMap((queryResult) => promiseWithCauseCapture(() => queryResult.run())),\n );\n}\n\n// TODO(burdon): Move to echo/errors.\nclass ObjectNotFoundError extends BaseError.extend('OBJECT_NOT_FOUND') {\n constructor(context?: Record<string, unknown>) {\n super('Object not found', { context });\n }\n}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context, Effect, Layer } from 'effect';\n\nimport type { Obj, Relation } from '@dxos/echo';\nimport type { Queue, QueueAPI, QueueFactory } from '@dxos/echo-db';\nimport type { DXN, QueueSubspaceTag } from '@dxos/keys';\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 queue: 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 queue: undefined,\n });\n\n static make = (queues: QueueFactory, queue?: Queue): Context.Tag.Service<QueueService> => {\n return {\n queues,\n queue,\n };\n };\n\n static layer = (queues: QueueFactory, queue?: Queue): Layer.Layer<QueueService> =>\n Layer.succeed(QueueService, QueueService.make(queues, queue));\n\n /**\n * Gets a queue by its DXN.\n */\n static getQueue = <T extends Obj.Any | Relation.Any = Obj.Any | Relation.Any>(\n dxn: DXN,\n ): Effect.Effect<Queue<T>, never, QueueService> => QueueService.pipe(Effect.map(({ queues }) => queues.get<T>(dxn)));\n\n /**\n * Creates a new queue.\n */\n static createQueue = <T extends Obj.Any | Relation.Any = Obj.Any | Relation.Any>(options?: {\n subspaceTag?: QueueSubspaceTag;\n }): Effect.Effect<Queue<T>, never, QueueService> =>\n QueueService.pipe(Effect.map(({ queues }) => queues.create<T>(options)));\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 queue: Queue;\n }\n>() {\n static layer = (queue: Queue) => Layer.succeed(ContextQueueService, { queue });\n}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { HttpClient, HttpClientRequest } from '@effect/platform';\nimport { type Config, Context, Effect, Layer, Redacted } from 'effect';\n\nimport { Query } from '@dxos/echo';\nimport { DataType } from '@dxos/schema';\n\nimport { DatabaseService } from './database';\n\nexport type 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 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 static getApiKey = (query: CredentialQuery): Effect.Effect<Redacted.Redacted<string>, never, CredentialsService> =>\n Effect.gen(function* () {\n const credential = yield* CredentialsService.getCredential(query);\n if (!credential.apiKey) {\n throw new Error(`API key not found for service: ${query.service}`);\n }\n return Redacted.make(credential.apiKey);\n });\n\n static configuredLayer = (credentials: ServiceCredential[]) =>\n Layer.succeed(CredentialsService, new ConfiguredCredentialsService(credentials));\n\n static layerConfig = (credentials: { service: string; apiKey: Config.Config<Redacted.Redacted<string>> }[]) =>\n Layer.effect(\n CredentialsService,\n Effect.gen(function* () {\n const serviceCredentials = yield* Effect.forEach(credentials, ({ service, apiKey }) =>\n Effect.gen(function* () {\n return {\n service,\n apiKey: Redacted.value(yield* apiKey),\n };\n }),\n );\n\n return new ConfiguredCredentialsService(serviceCredentials);\n }),\n );\n\n static layerFromDatabase = () =>\n Layer.effect(\n CredentialsService,\n Effect.gen(function* () {\n const dbService = yield* DatabaseService;\n const queryCredentials = async (query: CredentialQuery): Promise<ServiceCredential[]> => {\n const { objects: accessTokens } = await dbService.db.query(Query.type(DataType.AccessToken)).run();\n return accessTokens\n .filter((accessToken) => accessToken.source === query.service)\n .map((accessToken) => ({\n service: accessToken.source,\n apiKey: accessToken.token,\n }));\n };\n return {\n getCredential: async (query) => {\n const credentials = await queryCredentials(query);\n if (credentials.length === 0) {\n throw new Error(`Credential not found for service: ${query.service}`);\n }\n return credentials[0];\n },\n queryCredentials: async (query) => {\n return queryCredentials(query);\n },\n };\n }),\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/**\n * Maps the request to include the API key from the credential.\n */\nexport const withAuthorization = (query: CredentialQuery, kind?: 'Bearer' | 'Basic') =>\n HttpClient.mapRequestEffect(\n Effect.fnUntraced(function* (request) {\n const key = yield* CredentialsService.getApiKey(query).pipe(Effect.map(Redacted.value));\n const authorization = kind ? `${kind} ${key}` : key;\n return HttpClientRequest.setHeader(request, 'Authorization', authorization);\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 { Queue } from '@dxos/echo-db';\nimport type { ObjectId } from '@dxos/echo-schema';\nimport { log } from '@dxos/log';\nimport { DataType } from '@dxos/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 * Gets the parent message ID.\n */\n getTraceContext: () => TracingService.TraceContext;\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: Obj.Any) => void;\n }\n>() {\n static noop: Context.Tag.Service<TracingService> = { write: () => {}, getTraceContext: () => ({}) };\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 getTraceContext: () => ({}),\n };\n\n static layerConsole = Layer.succeed(TracingService, TracingService.console);\n\n static layerLogInfo = () =>\n Layer.succeed(TracingService, {\n write: (event) => {\n if (Obj.instanceOf(AgentStatus, event)) {\n log.info('status', { message: event.message });\n }\n },\n getTraceContext: () => ({}),\n });\n\n /**\n * Creates a TracingService layer that emits events to the parent tracing service.\n */\n static layerSubframe = (mapContext: (currentContext: TracingService.TraceContext) => TracingService.TraceContext) =>\n Layer.effect(\n TracingService,\n Effect.gen(function* () {\n const tracing = yield* TracingService;\n const context = mapContext(tracing.getTraceContext());\n return {\n write: (event) => tracing.write(event),\n getTraceContext: () => context,\n };\n }),\n );\n\n static layerQueue = (queue: Queue) =>\n Layer.effect(\n TracingService,\n Effect.gen(function* () {\n // TODO(dmaretskyi): Batching.\n return {\n write: (event) => queue.append([event]),\n getTraceContext: () => ({}),\n };\n }),\n );\n\n /**\n * Emit the current human-readable execution status.\n */\n static emitStatus: (data: Obj.MakeProps<typeof AgentStatus>) => Effect.Effect<void, never, TracingService> =\n Effect.fnUntraced(function* (data) {\n const tracing = yield* TracingService;\n tracing.write(\n Obj.make(AgentStatus, {\n parentMessage: tracing.getTraceContext().parentMessage,\n toolCallId: tracing.getTraceContext().toolCallId,\n ...data,\n }),\n );\n });\n\n static emitConverationMessage: (\n data: Obj.MakeProps<typeof DataType.Message>,\n ) => Effect.Effect<void, never, TracingService> = Effect.fnUntraced(function* (data) {\n const tracing = yield* TracingService;\n tracing.write(\n Obj.make(DataType.Message, {\n parentMessage: tracing.getTraceContext().parentMessage,\n ...data,\n properties: {\n [MESSAGE_PROPERTY_TOOL_CALL_ID]: tracing.getTraceContext().toolCallId,\n ...data.properties,\n },\n }),\n );\n });\n}\n\nexport namespace TracingService {\n export interface TraceContext {\n /**\n * If this thread sprung from a tool call, this is the ID of the message containing the tool call.\n */\n parentMessage?: ObjectId;\n\n /**\n * If the current thread is a byproduct of a tool call, this is the ID of the tool call.\n */\n toolCallId?: string;\n }\n}\n\n/**\n * Goes into {@link DataType.Message['properties']}\n */\nexport const MESSAGE_PROPERTY_TOOL_CALL_ID = 'toolCallId' as const;\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Context, Effect, Layer, Schema } from 'effect';\n\nimport { Obj, Type } from '@dxos/echo';\nimport { invariant } from '@dxos/invariant';\nimport { LogLevel, log } 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\nimport { getInvocationUrl } from '../url';\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// 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.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 =\n this._services.ai != null ? Layer.succeed(AiService.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"],
5
+ "mappings": "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",
6
+ "names": ["FUNCTIONS_META_KEY", "FUNCTIONS_PRESET_META_KEY", "isSecure", "protocol", "getUserFunctionIdInMetadata", "meta", "keys", "find", "key", "source", "id", "setUserFunctionIdInMetadata", "functionId", "Error", "push", "getInvocationUrl", "edgeUrl", "options", "baseUrl", "URL", "url", "toString", "spaceId", "searchParams", "set", "subjectId", "Context", "Effect", "Layer", "Option", "Obj", "promiseWithCauseCapture", "BaseError", "invariant", "DatabaseService", "Tag", "notAvailable", "succeed", "db", "Error", "make", "layer", "resolve", "dxn", "schema", "gen", "object", "graph", "createRefResolver", "context", "space", "spaceId", "fail", "ObjectNotFoundError", "instanceOf", "load", "fn", "ref", "tryLoad", "loadOption", "pipe", "catchTag", "undefined", "fromNullable", "add", "obj", "map", "remove", "flush", "opts", "flatMap", "getObjectById", "id", "query", "queryOrFilter", "withSpan", "runQuery", "queryResult", "run", "schemaQuery", "schemaRegistry", "runSchemaQuery", "extend", "Context", "Effect", "Layer", "Context", "QueueService", "Tag", "_define_property", "notAvailable", "Layer", "succeed", "queues", "get", "_dxn", "Error", "create", "queue", "undefined", "make", "layer", "getQueue", "dxn", "pipe", "Effect", "map", "createQueue", "options", "ContextQueueService", "HttpClient", "HttpClientRequest", "Context", "Effect", "Layer", "Redacted", "Query", "DataType", "Context", "CredentialsService", "Tag", "_define_property", "getCredential", "query", "Effect", "gen", "credentials", "promise", "getApiKey", "credential", "apiKey", "Error", "service", "Redacted", "make", "configuredLayer", "Layer", "succeed", "ConfiguredCredentialsService", "layerConfig", "effect", "serviceCredentials", "forEach", "value", "layerFromDatabase", "dbService", "DatabaseService", "queryCredentials", "objects", "accessTokens", "db", "Query", "type", "DataType", "AccessToken", "run", "filter", "accessToken", "source", "map", "token", "length", "addCredentials", "push", "find", "withAuthorization", "kind", "HttpClient", "mapRequestEffect", "fnUntraced", "request", "key", "pipe", "authorization", "HttpClientRequest", "setHeader", "Context", "Effect", "Layer", "AgentStatus", "Obj", "log", "DataType", "TracingService", "Tag", "_define_property", "noop", "write", "getTraceContext", "layerNoop", "succeed", "console", "event", "layerConsole", "layerLogInfo", "instanceOf", "info", "message", "layerSubframe", "mapContext", "effect", "gen", "tracing", "context", "layerQueue", "queue", "append", "emitStatus", "fnUntraced", "data", "make", "parentMessage", "toolCallId", "emitConverationMessage", "Message", "properties", "MESSAGE_PROPERTY_TOOL_CALL_ID", "Context", "Effect", "Layer", "Schema", "Obj", "Type", "invariant", "LogLevel", "log", "ComputeEventPayload", "Schema", "Union", "Struct", "type", "Literal", "nodeId", "String", "inputs", "Record", "key", "value", "Any", "outputs", "property", "event", "ComputeEvent", "payload", "pipe", "Type", "Obj", "typename", "version", "Context", "ComputeEventLogger", "Tag", "_define_property", "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", "Context", "RemoteFunctionExecutionService", "Tag", "fromClient", "baseUrl", "spaceId", "callFunction", "deployedFunctionId", "input", "url", "getInvocationUrl", "result", "fetch", "method", "headers", "body", "JSON", "stringify", "status", "Error", "cause", "text", "json", "_define_property", "mock", "mockLayer", "Layer", "succeed", "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", "setServices", "services", "_services", "getService", "serviceKey", "service", "undefined", "Error", "clone", "createLayer", "Layer", "succeed", "notAvailable", "ConfiguredCredentialsService", "mock", "mergeAll", "_define_property"]
7
+ }
@@ -4,11 +4,22 @@ import { EdgeHttpClient } from "@dxos/edge-client";
4
4
  import { invariant } from "@dxos/invariant";
5
5
  import { log } from "@dxos/log";
6
6
  var __dxlog_file = "/__w/dxos/dxos/packages/core/functions/src/edge/functions.ts";
7
- var uploadWorkerFunction = async ({ client, version, source, name, functionId, ownerPublicKey }) => {
7
+ var uploadWorkerFunction = async ({ client, version, name, functionId, ownerPublicKey, entryPoint, assets }) => {
8
+ log("uploading function", {
9
+ functionId,
10
+ name,
11
+ version,
12
+ ownerPublicKey
13
+ }, {
14
+ F: __dxlog_file,
15
+ L: 34,
16
+ S: void 0,
17
+ C: (f, a) => f(...a)
18
+ });
8
19
  const edgeUrl = client.config.values.runtime?.services?.edge?.url;
9
20
  invariant(edgeUrl, "Edge is not configured.", {
10
21
  F: __dxlog_file,
11
- L: 33,
22
+ L: 36,
12
23
  S: void 0,
13
24
  A: [
14
25
  "edgeUrl",
@@ -23,18 +34,19 @@ var uploadWorkerFunction = async ({ client, version, source, name, functionId, o
23
34
  }, {
24
35
  name,
25
36
  version,
26
- script: source,
27
- ownerPublicKey: ownerPublicKey.toHex()
37
+ ownerPublicKey: ownerPublicKey.toHex(),
38
+ entryPoint,
39
+ assets
28
40
  });
29
- log.info("Uploaded", {
41
+ log("uploaded", {
30
42
  identityKey: edgeIdentity.identityKey,
31
43
  functionId,
32
44
  name,
33
- source: source.length,
45
+ version,
34
46
  response
35
47
  }, {
36
48
  F: __dxlog_file,
37
- L: 43,
49
+ L: 46,
38
50
  S: void 0,
39
51
  C: (f, a) => f(...a)
40
52
  });
@@ -45,7 +57,7 @@ var incrementSemverPatch = (version) => {
45
57
  const patchNum = Number(patch);
46
58
  invariant(!Number.isNaN(patchNum), `Unexpected function version format: ${version}`, {
47
59
  F: __dxlog_file,
48
- L: 57,
60
+ L: 60,
49
61
  S: void 0,
50
62
  A: [
51
63
  "!Number.isNaN(patchNum)",
@@ -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"],
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
- "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"]
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 version: string;\n name?: string;\n functionId?: string;\n ownerPublicKey: PublicKey;\n entryPoint: string;\n assets: Record<string, Uint8Array>;\n};\n\nexport const uploadWorkerFunction = async ({\n client,\n version,\n name,\n functionId,\n ownerPublicKey,\n entryPoint,\n assets,\n}: UploadWorkerArgs): Promise<UploadFunctionResponseBody> => {\n log('uploading function', { functionId, name, version, ownerPublicKey });\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, ownerPublicKey: ownerPublicKey.toHex(), entryPoint, assets },\n );\n\n // TODO(burdon): Edge service log.\n log('uploaded', {\n identityKey: edgeIdentity.identityKey,\n functionId,\n name,\n version,\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
+ "mappings": ";AAOA,SAASA,0BAA0B;AACnC,SAASC,sBAAsB;AAC/B,SAASC,iBAAiB;AAE1B,SAASC,WAAW;;AAab,IAAMC,uBAAuB,OAAO,EACzCC,QACAC,SACAC,MACAC,YACAC,gBACAC,YACAC,OAAM,MACW;AACjBR,MAAI,sBAAsB;IAAEK;IAAYD;IAAMD;IAASG;EAAe,GAAA;;;;;;AACtE,QAAMG,UAAUP,OAAOQ,OAAOC,OAAOC,SAASC,UAAUC,MAAMC;AAC9DhB,YAAUU,SAAS,2BAAA;;;;;;;;;AACnB,QAAMO,aAAa,IAAIlB,eAAeW,OAAAA;AACtC,QAAMQ,eAAepB,mBAAmBK,MAAAA;AACxCc,aAAWE,YAAYD,YAAAA;AACvB,QAAME,WAAW,MAAMH,WAAWI,eAChC;IAAEf;EAAW,GACb;IAAED;IAAMD;IAASG,gBAAgBA,eAAee,MAAK;IAAId;IAAYC;EAAO,CAAA;AAI9ER,MAAI,YAAY;IACdsB,aAAaL,aAAaK;IAC1BjB;IACAD;IACAD;IACAgB;EACF,GAAA;;;;;;AAEA,SAAOA;AACT;AAEO,IAAMI,uBAAuB,CAACpB,YAAAA;AACnC,QAAM,CAACqB,OAAOC,OAAOC,KAAAA,IAASvB,QAAQwB,MAAM,GAAA;AAC5C,QAAMC,WAAWC,OAAOH,KAAAA;AACxB3B,YAAU,CAAC8B,OAAOC,MAAMF,QAAAA,GAAW,uCAAuCzB,OAAAA,IAAS;;;;;;;;;AACnF,SAAO;IAACqB;IAAOC;IAAOM,OAAOH,WAAW,CAAA;IAAII,KAAK,GAAA;AACnD;AAGO,IAAMC,iBAAiB,CAACC,QAAAA;AAC7B,SAAO,WAAWA,IAAIb,MAAK,CAAA;AAC7B;",
6
+ "names": ["createEdgeIdentity", "EdgeHttpClient", "invariant", "log", "uploadWorkerFunction", "client", "version", "name", "functionId", "ownerPublicKey", "entryPoint", "assets", "edgeUrl", "config", "values", "runtime", "services", "edge", "url", "edgeClient", "edgeIdentity", "setIdentity", "response", "uploadFunction", "toHex", "identityKey", "incrementSemverPatch", "major", "minor", "patch", "split", "patchNum", "Number", "isNaN", "String", "join", "publicKeyToDid", "key"]
7
7
  }
@@ -6,18 +6,22 @@ import {
6
6
  ContextQueueService,
7
7
  CredentialsService,
8
8
  DatabaseService,
9
- FunctionError,
10
- LocalFunctionExecutionService,
9
+ FUNCTIONS_META_KEY,
10
+ FUNCTIONS_PRESET_META_KEY,
11
+ MESSAGE_PROPERTY_TOOL_CALL_ID,
11
12
  QueueService,
12
13
  RemoteFunctionExecutionService,
13
14
  SERVICE_TAGS,
14
15
  ServiceContainer,
15
- ServiceNotAvailableError,
16
16
  TracingService,
17
17
  createDefectLogger,
18
18
  createEventLogger,
19
- logCustomEvent
20
- } from "./chunk-6PTFLPCO.mjs";
19
+ getInvocationUrl,
20
+ getUserFunctionIdInMetadata,
21
+ logCustomEvent,
22
+ setUserFunctionIdInMetadata,
23
+ withAuthorization
24
+ } from "./chunk-7NQ77AIQ.mjs";
21
25
 
22
26
  // src/handler.ts
23
27
  import { Schema } from "effect";
@@ -56,6 +60,16 @@ var ScriptType = Schema2.Struct({
56
60
  "name"
57
61
  ]));
58
62
  var FunctionType = Schema2.Struct({
63
+ /**
64
+ * Global registry ID.
65
+ * NOTE: The `key` property refers to the original registry entry.
66
+ */
67
+ // TODO(burdon): Create Format type for DXN-like ids, such as this and schema type.
68
+ // TODO(dmaretskyi): Consider making it part of ECHO meta.
69
+ // TODO(dmaretskyi): Make required.
70
+ key: Schema2.optional(Schema2.String).annotations({
71
+ description: "Unique registration key for the blueprint"
72
+ }),
59
73
  // TODO(burdon): Rename to id/uri?
60
74
  name: Schema2.NonEmptyString,
61
75
  version: Schema2.String,
@@ -76,23 +90,23 @@ var FunctionType = Schema2.Struct({
76
90
 
77
91
  // src/trace.ts
78
92
  import { Schema as Schema4 } from "effect";
79
- import { Type as Type2 } from "@dxos/echo";
93
+ import { Type as Type3 } from "@dxos/echo";
80
94
  import { Queue } from "@dxos/echo-db";
81
95
  import { ObjectId } from "@dxos/echo-schema";
82
96
  import { log } from "@dxos/log";
83
97
 
84
98
  // src/types.ts
85
99
  import { Schema as Schema3, SchemaAST } from "effect";
86
- import { Expando, OptionsAnnotationId, TypedObject, Ref as Ref2, RawObject } from "@dxos/echo-schema";
100
+ import { Type as Type2 } from "@dxos/echo";
101
+ import { Expando, OptionsAnnotationId, RawObject, Ref as Ref2 } from "@dxos/echo-schema";
87
102
  import { DXN } from "@dxos/keys";
88
- var TriggerKind = /* @__PURE__ */ function(TriggerKind2) {
89
- TriggerKind2["Timer"] = "timer";
90
- TriggerKind2["Webhook"] = "webhook";
91
- TriggerKind2["Subscription"] = "subscription";
92
- TriggerKind2["Email"] = "email";
93
- TriggerKind2["Queue"] = "queue";
94
- return TriggerKind2;
95
- }({});
103
+ var TriggerKinds = [
104
+ "timer",
105
+ "webhook",
106
+ "subscription",
107
+ "email",
108
+ "queue"
109
+ ];
96
110
  var kindLiteralAnnotations = {
97
111
  title: "Kind"
98
112
  };
@@ -184,7 +198,7 @@ var SubscriptionTriggerOutput = Schema3.mutable(Schema3.Struct({
184
198
  var TimerTriggerOutput = Schema3.mutable(Schema3.Struct({
185
199
  tick: Schema3.Number
186
200
  }));
187
- var FunctionTriggerSchema = Schema3.Struct({
201
+ var FunctionTrigger = Schema3.Struct({
188
202
  /**
189
203
  * Function or workflow to invoke.
190
204
  */
@@ -219,12 +233,10 @@ var FunctionTriggerSchema = Schema3.Struct({
219
233
  key: Schema3.String,
220
234
  value: Schema3.Any
221
235
  })))
222
- });
223
- var FunctionTrigger = class extends TypedObject({
236
+ }).pipe(Type2.Obj({
224
237
  typename: "dxos.org/type/FunctionTrigger",
225
238
  version: "0.2.0"
226
- })(FunctionTriggerSchema.fields) {
227
- };
239
+ }));
228
240
  var FunctionManifestSchema = Schema3.Struct({
229
241
  functions: Schema3.optional(Schema3.mutable(Schema3.Array(RawObject(FunctionType)))),
230
242
  triggers: Schema3.optional(Schema3.mutable(Schema3.Array(RawObject(FunctionTrigger))))
@@ -275,16 +287,16 @@ var InvocationTraceStartEvent = Schema4.Struct({
275
287
  /**
276
288
  * Queue for function/workflow invocation events.
277
289
  */
278
- invocationTraceQueue: Type2.Ref(Queue),
290
+ invocationTraceQueue: Type3.Ref(Queue),
279
291
  /**
280
292
  * DXN of the invoked function/workflow.
281
293
  */
282
- invocationTarget: Type2.Ref(Type2.Expando),
294
+ invocationTarget: Type3.Ref(Type3.Expando),
283
295
  /**
284
296
  * Present for automatic invocations.
285
297
  */
286
- trigger: Schema4.optional(Type2.Ref(FunctionTrigger))
287
- }).pipe(Type2.Obj({
298
+ trigger: Schema4.optional(Type3.Ref(FunctionTrigger))
299
+ }).pipe(Type3.Obj({
288
300
  typename: "dxos.org/type/InvocationTraceStart",
289
301
  version: "0.1.0"
290
302
  }));
@@ -305,7 +317,7 @@ var InvocationTraceEndEvent = Schema4.Struct({
305
317
  timestampMs: Schema4.Number,
306
318
  outcome: Schema4.Enums(InvocationOutcome),
307
319
  exception: Schema4.optional(TraceEventException)
308
- }).pipe(Type2.Obj({
320
+ }).pipe(Type3.Obj({
309
321
  typename: "dxos.org/type/InvocationTraceEnd",
310
322
  version: "0.1.0"
311
323
  }));
@@ -320,13 +332,11 @@ var TraceEvent = Schema4.Struct({
320
332
  // TODO(burdon): Need enum/numeric result (not string).
321
333
  outcome: Schema4.String,
322
334
  truncated: Schema4.Boolean,
323
- /**
324
- * Time when the event was persisted.
325
- */
326
- ingestionTimestampMs: Schema4.Number,
335
+ /** Time when the event was persisted. */
336
+ ingestionTimestamp: Schema4.Number,
327
337
  logs: Schema4.Array(TraceEventLog),
328
338
  exceptions: Schema4.Array(TraceEventException)
329
- }).pipe(Type2.Obj({
339
+ }).pipe(Type3.Obj({
330
340
  typename: "dxos.org/type/TraceEvent",
331
341
  version: "0.1.0"
332
342
  }));
@@ -359,7 +369,7 @@ var createInvocationSpans = (items) => {
359
369
  invocationId
360
370
  }, {
361
371
  F: __dxlog_file,
362
- L: 160,
372
+ L: 158,
363
373
  S: void 0,
364
374
  C: (f, a) => f(...a)
365
375
  });
@@ -381,74 +391,127 @@ var createInvocationSpans = (items) => {
381
391
  return result;
382
392
  };
383
393
 
384
- // src/url.ts
385
- var FUNCTIONS_META_KEY = "dxos.org/service/function";
386
- var FUNCTIONS_PRESET_META_KEY = "dxos.org/service/function-preset";
387
- var isSecure = (protocol) => {
388
- return protocol === "https:" || protocol === "wss:";
394
+ // src/services/local-function-execution.ts
395
+ import { Context, Effect, Layer, Schema as Schema5 } from "effect";
396
+ import { todo } from "@dxos/debug";
397
+
398
+ // src/errors.ts
399
+ import { BaseError } from "@dxos/errors";
400
+ var ServiceNotAvailableError = class extends BaseError.extend("SERVICE_NOT_AVAILABLE") {
401
+ constructor(serviceName) {
402
+ super(`Service not available: ${serviceName}`);
403
+ }
389
404
  };
390
- var getUserFunctionUrlInMetadata = (meta) => {
391
- return meta.keys.find((key) => key.source === FUNCTIONS_META_KEY)?.id;
405
+ var FunctionError = class extends BaseError.extend("FUNCTION_ERROR") {
392
406
  };
393
- var setUserFunctionUrlInMetadata = (meta, functionUrl) => {
394
- const key = meta.keys.find((key2) => key2.source === FUNCTIONS_META_KEY);
395
- if (key) {
396
- if (key.id !== functionUrl) {
397
- throw new Error("Metadata mismatch");
398
- }
399
- } else {
400
- meta.keys.push({
401
- source: FUNCTIONS_META_KEY,
402
- id: functionUrl
407
+
408
+ // src/services/local-function-execution.ts
409
+ function _define_property(obj, key, value) {
410
+ if (key in obj) {
411
+ Object.defineProperty(obj, key, {
412
+ value,
413
+ enumerable: true,
414
+ configurable: true,
415
+ writable: true
403
416
  });
417
+ } else {
418
+ obj[key] = value;
404
419
  }
420
+ return obj;
421
+ }
422
+ var _Context_Tag;
423
+ var LocalFunctionExecutionService = class extends (_Context_Tag = Context.Tag("@dxos/functions/LocalFunctionExecutionService")()) {
405
424
  };
406
- var makeFunctionUrl = (fn) => `/${fn.functionId}`;
407
- var getInvocationUrl = (functionUrl, edgeUrl, options = {}) => {
408
- const baseUrl = new URL("functions/", edgeUrl);
409
- const relativeUrl = functionUrl.replace(/^\//, "");
410
- const url = new URL(`./${relativeUrl}`, baseUrl.toString());
411
- options.spaceId && url.searchParams.set("spaceId", options.spaceId);
412
- options.subjectId && url.searchParams.set("subjectId", options.subjectId);
413
- url.protocol = isSecure(url.protocol) ? "https" : "http";
414
- return url.toString();
415
- };
425
+ _define_property(LocalFunctionExecutionService, "layer", Layer.succeed(LocalFunctionExecutionService, {
426
+ invokeFunction: (functionDef, input) => invokeFunction(functionDef, input)
427
+ }));
428
+ _define_property(LocalFunctionExecutionService, "invokeFunction", Effect.serviceFunctionEffect(LocalFunctionExecutionService, (_) => _.invokeFunction));
429
+ var invokeFunction = (functionDef, input) => Effect.gen(function* () {
430
+ const assertInput = functionDef.inputSchema.pipe(Schema5.asserts);
431
+ assertInput(input);
432
+ const context = {
433
+ space: void 0,
434
+ getService: () => todo(),
435
+ getSpace: async (_spaceId) => {
436
+ throw new Error("Not available. Use the database service instead.");
437
+ }
438
+ };
439
+ const data = yield* Effect.gen(function* () {
440
+ const result = functionDef.handler({
441
+ context,
442
+ data: input
443
+ });
444
+ if (Effect.isEffect(result)) {
445
+ return yield* result.pipe(Effect.orDie);
446
+ } else if (typeof result === "object" && result !== null && "then" in result && typeof result.then === "function") {
447
+ return yield* Effect.promise(() => result);
448
+ } else {
449
+ return result;
450
+ }
451
+ }).pipe(Effect.orDie, Effect.catchAllDefect((defect) => Effect.die(new FunctionError("Error running function", {
452
+ context: {
453
+ name: functionDef.name
454
+ },
455
+ cause: defect
456
+ }))));
457
+ const assertOutput = functionDef.outputSchema?.pipe(Schema5.asserts);
458
+ assertOutput(data);
459
+ return data;
460
+ }).pipe(Effect.withSpan("invokeFunction", {
461
+ attributes: {
462
+ name: functionDef.name
463
+ }
464
+ }));
416
465
 
417
466
  // src/executor/executor.ts
418
- import { Effect, Schema as Schema5 } from "effect";
467
+ import { Effect as Effect2, Schema as Schema6 } from "effect";
419
468
  import { runAndForwardErrors } from "@dxos/effect";
420
- var FunctionExecutor = class {
421
- constructor(_services) {
422
- this._services = _services;
469
+ function _define_property2(obj, key, value) {
470
+ if (key in obj) {
471
+ Object.defineProperty(obj, key, {
472
+ value,
473
+ enumerable: true,
474
+ configurable: true,
475
+ writable: true
476
+ });
477
+ } else {
478
+ obj[key] = value;
423
479
  }
480
+ return obj;
481
+ }
482
+ var FunctionExecutor = class {
483
+ /**
484
+ * Invoke function.
485
+ */
424
486
  // TODO(dmaretskyi): Invocation context: queue, space, etc...
425
- async invoke(fnDef, input) {
426
- const assertInput = fnDef.inputSchema.pipe(Schema5.asserts);
487
+ async invoke(functionDef, input) {
488
+ const assertInput = functionDef.inputSchema.pipe(Schema6.asserts);
427
489
  assertInput(input);
428
490
  const context = {
491
+ space: void 0,
429
492
  getService: this._services.getService.bind(this._services),
430
493
  getSpace: async (_spaceId) => {
431
494
  throw new Error("Not available. Use the database service instead.");
432
- },
433
- space: void 0,
434
- get ai() {
435
- throw new Error("Not available. Use the ai service instead.");
436
495
  }
437
496
  };
438
- const result = fnDef.handler({
497
+ const result = functionDef.handler({
439
498
  context,
440
499
  data: input
441
500
  });
442
501
  let data;
443
- if (Effect.isEffect(result)) {
444
- data = await result.pipe(Effect.provide(this._services.createLayer()), runAndForwardErrors);
502
+ if (Effect2.isEffect(result)) {
503
+ data = await result.pipe(Effect2.provide(this._services.createLayer()), runAndForwardErrors);
445
504
  } else {
446
505
  data = await result;
447
506
  }
448
- const assertOutput = fnDef.outputSchema?.pipe(Schema5.asserts);
507
+ const assertOutput = functionDef.outputSchema?.pipe(Schema6.asserts);
449
508
  assertOutput(data);
450
509
  return data;
451
510
  }
511
+ constructor(_services) {
512
+ _define_property2(this, "_services", void 0);
513
+ this._services = _services;
514
+ }
452
515
  };
453
516
  export {
454
517
  ComputeEvent,
@@ -459,19 +522,20 @@ export {
459
522
  CredentialsService,
460
523
  DatabaseService,
461
524
  EmailTriggerOutput,
525
+ FUNCTIONS_META_KEY,
462
526
  FUNCTIONS_PRESET_META_KEY,
463
527
  FUNCTION_TYPES,
464
528
  FunctionError,
465
529
  FunctionExecutor,
466
530
  FunctionManifestSchema,
467
531
  FunctionTrigger,
468
- FunctionTriggerSchema,
469
532
  FunctionType,
470
533
  InvocationOutcome,
471
534
  InvocationTraceEndEvent,
472
535
  InvocationTraceEventType,
473
536
  InvocationTraceStartEvent,
474
537
  LocalFunctionExecutionService,
538
+ MESSAGE_PROPERTY_TOOL_CALL_ID,
475
539
  QueueService,
476
540
  QueueTriggerOutput,
477
541
  RemoteFunctionExecutionService,
@@ -485,7 +549,7 @@ export {
485
549
  TraceEventException,
486
550
  TraceEventLog,
487
551
  TracingService,
488
- TriggerKind,
552
+ TriggerKinds,
489
553
  TriggerSchema,
490
554
  WebhookTriggerOutput,
491
555
  createDefectLogger,
@@ -493,9 +557,9 @@ export {
493
557
  createInvocationSpans,
494
558
  defineFunction,
495
559
  getInvocationUrl,
496
- getUserFunctionUrlInMetadata,
560
+ getUserFunctionIdInMetadata,
497
561
  logCustomEvent,
498
- makeFunctionUrl,
499
- setUserFunctionUrlInMetadata
562
+ setUserFunctionIdInMetadata,
563
+ withAuthorization
500
564
  };
501
565
  //# sourceMappingURL=index.mjs.map