@dxos/functions 0.8.2-main.12df754 → 0.8.2-main.30e4dbb

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 (176) hide show
  1. package/dist/lib/browser/bundler/index.mjs +0 -3
  2. package/dist/lib/browser/bundler/index.mjs.map +1 -1
  3. package/dist/lib/browser/edge/index.mjs +62 -7
  4. package/dist/lib/browser/edge/index.mjs.map +4 -4
  5. package/dist/lib/browser/index.mjs +370 -102
  6. package/dist/lib/browser/index.mjs.map +4 -4
  7. package/dist/lib/browser/meta.json +1 -1
  8. package/dist/lib/node/bundler/index.cjs +0 -1
  9. package/dist/lib/node/bundler/index.cjs.map +1 -1
  10. package/dist/lib/node/edge/index.cjs +64 -5
  11. package/dist/lib/node/edge/index.cjs.map +4 -4
  12. package/dist/lib/node/index.cjs +382 -94
  13. package/dist/lib/node/index.cjs.map +4 -4
  14. package/dist/lib/node/meta.json +1 -1
  15. package/dist/lib/node-esm/bundler/index.mjs +0 -1
  16. package/dist/lib/node-esm/bundler/index.mjs.map +1 -1
  17. package/dist/lib/node-esm/edge/index.mjs +63 -6
  18. package/dist/lib/node-esm/edge/index.mjs.map +4 -4
  19. package/dist/lib/node-esm/index.mjs +370 -100
  20. package/dist/lib/node-esm/index.mjs.map +4 -4
  21. package/dist/lib/node-esm/meta.json +1 -1
  22. package/dist/types/src/bundler/bundler.d.ts.map +1 -1
  23. package/dist/types/src/edge/functions.d.ts +2 -3
  24. package/dist/types/src/edge/functions.d.ts.map +1 -1
  25. package/dist/types/src/edge/index.d.ts.map +1 -1
  26. package/dist/types/src/handler.d.ts +15 -64
  27. package/dist/types/src/handler.d.ts.map +1 -1
  28. package/dist/types/src/index.d.ts +3 -3
  29. package/dist/types/src/index.d.ts.map +1 -1
  30. package/dist/types/src/schema.d.ts +57 -0
  31. package/dist/types/src/schema.d.ts.map +1 -0
  32. package/dist/types/src/trace.d.ts +148 -0
  33. package/dist/types/src/trace.d.ts.map +1 -0
  34. package/dist/types/src/translations.d.ts +2 -1
  35. package/dist/types/src/translations.d.ts.map +1 -1
  36. package/dist/types/src/types.d.ts +407 -0
  37. package/dist/types/src/types.d.ts.map +1 -0
  38. package/dist/types/src/{types/url.d.ts → url.d.ts} +1 -1
  39. package/dist/types/src/url.d.ts.map +1 -0
  40. package/dist/types/tsconfig.tsbuildinfo +1 -1
  41. package/package.json +20 -36
  42. package/src/edge/functions.ts +2 -4
  43. package/src/edge/index.ts +4 -0
  44. package/src/handler.ts +20 -122
  45. package/src/index.ts +4 -5
  46. package/src/schema.ts +53 -0
  47. package/src/{types/trace.ts → trace.ts} +33 -31
  48. package/src/translations.ts +1 -1
  49. package/src/types.ts +210 -0
  50. package/src/{types/url.ts → url.ts} +1 -1
  51. package/dist/lib/browser/chunk-2YE6S7XY.mjs +0 -360
  52. package/dist/lib/browser/chunk-2YE6S7XY.mjs.map +0 -7
  53. package/dist/lib/browser/chunk-7CHDHCV3.mjs +0 -482
  54. package/dist/lib/browser/chunk-7CHDHCV3.mjs.map +0 -7
  55. package/dist/lib/browser/chunk-LT4LR4VU.mjs +0 -72
  56. package/dist/lib/browser/chunk-LT4LR4VU.mjs.map +0 -7
  57. package/dist/lib/browser/chunk-XRCXIG74.mjs +0 -12
  58. package/dist/lib/browser/chunk-XRCXIG74.mjs.map +0 -7
  59. package/dist/lib/browser/testing/index.mjs +0 -670
  60. package/dist/lib/browser/testing/index.mjs.map +0 -7
  61. package/dist/lib/browser/types/index.mjs +0 -51
  62. package/dist/lib/browser/types/index.mjs.map +0 -7
  63. package/dist/lib/node/chunk-FBIUZ7SD.cjs +0 -496
  64. package/dist/lib/node/chunk-FBIUZ7SD.cjs.map +0 -7
  65. package/dist/lib/node/chunk-JEQ2X3Z6.cjs +0 -34
  66. package/dist/lib/node/chunk-JEQ2X3Z6.cjs.map +0 -7
  67. package/dist/lib/node/chunk-NXZNXVT3.cjs +0 -94
  68. package/dist/lib/node/chunk-NXZNXVT3.cjs.map +0 -7
  69. package/dist/lib/node/chunk-SV5NRE5L.cjs +0 -395
  70. package/dist/lib/node/chunk-SV5NRE5L.cjs.map +0 -7
  71. package/dist/lib/node/testing/index.cjs +0 -687
  72. package/dist/lib/node/testing/index.cjs.map +0 -7
  73. package/dist/lib/node/types/index.cjs +0 -72
  74. package/dist/lib/node/types/index.cjs.map +0 -7
  75. package/dist/lib/node-esm/chunk-3XMJFSID.mjs +0 -360
  76. package/dist/lib/node-esm/chunk-3XMJFSID.mjs.map +0 -7
  77. package/dist/lib/node-esm/chunk-C6YINTWG.mjs +0 -482
  78. package/dist/lib/node-esm/chunk-C6YINTWG.mjs.map +0 -7
  79. package/dist/lib/node-esm/chunk-DHGBFXSZ.mjs +0 -12
  80. package/dist/lib/node-esm/chunk-DHGBFXSZ.mjs.map +0 -7
  81. package/dist/lib/node-esm/chunk-O2SXVYU5.mjs +0 -72
  82. package/dist/lib/node-esm/chunk-O2SXVYU5.mjs.map +0 -7
  83. package/dist/lib/node-esm/testing/index.mjs +0 -670
  84. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  85. package/dist/lib/node-esm/types/index.mjs +0 -51
  86. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  87. package/dist/types/src/browser/index.d.ts +0 -2
  88. package/dist/types/src/browser/index.d.ts.map +0 -1
  89. package/dist/types/src/function/function-registry.d.ts +0 -25
  90. package/dist/types/src/function/function-registry.d.ts.map +0 -1
  91. package/dist/types/src/function/function-registry.test.d.ts +0 -2
  92. package/dist/types/src/function/function-registry.test.d.ts.map +0 -1
  93. package/dist/types/src/function/index.d.ts +0 -2
  94. package/dist/types/src/function/index.d.ts.map +0 -1
  95. package/dist/types/src/runtime/dev-server.d.ts +0 -52
  96. package/dist/types/src/runtime/dev-server.d.ts.map +0 -1
  97. package/dist/types/src/runtime/dev-server.test.d.ts +0 -2
  98. package/dist/types/src/runtime/dev-server.test.d.ts.map +0 -1
  99. package/dist/types/src/runtime/index.d.ts +0 -3
  100. package/dist/types/src/runtime/index.d.ts.map +0 -1
  101. package/dist/types/src/runtime/scheduler.d.ts +0 -34
  102. package/dist/types/src/runtime/scheduler.d.ts.map +0 -1
  103. package/dist/types/src/runtime/scheduler.test.d.ts +0 -2
  104. package/dist/types/src/runtime/scheduler.test.d.ts.map +0 -1
  105. package/dist/types/src/testing/functions-integration.test.d.ts +0 -2
  106. package/dist/types/src/testing/functions-integration.test.d.ts.map +0 -1
  107. package/dist/types/src/testing/index.d.ts +0 -5
  108. package/dist/types/src/testing/index.d.ts.map +0 -1
  109. package/dist/types/src/testing/manifest.d.ts +0 -3
  110. package/dist/types/src/testing/manifest.d.ts.map +0 -1
  111. package/dist/types/src/testing/plugin-init.d.ts +0 -6
  112. package/dist/types/src/testing/plugin-init.d.ts.map +0 -1
  113. package/dist/types/src/testing/setup.d.ts +0 -15
  114. package/dist/types/src/testing/setup.d.ts.map +0 -1
  115. package/dist/types/src/testing/test/handler.d.ts +0 -4
  116. package/dist/types/src/testing/test/handler.d.ts.map +0 -1
  117. package/dist/types/src/testing/test/index.d.ts +0 -3
  118. package/dist/types/src/testing/test/index.d.ts.map +0 -1
  119. package/dist/types/src/testing/types.d.ts +0 -10
  120. package/dist/types/src/testing/types.d.ts.map +0 -1
  121. package/dist/types/src/testing/util.d.ts +0 -5
  122. package/dist/types/src/testing/util.d.ts.map +0 -1
  123. package/dist/types/src/trigger/index.d.ts +0 -3
  124. package/dist/types/src/trigger/index.d.ts.map +0 -1
  125. package/dist/types/src/trigger/trigger-registry.d.ts +0 -38
  126. package/dist/types/src/trigger/trigger-registry.d.ts.map +0 -1
  127. package/dist/types/src/trigger/trigger-registry.test.d.ts +0 -2
  128. package/dist/types/src/trigger/trigger-registry.test.d.ts.map +0 -1
  129. package/dist/types/src/trigger/type/index.d.ts +0 -3
  130. package/dist/types/src/trigger/type/index.d.ts.map +0 -1
  131. package/dist/types/src/trigger/type/subscription-trigger.d.ts +0 -4
  132. package/dist/types/src/trigger/type/subscription-trigger.d.ts.map +0 -1
  133. package/dist/types/src/trigger/type/timer-trigger.d.ts +0 -4
  134. package/dist/types/src/trigger/type/timer-trigger.d.ts.map +0 -1
  135. package/dist/types/src/trigger/type/webhook-trigger.d.ts +0 -4
  136. package/dist/types/src/trigger/type/webhook-trigger.d.ts.map +0 -1
  137. package/dist/types/src/types/index.d.ts +0 -5
  138. package/dist/types/src/types/index.d.ts.map +0 -1
  139. package/dist/types/src/types/schema.d.ts +0 -53
  140. package/dist/types/src/types/schema.d.ts.map +0 -1
  141. package/dist/types/src/types/trace.d.ts +0 -146
  142. package/dist/types/src/types/trace.d.ts.map +0 -1
  143. package/dist/types/src/types/types.d.ts +0 -265
  144. package/dist/types/src/types/types.d.ts.map +0 -1
  145. package/dist/types/src/types/url.d.ts.map +0 -1
  146. package/dist/types/tools/schema.d.ts +0 -2
  147. package/dist/types/tools/schema.d.ts.map +0 -1
  148. package/schema/functions.json +0 -211
  149. package/src/browser/index.ts +0 -5
  150. package/src/function/function-registry.test.ts +0 -118
  151. package/src/function/function-registry.ts +0 -104
  152. package/src/function/index.ts +0 -5
  153. package/src/runtime/dev-server.test.ts +0 -79
  154. package/src/runtime/dev-server.ts +0 -240
  155. package/src/runtime/index.ts +0 -6
  156. package/src/runtime/scheduler.test.ts +0 -152
  157. package/src/runtime/scheduler.ts +0 -170
  158. package/src/testing/functions-integration.test.ts +0 -65
  159. package/src/testing/index.ts +0 -8
  160. package/src/testing/manifest.ts +0 -15
  161. package/src/testing/plugin-init.ts +0 -20
  162. package/src/testing/setup.ts +0 -109
  163. package/src/testing/test/handler.ts +0 -15
  164. package/src/testing/test/index.ts +0 -7
  165. package/src/testing/types.ts +0 -9
  166. package/src/testing/util.ts +0 -26
  167. package/src/trigger/index.ts +0 -6
  168. package/src/trigger/trigger-registry.test.ts +0 -278
  169. package/src/trigger/trigger-registry.ts +0 -218
  170. package/src/trigger/type/index.ts +0 -7
  171. package/src/trigger/type/subscription-trigger.ts +0 -84
  172. package/src/trigger/type/timer-trigger.ts +0 -48
  173. package/src/trigger/type/webhook-trigger.ts +0 -48
  174. package/src/types/index.ts +0 -8
  175. package/src/types/schema.ts +0 -46
  176. package/src/types/types.ts +0 -163
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../src/testing/setup.ts", "../../../../src/testing/types.ts", "../../../../src/runtime/dev-server.ts", "../../../../src/runtime/scheduler.ts", "../../../../src/testing/util.ts", "../../../../src/testing/manifest.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { getRandomPort } from 'get-port-please';\nimport path from 'node:path';\n\nimport { waitForCondition } from '@dxos/async';\nimport { Client, Config } from '@dxos/client';\nimport { type Space } from '@dxos/client/echo';\nimport { type TestBuilder } from '@dxos/client/testing';\nimport { range } from '@dxos/util';\n\nimport { TestType } from './types';\nimport { FunctionRegistry } from '../function';\nimport { DevServer, type DevServerOptions, Scheduler } from '../runtime';\nimport { TriggerRegistry } from '../trigger';\nimport { FunctionDef, FunctionTrigger } from '../types';\n\nexport type FunctionsPluginInitializer = (client: Client) => Promise<{ close: () => Promise<void> }>;\n\n// TODO(burdon): Extend/wrap TestBuilder.\n\nexport const createInitializedClients = async (testBuilder: TestBuilder, count: number = 1, config?: Config) => {\n const clients = range(count).map(\n () =>\n new Client({\n config,\n services: testBuilder.createLocalClientServices(),\n types: [FunctionDef, FunctionTrigger, TestType],\n }),\n );\n\n testBuilder.ctx.onDispose(() => Promise.all(clients.map((client) => client.destroy())));\n return Promise.all(\n clients.map(async (client, index) => {\n await client.initialize();\n await client.halo.createIdentity({ displayName: `Peer ${index}` });\n await client.spaces.waitUntilReady();\n return client;\n }),\n );\n};\n\nexport const createFunctionRuntime = async (\n testBuilder: TestBuilder,\n pluginInitializer: FunctionsPluginInitializer,\n): Promise<Client> => {\n const functionsPort = await getRandomPort('127.0.0.1');\n const config = new Config({\n runtime: {\n agent: {\n plugins: [{ id: 'dxos.org/agent/plugin/functions', config: { port: functionsPort } }],\n },\n },\n });\n\n const [client] = await createInitializedClients(testBuilder, 1, config);\n const plugin = await pluginInitializer(client);\n testBuilder.ctx.onDispose(() => plugin.close());\n return client;\n};\n\nexport const startFunctionsHost = async (\n testBuilder: TestBuilder,\n pluginInitializer: FunctionsPluginInitializer,\n options?: DevServerOptions,\n) => {\n const functionRuntime = await createFunctionRuntime(testBuilder, pluginInitializer);\n const functionsRegistry = new FunctionRegistry(functionRuntime);\n const devServer = await startDevServer(testBuilder, functionRuntime, functionsRegistry, options);\n const scheduler = await startScheduler(testBuilder, functionRuntime, devServer, functionsRegistry);\n return {\n scheduler,\n client: functionRuntime,\n waitForActiveTriggers: async (space: Space) => {\n await waitForCondition({ condition: () => scheduler.triggers.getActiveTriggers(space).length > 0 });\n },\n };\n};\n\nconst startScheduler = async (\n testBuilder: TestBuilder,\n client: Client,\n devServer: DevServer,\n functionRegistry: FunctionRegistry,\n) => {\n const triggerRegistry = new TriggerRegistry(client);\n const scheduler = new Scheduler(functionRegistry, triggerRegistry, { endpoint: devServer.endpoint });\n await scheduler.start();\n testBuilder.ctx.onDispose(() => scheduler.stop());\n return scheduler;\n};\n\nconst startDevServer = async (\n testBuilder: TestBuilder,\n client: Client,\n functionRegistry: FunctionRegistry,\n options?: { baseDir?: string },\n) => {\n const server = new DevServer(client, functionRegistry, {\n baseDir: path.join(__dirname, '../testing'),\n port: await getRandomPort('127.0.0.1'),\n ...options,\n });\n await server.start();\n testBuilder.ctx.onDispose(() => server.stop());\n return server;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { S, TypedObject } from '@dxos/echo-schema';\n\nexport class TestType extends TypedObject({ typename: 'example.com/type/Test', version: '0.1.0' })({\n title: S.String,\n}) {}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport express from 'express';\nimport { getPort } from 'get-port-please';\nimport type http from 'http';\nimport { join } from 'node:path';\n\nimport { asyncTimeout, Event, Trigger } from '@dxos/async';\nimport { type Client } from '@dxos/client';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { log } from '@dxos/log';\n\nimport { type FunctionRegistry } from '../function';\nimport { type FunctionContext, type FunctionEvent, type FunctionHandler, type FunctionResponse } from '../handler';\nimport { type FunctionDef } from '../types';\n\nconst FN_TIMEOUT = 20_000;\n\nexport type DevServerOptions = {\n baseDir: string;\n port?: number;\n reload?: boolean;\n dataDir?: string;\n};\n\n/**\n * Functions dev server provides a local HTTP server for loading and invoking functions.\n * Functions are executed in the context of an authenticated client.\n */\nexport class DevServer {\n private _ctx = createContext();\n\n // Function handlers indexed by name (URL path).\n private readonly _handlers: Record<string, { def: FunctionDef; handler: FunctionHandler<any> }> = {};\n\n private _server?: http.Server;\n private _port?: number;\n private _functionServiceRegistration?: string;\n private _proxy?: string;\n private _seq = 0;\n\n public readonly update = new Event<number>();\n\n constructor(\n private readonly _client: Client,\n private readonly _functionsRegistry: FunctionRegistry,\n private readonly _options: DevServerOptions,\n ) {}\n\n get stats() {\n return {\n seq: this._seq,\n };\n }\n\n get endpoint() {\n invariant(this._port);\n return `http://localhost:${this._port}`;\n }\n\n get proxy() {\n return this._proxy;\n }\n\n get functions() {\n return Object.values(this._handlers);\n }\n\n async start() {\n invariant(!this._server);\n log.info('starting...');\n this._ctx = createContext();\n\n // TODO(burdon): Change to hono.\n const app = express();\n app.use(express.json());\n\n app.post('/:path', async (req, res) => {\n const { path } = req.params;\n try {\n log.info('calling', { path });\n if (this._options.reload) {\n const { def } = this._handlers['/' + path];\n await this._load(def, true);\n }\n\n // TODO(burdon): Get function context.\n res.statusCode = await asyncTimeout(this.invoke('/' + path, req.body), FN_TIMEOUT);\n res.end();\n } catch (err: any) {\n log.catch(err);\n res.statusCode = 500;\n res.end();\n }\n });\n\n this._port = this._options.port ?? (await getPort({ host: 'localhost', port: 7200, portRange: [7200, 7299] }));\n this._server = app.listen(this._port);\n\n try {\n // Register functions.\n const { registrationId, endpoint } = await this._client.services.services.FunctionRegistryService!.register({\n endpoint: this.endpoint,\n });\n\n log.info('registered', { endpoint });\n this._proxy = endpoint;\n this._functionServiceRegistration = registrationId;\n\n // Open after registration, so that it can be updated with the list of function definitions.\n await this._handleNewFunctions(this._functionsRegistry.getUniqueByUri());\n this._ctx.onDispose(this._functionsRegistry.registered.on(({ added }) => this._handleNewFunctions(added)));\n } catch (err: any) {\n await this.stop();\n throw new Error('FunctionRegistryService not available (check plugin is configured).');\n }\n\n log.info('started', { port: this._port });\n }\n\n async stop() {\n if (!this._server) {\n return;\n }\n\n log.info('stopping...');\n await this._ctx.dispose();\n\n const trigger = new Trigger();\n this._server.close(async () => {\n log.info('server stopped');\n try {\n if (this._functionServiceRegistration) {\n invariant(this._client.services.services.FunctionRegistryService);\n await this._client.services.services.FunctionRegistryService.unregister({\n registrationId: this._functionServiceRegistration,\n });\n\n log.info('unregistered', { registrationId: this._functionServiceRegistration });\n this._functionServiceRegistration = undefined;\n this._proxy = undefined;\n }\n\n trigger.wake();\n } catch (err) {\n trigger.throw(err as Error);\n }\n });\n\n await trigger.wait();\n this._port = undefined;\n this._server = undefined;\n log.info('stopped');\n }\n\n private async _handleNewFunctions(newFunctions: FunctionDef[]) {\n newFunctions.forEach((def) => this._load(def));\n await this._safeUpdateRegistration();\n log('new functions loaded', { newFunctions });\n }\n\n /**\n * Load function.\n */\n private async _load(def: FunctionDef, force?: boolean | undefined) {\n const { uri, route, handler } = def;\n const filePath = join(this._options.baseDir, handler);\n log.info('loading', { uri, force });\n\n // Remove from cache.\n if (force) {\n Object.keys(require.cache)\n .filter((key) => key.startsWith(filePath))\n .forEach((key) => {\n delete require.cache[key];\n });\n }\n\n // TODO(burdon): Import types.\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const module = require(filePath);\n if (typeof module.default !== 'function') {\n throw new Error(`Handler must export default function: ${uri}`);\n }\n\n this._handlers[route] = { def, handler: module.default };\n }\n\n private async _safeUpdateRegistration(): Promise<void> {\n invariant(this._functionServiceRegistration);\n try {\n await this._client.services.services.FunctionRegistryService!.updateRegistration({\n registrationId: this._functionServiceRegistration,\n functions: this.functions.map(({ def: { id, route } }) => ({ id, route })),\n });\n } catch (err) {\n log.catch(err);\n }\n }\n\n /**\n * Invoke function.\n */\n public async invoke(path: string, data: any): Promise<number> {\n const seq = ++this._seq;\n const now = Date.now();\n\n log.info('req', { seq, path });\n const statusCode = await this._invoke(path, { data });\n\n log.info('res', { seq, path, statusCode, duration: Date.now() - now });\n this.update.emit(statusCode);\n return statusCode;\n }\n\n private async _invoke(path: string, event: FunctionEvent) {\n const { handler } = this._handlers[path] ?? {};\n invariant(handler, `invalid path: ${path}`);\n const context: FunctionContext = {\n client: this._client,\n dataDir: this._options.dataDir,\n } as any;\n\n let statusCode = 200;\n const response: FunctionResponse = {\n status: (code: number) => {\n statusCode = code;\n return response;\n },\n };\n\n await handler({ context, event, response });\n return statusCode;\n }\n}\n\nconst createContext = () => new Context({ name: 'DevServer' });\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport path from 'node:path';\n\nimport { Mutex } from '@dxos/async';\nimport { loadObjectReferences, type Space } from '@dxos/client/echo';\nimport { Context } from '@dxos/context';\nimport { Reference } from '@dxos/echo-protocol';\nimport { log } from '@dxos/log';\n\nimport { type FunctionRegistry } from '../function';\nimport { type FunctionEventMeta } from '../handler';\nimport { type TriggerCallback, type TriggerRegistry } from '../trigger';\nimport { type FunctionDef, type FunctionManifest, type FunctionTrigger } from '../types';\n\nexport type Callback = (data: any) => Promise<void | number>;\n\nexport type SchedulerOptions = {\n endpoint?: string;\n callback?: Callback;\n};\n\n/**\n * The scheduler triggers function execution based on various trigger configurations.\n * Functions are scheduled within the context of a specific space.\n */\nexport class Scheduler {\n private _ctx = createContext();\n\n private readonly _functionUriToCallMutex = new Map<string, Mutex>();\n\n constructor(\n public readonly functions: FunctionRegistry,\n public readonly triggers: TriggerRegistry,\n private readonly _options: SchedulerOptions = {},\n ) {\n this.functions.registered.on(async ({ space, added }) => {\n await this._safeActivateTriggers(space, this.triggers.getInactiveTriggers(space), added);\n });\n this.triggers.registered.on(async ({ space, triggers }) => {\n await this._safeActivateTriggers(space, triggers, this.functions.getFunctions(space));\n });\n }\n\n async start() {\n await this._ctx.dispose();\n this._ctx = createContext();\n await this.functions.open(this._ctx);\n await this.triggers.open(this._ctx);\n }\n\n async stop() {\n await this._ctx.dispose();\n await this.functions.close();\n await this.triggers.close();\n }\n\n // TODO(burdon): Remove and update registries directly?\n public async register(space: Space, manifest: FunctionManifest) {\n await this.functions.register(space, manifest.functions);\n await this.triggers.register(space, manifest);\n }\n\n private async _safeActivateTriggers(\n space: Space,\n triggers: FunctionTrigger[],\n functions: FunctionDef[],\n ): Promise<void> {\n const mountTasks = triggers.map((trigger) => {\n return this.activate(space, functions, trigger);\n });\n\n await Promise.all(mountTasks).catch(log.catch);\n }\n\n /**\n * Activate trigger.\n */\n // TODO(burdon): How are triggers deactivated?\n private async activate(space: Space, functions: FunctionDef[], trigger: FunctionTrigger) {\n const definition = functions.find((def) => def.uri === trigger.function);\n if (!definition) {\n log.info('function is not found for trigger', { trigger });\n return;\n }\n\n const execFunction: TriggerCallback = async (args) => {\n const mutex = this._functionUriToCallMutex.get(definition.uri) ?? new Mutex();\n this._functionUriToCallMutex.set(definition.uri, mutex);\n\n log.info('function triggered, waiting for mutex', { uri: definition.uri });\n return mutex.executeSynchronized(async () => {\n log.info('mutex acquired', { uri: definition.uri });\n\n // Load potential references in meta properties to serialize.\n await loadObjectReferences(trigger, (t) => Object.values(t.meta ?? {}));\n const meta: FunctionTrigger['meta'] = {};\n for (const [key, value] of Object.entries(trigger.meta ?? {})) {\n if (value instanceof Reference) {\n const object = await space.db.query({ id: value.objectId }).first();\n if (object) {\n meta[key] = object;\n }\n } else {\n meta[key] = value;\n }\n }\n\n return this._execFunction(definition, trigger, {\n meta,\n data: { ...args, spaceKey: space.key },\n });\n });\n };\n\n await this.triggers.activate(space, trigger, execFunction);\n log('activated trigger', { space: space.key, trigger });\n }\n\n /**\n * Invoke function RPC.\n */\n private async _execFunction<TData, TMeta>(\n def: FunctionDef,\n trigger: FunctionTrigger,\n { meta, data }: { meta?: TMeta; data: TData },\n ): Promise<number> {\n let status = 0;\n try {\n // TODO(burdon): Pass in Space key (common context)?\n const payload = Object.assign({}, meta && ({ meta } satisfies FunctionEventMeta<TMeta>), data);\n\n const { endpoint, callback } = this._options;\n if (endpoint) {\n // TODO(burdon): Move out of scheduler (generalize as callback).\n const url = path.join(endpoint, def.route);\n log.info('exec', { function: def.uri, url, triggerType: trigger.spec?.type });\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(payload),\n });\n\n status = response.status;\n } else if (callback) {\n log.info('exec', { function: def.uri });\n status = (await callback(payload)) ?? 200;\n }\n\n // Check errors.\n if (status && status >= 400) {\n throw new Error(`Response: ${status}`);\n }\n\n // const result = await response.json();\n log.info('done', { function: def.uri, status });\n } catch (err: any) {\n log.error('error', { function: def.uri, error: err.message });\n status = 500;\n }\n\n return status;\n }\n}\n\nconst createContext = () => new Context({ name: 'FunctionScheduler' });\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport type { Client } from '@dxos/client';\nimport { Filter, type Space } from '@dxos/client/echo';\nimport { performInvitation } from '@dxos/client/testing';\nimport { invariant } from '@dxos/invariant';\nimport { Invitation } from '@dxos/protocols/proto/dxos/client/services';\n\nimport { FunctionTrigger } from '../types';\n\nexport const triggerWebhook = async (space: Space, uri: string) => {\n const trigger = (\n await space.db.query(Filter.schema(FunctionTrigger, (trigger: FunctionTrigger) => trigger.function === uri)).run()\n ).objects[0];\n invariant(trigger.spec?.type === 'webhook');\n void fetch(`http://localhost:${trigger.spec.port}`);\n};\n\nexport const inviteMember = async (host: Space, guest: Client) => {\n const [{ invitation: hostInvitation }] = await Promise.all(performInvitation({ host, guest: guest.spaces }));\n if (hostInvitation?.state !== Invitation.State.SUCCESS) {\n throw new Error(`Expected ${hostInvitation?.state} to be ${Invitation.State.SUCCESS}.`);\n }\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport type { FunctionManifest } from '../types';\n\nexport const testFunctionManifest: FunctionManifest = {\n functions: [\n {\n uri: 'example.com/function/test',\n route: 'test',\n handler: 'test',\n },\n ],\n};\n"],
5
- "mappings": "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",
6
- "names": ["getRandomPort", "path", "waitForCondition", "Client", "Config", "range", "S", "TypedObject", "TestType", "TypedObject", "typename", "version", "title", "S", "String", "express", "getPort", "join", "asyncTimeout", "Event", "Trigger", "Context", "invariant", "log", "FN_TIMEOUT", "DevServer", "constructor", "_client", "_functionsRegistry", "_options", "_ctx", "createContext", "_handlers", "_seq", "update", "Event", "stats", "seq", "endpoint", "invariant", "_port", "proxy", "_proxy", "functions", "Object", "values", "start", "_server", "log", "info", "app", "express", "use", "json", "post", "req", "res", "path", "params", "reload", "def", "_load", "statusCode", "asyncTimeout", "invoke", "body", "end", "err", "catch", "port", "getPort", "host", "portRange", "listen", "registrationId", "services", "FunctionRegistryService", "register", "_functionServiceRegistration", "_handleNewFunctions", "getUniqueByUri", "onDispose", "registered", "on", "added", "stop", "Error", "dispose", "trigger", "Trigger", "close", "unregister", "undefined", "wake", "throw", "wait", "newFunctions", "forEach", "_safeUpdateRegistration", "force", "uri", "route", "handler", "filePath", "join", "baseDir", "keys", "require", "cache", "filter", "key", "startsWith", "module", "default", "updateRegistration", "map", "id", "data", "now", "Date", "_invoke", "duration", "emit", "event", "context", "client", "dataDir", "response", "status", "code", "Context", "name", "path", "Mutex", "loadObjectReferences", "Context", "Reference", "log", "Scheduler", "constructor", "functions", "triggers", "_options", "_ctx", "createContext", "_functionUriToCallMutex", "Map", "registered", "on", "space", "added", "_safeActivateTriggers", "getInactiveTriggers", "getFunctions", "start", "dispose", "open", "stop", "close", "register", "manifest", "mountTasks", "map", "trigger", "activate", "Promise", "all", "catch", "definition", "find", "def", "uri", "function", "info", "execFunction", "args", "mutex", "get", "set", "executeSynchronized", "t", "Object", "values", "meta", "key", "value", "entries", "object", "db", "query", "id", "objectId", "first", "_execFunction", "data", "spaceKey", "status", "payload", "assign", "endpoint", "callback", "url", "join", "route", "triggerType", "spec", "type", "response", "fetch", "method", "headers", "body", "JSON", "stringify", "Error", "err", "error", "message", "name", "createInitializedClients", "testBuilder", "count", "config", "clients", "range", "map", "Client", "services", "createLocalClientServices", "types", "FunctionDef", "FunctionTrigger", "TestType", "ctx", "onDispose", "Promise", "all", "client", "destroy", "index", "initialize", "halo", "createIdentity", "displayName", "spaces", "waitUntilReady", "createFunctionRuntime", "pluginInitializer", "functionsPort", "getRandomPort", "Config", "runtime", "agent", "plugins", "id", "port", "plugin", "close", "startFunctionsHost", "options", "functionRuntime", "functionsRegistry", "FunctionRegistry", "devServer", "startDevServer", "scheduler", "startScheduler", "waitForActiveTriggers", "space", "waitForCondition", "condition", "triggers", "getActiveTriggers", "length", "functionRegistry", "triggerRegistry", "TriggerRegistry", "Scheduler", "endpoint", "start", "stop", "server", "DevServer", "baseDir", "path", "join", "__dirname", "Filter", "performInvitation", "invariant", "Invitation", "triggerWebhook", "space", "uri", "trigger", "db", "query", "Filter", "schema", "FunctionTrigger", "function", "run", "objects", "invariant", "spec", "type", "fetch", "port", "inviteMember", "host", "guest", "invitation", "hostInvitation", "Promise", "all", "performInvitation", "spaces", "state", "Invitation", "State", "SUCCESS", "Error", "testFunctionManifest", "functions", "uri", "route", "handler"]
7
- }
@@ -1,51 +0,0 @@
1
- import "@dxos/node-std/globals";
2
- import {
3
- FUNCTIONS_PRESET_META_KEY,
4
- FUNCTION_TYPES,
5
- FunctionDef,
6
- FunctionManifestSchema,
7
- FunctionTrigger,
8
- FunctionTriggerSchema,
9
- FunctionType,
10
- InvocationOutcome,
11
- InvocationTraceEndEvent,
12
- InvocationTraceEventType,
13
- InvocationTraceStartEvent,
14
- ScriptType,
15
- TraceEvent,
16
- TraceEventException,
17
- TraceEventLog,
18
- TriggerKind,
19
- TriggerSchema,
20
- createInvocationSpans,
21
- getInvocationUrl,
22
- getUserFunctionUrlInMetadata,
23
- makeFunctionUrl,
24
- setUserFunctionUrlInMetadata
25
- } from "../chunk-2YE6S7XY.mjs";
26
- import "../chunk-XRCXIG74.mjs";
27
- export {
28
- FUNCTIONS_PRESET_META_KEY,
29
- FUNCTION_TYPES,
30
- FunctionDef,
31
- FunctionManifestSchema,
32
- FunctionTrigger,
33
- FunctionTriggerSchema,
34
- FunctionType,
35
- InvocationOutcome,
36
- InvocationTraceEndEvent,
37
- InvocationTraceEventType,
38
- InvocationTraceStartEvent,
39
- ScriptType,
40
- TraceEvent,
41
- TraceEventException,
42
- TraceEventLog,
43
- TriggerKind,
44
- TriggerSchema,
45
- createInvocationSpans,
46
- getInvocationUrl,
47
- getUserFunctionUrlInMetadata,
48
- makeFunctionUrl,
49
- setUserFunctionUrlInMetadata
50
- };
51
- //# sourceMappingURL=index.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": [],
4
- "sourcesContent": [],
5
- "mappings": "",
6
- "names": []
7
- }
@@ -1,496 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var chunk_FBIUZ7SD_exports = {};
20
- __export(chunk_FBIUZ7SD_exports, {
21
- FunctionRegistry: () => FunctionRegistry,
22
- TriggerRegistry: () => TriggerRegistry,
23
- createSubscriptionTrigger: () => createSubscriptionTrigger,
24
- createTimerTrigger: () => createTimerTrigger
25
- });
26
- module.exports = __toCommonJS(chunk_FBIUZ7SD_exports);
27
- var import_chunk_SV5NRE5L = require("./chunk-SV5NRE5L.cjs");
28
- var import_async = require("@dxos/async");
29
- var import_echo = require("@dxos/client/echo");
30
- var import_context = require("@dxos/context");
31
- var import_keys = require("@dxos/keys");
32
- var import_log = require("@dxos/log");
33
- var import_util = require("@dxos/util");
34
- var import_async2 = require("@dxos/async");
35
- var import_echo2 = require("@dxos/client/echo");
36
- var import_echo_db = require("@dxos/echo-db");
37
- var import_log2 = require("@dxos/log");
38
- var import_cron_schedule = require("cron-schedule");
39
- var import_async3 = require("@dxos/async");
40
- var import_log3 = require("@dxos/log");
41
- var import_async4 = require("@dxos/async");
42
- var import_echo3 = require("@dxos/client/echo");
43
- var import_context2 = require("@dxos/context");
44
- var import_echo_schema = require("@dxos/echo-schema");
45
- var import_invariant = require("@dxos/invariant");
46
- var import_keys2 = require("@dxos/keys");
47
- var import_log4 = require("@dxos/log");
48
- var import_util2 = require("@dxos/util");
49
- var __dxlog_file = "/home/runner/work/dxos/dxos/packages/core/functions/src/function/function-registry.ts";
50
- var FunctionRegistry = class extends import_context.Resource {
51
- constructor(_client) {
52
- super();
53
- this._client = _client;
54
- this._functionBySpaceKey = new import_util.ComplexMap(import_keys.PublicKey.hash);
55
- this.registered = new import_async.Event();
56
- }
57
- getFunctions(space) {
58
- return this._functionBySpaceKey.get(space.key) ?? [];
59
- }
60
- getUniqueByUri() {
61
- const uniqueByUri = [
62
- ...this._functionBySpaceKey.values()
63
- ].flatMap((defs) => defs).reduce((acc, v) => {
64
- acc.set(v.uri, v);
65
- return acc;
66
- }, /* @__PURE__ */ new Map());
67
- return [
68
- ...uniqueByUri.values()
69
- ];
70
- }
71
- /**
72
- * Loads function definitions from the manifest into the space.
73
- * We first load all the definitions from the space to deduplicate by functionId.
74
- */
75
- async register(space, functions) {
76
- (0, import_log.log)("register", {
77
- space: space.key,
78
- functions: functions?.length ?? 0
79
- }, {
80
- F: __dxlog_file,
81
- L: 48,
82
- S: this,
83
- C: (f, a) => f(...a)
84
- });
85
- if (!functions?.length) {
86
- return;
87
- }
88
- if (!space.db.graph.schemaRegistry.hasSchema(import_chunk_SV5NRE5L.FunctionDef)) {
89
- space.db.graph.schemaRegistry.addSchema([
90
- import_chunk_SV5NRE5L.FunctionDef
91
- ]);
92
- }
93
- const { objects: existing } = await space.db.query(import_echo.Filter.schema(import_chunk_SV5NRE5L.FunctionDef)).run();
94
- const { added } = (0, import_util.diff)(existing, functions, (a, b) => a.uri === b.uri);
95
- added.forEach((def) => space.db.add((0, import_echo.live)(import_chunk_SV5NRE5L.FunctionDef, def)));
96
- if (added.length > 0) {
97
- await space.db.flush({
98
- indexes: true,
99
- updates: true
100
- });
101
- }
102
- }
103
- async _open() {
104
- import_log.log.info("opening...", void 0, {
105
- F: __dxlog_file,
106
- L: 68,
107
- S: this,
108
- C: (f, a) => f(...a)
109
- });
110
- const spacesSubscription = this._client.spaces.subscribe(async (spaces) => {
111
- for (const space of spaces) {
112
- if (this._functionBySpaceKey.has(space.key)) {
113
- continue;
114
- }
115
- const registered = [];
116
- this._functionBySpaceKey.set(space.key, registered);
117
- await space.waitUntilReady();
118
- if (this._ctx.disposed) {
119
- break;
120
- }
121
- this._ctx.onDispose(space.db.query(import_echo.Filter.schema(import_chunk_SV5NRE5L.FunctionDef)).subscribe(({ objects }) => {
122
- const { added } = (0, import_util.diff)(registered, objects, (a, b) => a.uri === b.uri);
123
- if (added.length > 0) {
124
- registered.push(...added);
125
- this.registered.emit({
126
- space,
127
- added
128
- });
129
- }
130
- }));
131
- }
132
- });
133
- this._ctx.onDispose(() => spacesSubscription.unsubscribe());
134
- }
135
- async _close(_) {
136
- import_log.log.info("closing...", void 0, {
137
- F: __dxlog_file,
138
- L: 101,
139
- S: this,
140
- C: (f, a) => f(...a)
141
- });
142
- this._functionBySpaceKey.clear();
143
- }
144
- };
145
- var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/core/functions/src/trigger/type/subscription-trigger.ts";
146
- var createSubscriptionTrigger = async (ctx, space, spec, callback) => {
147
- const objectIds = /* @__PURE__ */ new Set();
148
- const task = new import_async2.UpdateScheduler(ctx, async () => {
149
- if (objectIds.size > 0) {
150
- const objects = Array.from(objectIds);
151
- objectIds.clear();
152
- await callback({
153
- objects
154
- });
155
- }
156
- }, {
157
- maxFrequency: 4
158
- });
159
- const subscriptions = [];
160
- const subscription = (0, import_echo_db.createSubscription)(({ added, updated }) => {
161
- const sizeBefore = objectIds.size;
162
- for (const object of added) {
163
- objectIds.add(object.id);
164
- }
165
- for (const object of updated) {
166
- objectIds.add(object.id);
167
- }
168
- if (objectIds.size > sizeBefore) {
169
- import_log2.log.info("updated", {
170
- added: added.length,
171
- updated: updated.length
172
- }, {
173
- F: __dxlog_file2,
174
- L: 46,
175
- S: void 0,
176
- C: (f, a) => f(...a)
177
- });
178
- task.trigger();
179
- }
180
- });
181
- subscriptions.push(() => subscription.unsubscribe());
182
- const { filter, options: { deep, delay } = {} } = spec;
183
- const update = ({ objects }) => {
184
- import_log2.log.info("update", {
185
- objects: objects.length
186
- }, {
187
- F: __dxlog_file2,
188
- L: 56,
189
- S: void 0,
190
- C: (f, a) => f(...a)
191
- });
192
- subscription.update(objects);
193
- if (deep) {
194
- }
195
- };
196
- import_log2.log.info("subscription", {
197
- filter
198
- }, {
199
- F: __dxlog_file2,
200
- L: 74,
201
- S: void 0,
202
- C: (f, a) => f(...a)
203
- });
204
- if (filter.type) {
205
- const query = space.db.query(import_echo2.Filter.typename(filter.type, filter.props));
206
- subscriptions.push(query.subscribe(delay ? (0, import_async2.debounce)(update, delay) : update));
207
- }
208
- ctx.onDispose(() => {
209
- subscriptions.forEach((unsubscribe) => unsubscribe());
210
- });
211
- };
212
- var __dxlog_file3 = "/home/runner/work/dxos/dxos/packages/core/functions/src/trigger/type/timer-trigger.ts";
213
- var createTimerTrigger = async (ctx, space, spec, callback) => {
214
- const task = new import_async3.DeferredTask(ctx, async () => {
215
- await callback({});
216
- });
217
- let last = 0;
218
- let run = 0;
219
- const schedule = (0, import_cron_schedule.parseCronExpression)(spec.cron);
220
- const getRunTimeout = () => Date.now() - schedule.getNextDate().getTime();
221
- const runCron = () => {
222
- if (ctx.disposed) {
223
- return;
224
- }
225
- const now = Date.now();
226
- const delta = last ? now - last : 0;
227
- last = now;
228
- run++;
229
- import_log3.log.info("tick", {
230
- space: space.key.truncate(),
231
- count: run,
232
- delta
233
- }, {
234
- F: __dxlog_file3,
235
- L: 39,
236
- S: void 0,
237
- C: (f, a) => f(...a)
238
- });
239
- task.schedule();
240
- timeout = setTimeout(runCron, getRunTimeout());
241
- };
242
- let timeout = setTimeout(runCron, getRunTimeout());
243
- ctx.onDispose(() => clearTimeout(timeout));
244
- };
245
- var __dxlog_file4 = "/home/runner/work/dxos/dxos/packages/core/functions/src/trigger/trigger-registry.ts";
246
- var triggerFactory = {
247
- timer: createTimerTrigger,
248
- // TODO(burdon): Cannot use in browser.
249
- // webhook: createWebhookTrigger,
250
- subscription: createSubscriptionTrigger
251
- };
252
- var TriggerRegistry = class extends import_context2.Resource {
253
- constructor(_client, _options) {
254
- super();
255
- this._client = _client;
256
- this._options = _options;
257
- this._triggersBySpaceKey = new import_util2.ComplexMap(import_keys2.PublicKey.hash);
258
- this.registered = new import_async4.Event();
259
- this.removed = new import_async4.Event();
260
- }
261
- getActiveTriggers(space) {
262
- return this._getTriggers(space, (t) => t.activationCtx != null);
263
- }
264
- getInactiveTriggers(space) {
265
- return this._getTriggers(space, (t) => t.activationCtx == null);
266
- }
267
- /**
268
- * Set callback for trigger.
269
- */
270
- async activate(space, trigger, callback) {
271
- (0, import_log4.log)("activate", {
272
- space: space.key,
273
- trigger
274
- }, {
275
- F: __dxlog_file4,
276
- L: 75,
277
- S: this,
278
- C: (f, a) => f(...a)
279
- });
280
- const activationCtx = new import_context2.Context({
281
- name: `FunctionTrigger-${trigger.function}`
282
- }, {
283
- F: __dxlog_file4,
284
- L: 77
285
- });
286
- this._ctx.onDispose(() => activationCtx.dispose());
287
- const registeredTrigger = this._triggersBySpaceKey.get(space.key)?.find((reg) => reg.trigger.id === trigger.id);
288
- (0, import_invariant.invariant)(registeredTrigger, `Trigger is not registered: ${trigger.function}`, {
289
- F: __dxlog_file4,
290
- L: 80,
291
- S: this,
292
- A: [
293
- "registeredTrigger",
294
- "`Trigger is not registered: ${trigger.function}`"
295
- ]
296
- });
297
- registeredTrigger.activationCtx = activationCtx;
298
- try {
299
- (0, import_invariant.invariant)(trigger.spec, void 0, {
300
- F: __dxlog_file4,
301
- L: 85,
302
- S: this,
303
- A: [
304
- "trigger.spec",
305
- ""
306
- ]
307
- });
308
- const options = this._options?.[trigger.spec.type];
309
- const createTrigger = triggerFactory[trigger.spec.type];
310
- (0, import_invariant.invariant)(createTrigger, `Trigger factory not found: ${trigger.spec.type}`, {
311
- F: __dxlog_file4,
312
- L: 88,
313
- S: this,
314
- A: [
315
- "createTrigger",
316
- "`Trigger factory not found: ${trigger.spec.type}`"
317
- ]
318
- });
319
- await createTrigger(activationCtx, space, trigger.spec, callback, options);
320
- } catch (err) {
321
- delete registeredTrigger.activationCtx;
322
- throw err;
323
- }
324
- }
325
- /**
326
- * Loads triggers from the manifest into the space.
327
- */
328
- async register(space, manifest) {
329
- (0, import_log4.log)("register", {
330
- space: space.key
331
- }, {
332
- F: __dxlog_file4,
333
- L: 100,
334
- S: this,
335
- C: (f, a) => f(...a)
336
- });
337
- if (!manifest.triggers?.length) {
338
- return;
339
- }
340
- if (!space.db.graph.schemaRegistry.hasSchema(import_chunk_SV5NRE5L.FunctionTrigger)) {
341
- space.db.graph.schemaRegistry.addSchema([
342
- import_chunk_SV5NRE5L.FunctionTrigger
343
- ]);
344
- }
345
- const manifestTriggers = manifest.triggers.map((trigger) => {
346
- let keys = trigger[import_echo_schema.ECHO_ATTR_META]?.keys;
347
- delete trigger[import_echo_schema.ECHO_ATTR_META];
348
- if (!keys?.length) {
349
- keys = [
350
- (0, import_echo_schema.foreignKey)("manifest", [
351
- trigger.function,
352
- trigger.spec?.type
353
- ].join(":"))
354
- ];
355
- }
356
- return (0, import_echo3.live)(import_chunk_SV5NRE5L.FunctionTrigger, trigger, {
357
- keys
358
- });
359
- });
360
- const { objects: existing } = await space.db.query(import_echo3.Filter.schema(import_chunk_SV5NRE5L.FunctionTrigger)).run();
361
- const { added } = (0, import_util2.diff)(existing, manifestTriggers, import_echo3.compareForeignKeys);
362
- added.forEach((trigger) => {
363
- space.db.add(trigger);
364
- import_log4.log.info("added", {
365
- meta: (0, import_echo3.getMeta)(trigger)
366
- }, {
367
- F: __dxlog_file4,
368
- L: 127,
369
- S: this,
370
- C: (f, a) => f(...a)
371
- });
372
- });
373
- if (added.length > 0) {
374
- await space.db.flush();
375
- }
376
- }
377
- async _open() {
378
- import_log4.log.info("open...", void 0, {
379
- F: __dxlog_file4,
380
- L: 136,
381
- S: this,
382
- C: (f, a) => f(...a)
383
- });
384
- const spaceListSubscription = this._client.spaces.subscribe(async (spaces) => {
385
- for (const space of spaces) {
386
- if (this._triggersBySpaceKey.has(space.key)) {
387
- continue;
388
- }
389
- const registered = [];
390
- this._triggersBySpaceKey.set(space.key, registered);
391
- await space.waitUntilReady();
392
- if (this._ctx.disposed) {
393
- break;
394
- }
395
- this._ctx.onDispose(space.db.query(import_echo3.Filter.schema(import_chunk_SV5NRE5L.FunctionTrigger)).subscribe(async ({ objects: current }) => {
396
- import_log4.log.info("update", {
397
- space: space.key,
398
- registered: registered.length,
399
- current: current.length
400
- }, {
401
- F: __dxlog_file4,
402
- L: 153,
403
- S: this,
404
- C: (f, a) => f(...a)
405
- });
406
- await this._handleRemovedTriggers(space, current, registered);
407
- this._handleNewTriggers(space, current, registered);
408
- }));
409
- }
410
- });
411
- this._ctx.onDispose(() => spaceListSubscription.unsubscribe());
412
- import_log4.log.info("opened", void 0, {
413
- F: __dxlog_file4,
414
- L: 162,
415
- S: this,
416
- C: (f, a) => f(...a)
417
- });
418
- }
419
- async _close(_) {
420
- import_log4.log.info("close...", void 0, {
421
- F: __dxlog_file4,
422
- L: 166,
423
- S: this,
424
- C: (f, a) => f(...a)
425
- });
426
- this._triggersBySpaceKey.clear();
427
- import_log4.log.info("closed", void 0, {
428
- F: __dxlog_file4,
429
- L: 168,
430
- S: this,
431
- C: (f, a) => f(...a)
432
- });
433
- }
434
- _handleNewTriggers(space, current, registered) {
435
- const added = current.filter((candidate) => {
436
- return candidate.enabled && registered.find((reg) => reg.trigger.id === candidate.id) == null;
437
- });
438
- if (added.length > 0) {
439
- const newRegisteredTriggers = added.map((trigger) => ({
440
- trigger
441
- }));
442
- registered.push(...newRegisteredTriggers);
443
- import_log4.log.info("added", () => ({
444
- spaceKey: space.key,
445
- triggers: added.map((trigger) => trigger.function)
446
- }), {
447
- F: __dxlog_file4,
448
- L: 179,
449
- S: this,
450
- C: (f, a) => f(...a)
451
- });
452
- this.registered.emit({
453
- space,
454
- triggers: added
455
- });
456
- }
457
- }
458
- async _handleRemovedTriggers(space, current, registered) {
459
- const removed = [];
460
- for (let i = registered.length - 1; i >= 0; i--) {
461
- const wasRemoved = current.filter((trigger) => trigger.enabled).find((trigger) => trigger.id === registered[i].trigger.id) == null;
462
- if (wasRemoved) {
463
- const unregistered = registered.splice(i, 1)[0];
464
- await unregistered.activationCtx?.dispose();
465
- removed.push(unregistered.trigger);
466
- }
467
- }
468
- if (removed.length > 0) {
469
- import_log4.log.info("removed", () => ({
470
- spaceKey: space.key,
471
- triggers: removed.map((trigger) => trigger.function)
472
- }), {
473
- F: __dxlog_file4,
474
- L: 205,
475
- S: this,
476
- C: (f, a) => f(...a)
477
- });
478
- this.removed.emit({
479
- space,
480
- triggers: removed
481
- });
482
- }
483
- }
484
- _getTriggers(space, predicate) {
485
- const allSpaceTriggers = this._triggersBySpaceKey.get(space.key) ?? [];
486
- return allSpaceTriggers.filter(predicate).map((trigger) => trigger.trigger);
487
- }
488
- };
489
- // Annotate the CommonJS export names for ESM import in node:
490
- 0 && (module.exports = {
491
- FunctionRegistry,
492
- TriggerRegistry,
493
- createSubscriptionTrigger,
494
- createTimerTrigger
495
- });
496
- //# sourceMappingURL=chunk-FBIUZ7SD.cjs.map