@dxos/functions 0.7.4 → 0.7.5-labs.071a3e2

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 (87) hide show
  1. package/dist/lib/browser/{chunk-Y2OPAP26.mjs → chunk-FTGUA7ZJ.mjs} +2 -2
  2. package/dist/lib/browser/chunk-R4ERZ4GX.mjs +162 -0
  3. package/dist/lib/browser/chunk-R4ERZ4GX.mjs.map +7 -0
  4. package/dist/lib/browser/chunk-XRCXIG74.mjs +12 -0
  5. package/dist/lib/browser/chunk-YJEIETRB.mjs +128 -0
  6. package/dist/lib/browser/chunk-YJEIETRB.mjs.map +7 -0
  7. package/dist/lib/browser/edge/index.mjs +21 -0
  8. package/dist/lib/browser/index.mjs +27 -6
  9. package/dist/lib/browser/index.mjs.map +2 -2
  10. package/dist/lib/browser/meta.json +1 -1
  11. package/dist/lib/browser/testing/index.mjs +5 -3
  12. package/dist/lib/browser/testing/index.mjs.map +1 -1
  13. package/dist/lib/browser/{types.mjs → types/index.mjs} +7 -2
  14. package/dist/lib/browser/types/index.mjs.map +7 -0
  15. package/dist/lib/node/chunk-4WNFTPH7.cjs +188 -0
  16. package/dist/lib/node/chunk-4WNFTPH7.cjs.map +7 -0
  17. package/dist/lib/node/chunk-JEQ2X3Z6.cjs +34 -0
  18. package/dist/lib/node/chunk-JEQ2X3Z6.cjs.map +7 -0
  19. package/dist/lib/node/chunk-MZMHE4DC.cjs +154 -0
  20. package/dist/lib/node/chunk-MZMHE4DC.cjs.map +7 -0
  21. package/dist/lib/node/{chunk-CCULBUSE.cjs → chunk-NC6L7H5C.cjs} +15 -15
  22. package/dist/lib/node/edge/index.cjs +42 -0
  23. package/dist/lib/node/edge/index.cjs.map +7 -0
  24. package/dist/lib/node/index.cjs +38 -18
  25. package/dist/lib/node/index.cjs.map +2 -2
  26. package/dist/lib/node/meta.json +1 -1
  27. package/dist/lib/node/testing/index.cjs +11 -10
  28. package/dist/lib/node/testing/index.cjs.map +1 -1
  29. package/dist/lib/node/{types.cjs → types/index.cjs} +14 -9
  30. package/dist/lib/node/types/index.cjs.map +7 -0
  31. package/dist/lib/node-esm/chunk-DHGBFXSZ.mjs +12 -0
  32. package/dist/lib/node-esm/chunk-DHGBFXSZ.mjs.map +7 -0
  33. package/dist/lib/node-esm/{chunk-GGGGWYP6.mjs → chunk-FK2RGYVS.mjs} +2 -2
  34. package/dist/lib/node-esm/chunk-T2KBXTMR.mjs +128 -0
  35. package/dist/lib/node-esm/chunk-T2KBXTMR.mjs.map +7 -0
  36. package/dist/lib/node-esm/chunk-UOQLFLOW.mjs +162 -0
  37. package/dist/lib/node-esm/chunk-UOQLFLOW.mjs.map +7 -0
  38. package/dist/lib/node-esm/edge/index.mjs +21 -0
  39. package/dist/lib/node-esm/edge/index.mjs.map +7 -0
  40. package/dist/lib/node-esm/index.mjs +27 -6
  41. package/dist/lib/node-esm/index.mjs.map +2 -2
  42. package/dist/lib/node-esm/meta.json +1 -1
  43. package/dist/lib/node-esm/testing/index.mjs +5 -3
  44. package/dist/lib/node-esm/testing/index.mjs.map +1 -1
  45. package/dist/lib/node-esm/{types.mjs → types/index.mjs} +7 -2
  46. package/dist/lib/node-esm/types/index.mjs.map +7 -0
  47. package/dist/types/src/edge/functions.d.ts +25 -0
  48. package/dist/types/src/edge/functions.d.ts.map +1 -0
  49. package/dist/types/src/edge/index.d.ts +2 -0
  50. package/dist/types/src/edge/index.d.ts.map +1 -0
  51. package/dist/types/src/handler.d.ts.map +1 -1
  52. package/dist/types/src/index.d.ts +1 -0
  53. package/dist/types/src/index.d.ts.map +1 -1
  54. package/dist/types/src/testing/types.d.ts +3 -5
  55. package/dist/types/src/testing/types.d.ts.map +1 -1
  56. package/dist/types/src/translations.d.ts +9 -0
  57. package/dist/types/src/translations.d.ts.map +1 -0
  58. package/dist/types/src/types/index.d.ts +3 -0
  59. package/dist/types/src/types/index.d.ts.map +1 -0
  60. package/dist/types/src/types/schema.d.ts +57 -0
  61. package/dist/types/src/types/schema.d.ts.map +1 -0
  62. package/dist/types/src/{types.d.ts → types/types.d.ts} +76 -75
  63. package/dist/types/src/types/types.d.ts.map +1 -0
  64. package/dist/types/tsconfig.tsbuildinfo +1 -0
  65. package/package.json +27 -20
  66. package/src/edge/functions.ts +120 -0
  67. package/src/edge/index.ts +5 -0
  68. package/src/handler.ts +1 -0
  69. package/src/index.ts +1 -0
  70. package/src/translations.ts +15 -0
  71. package/src/trigger/trigger-registry.test.ts +3 -1
  72. package/src/types/index.ts +6 -0
  73. package/src/types/schema.ts +46 -0
  74. package/src/{types.ts → types/types.ts} +8 -0
  75. package/dist/lib/browser/chunk-N5D5R4Q4.mjs +0 -129
  76. package/dist/lib/browser/chunk-N5D5R4Q4.mjs.map +0 -7
  77. package/dist/lib/node/chunk-JMJCJ3SA.cjs +0 -156
  78. package/dist/lib/node/chunk-JMJCJ3SA.cjs.map +0 -7
  79. package/dist/lib/node/types.cjs.map +0 -7
  80. package/dist/lib/node-esm/chunk-2NACE6MJ.mjs +0 -129
  81. package/dist/lib/node-esm/chunk-2NACE6MJ.mjs.map +0 -7
  82. package/dist/types/src/types.d.ts.map +0 -1
  83. /package/dist/lib/browser/{chunk-Y2OPAP26.mjs.map → chunk-FTGUA7ZJ.mjs.map} +0 -0
  84. /package/dist/lib/browser/{types.mjs.map → chunk-XRCXIG74.mjs.map} +0 -0
  85. /package/dist/lib/{node-esm/types.mjs.map → browser/edge/index.mjs.map} +0 -0
  86. /package/dist/lib/node/{chunk-CCULBUSE.cjs.map → chunk-NC6L7H5C.cjs.map} +0 -0
  87. /package/dist/lib/node-esm/{chunk-GGGGWYP6.mjs.map → chunk-FK2RGYVS.mjs.map} +0 -0
@@ -2,7 +2,7 @@ import "@dxos/node-std/globals";
2
2
  import {
3
3
  FunctionDef,
4
4
  FunctionTrigger
5
- } from "./chunk-N5D5R4Q4.mjs";
5
+ } from "./chunk-R4ERZ4GX.mjs";
6
6
 
7
7
  // packages/core/functions/src/function/function-registry.ts
8
8
  import { Event } from "@dxos/async";
@@ -477,4 +477,4 @@ export {
477
477
  createTimerTrigger,
478
478
  TriggerRegistry
479
479
  };
480
- //# sourceMappingURL=chunk-Y2OPAP26.mjs.map
480
+ //# sourceMappingURL=chunk-FTGUA7ZJ.mjs.map
@@ -0,0 +1,162 @@
1
+ import "@dxos/node-std/globals";
2
+
3
+ // packages/core/functions/src/types/schema.ts
4
+ import { JsonSchemaType, Ref, S, TypedObject } from "@dxos/echo-schema";
5
+ import { TextType } from "@dxos/schema";
6
+ var ScriptType = class extends TypedObject({
7
+ typename: "dxos.org/type/Script",
8
+ version: "0.1.0"
9
+ })({
10
+ // TODO(burdon): Change to URI?
11
+ name: S.optional(S.String),
12
+ description: S.optional(S.String),
13
+ // TODO(burdon): Change to hash of deployed content.
14
+ // Whether source has changed since last deploy.
15
+ changed: S.optional(S.Boolean),
16
+ source: Ref(TextType)
17
+ }) {
18
+ };
19
+ var FunctionType = class extends TypedObject({
20
+ typename: "dxos.org/type/Function",
21
+ version: "0.1.0"
22
+ })({
23
+ // TODO(burdon): Rename to id/uri?
24
+ name: S.NonEmptyString,
25
+ version: S.String,
26
+ description: S.optional(S.String),
27
+ // Reference to a source script if it exists within ECHO.
28
+ // TODO(burdon): Don't ref ScriptType directly (core).
29
+ source: S.optional(Ref(ScriptType)),
30
+ inputSchema: S.optional(JsonSchemaType),
31
+ // Local binding to a function name.
32
+ binding: S.optional(S.String)
33
+ }) {
34
+ };
35
+
36
+ // packages/core/functions/src/types/types.ts
37
+ import { AST, OptionsAnnotationId, RawObject, S as S2, TypedObject as TypedObject2 } from "@dxos/echo-schema";
38
+ var TriggerKind;
39
+ (function(TriggerKind2) {
40
+ TriggerKind2["Timer"] = "timer";
41
+ TriggerKind2["Webhook"] = "webhook";
42
+ TriggerKind2["Subscription"] = "subscription";
43
+ TriggerKind2["Email"] = "email";
44
+ })(TriggerKind || (TriggerKind = {}));
45
+ var typeLiteralAnnotations = {
46
+ [AST.TitleAnnotationId]: "Type"
47
+ };
48
+ var TimerTriggerSchema = S2.Struct({
49
+ type: S2.Literal("timer").annotations(typeLiteralAnnotations),
50
+ cron: S2.String.annotations({
51
+ [AST.TitleAnnotationId]: "Cron",
52
+ [AST.ExamplesAnnotationId]: [
53
+ "0 0 * * *"
54
+ ]
55
+ })
56
+ }).pipe(S2.mutable);
57
+ var EmailTriggerSchema = S2.Struct({
58
+ type: S2.Literal("email").annotations(typeLiteralAnnotations)
59
+ }).pipe(S2.mutable);
60
+ var WebhookTriggerSchema = S2.Struct({
61
+ type: S2.Literal("webhook").annotations(typeLiteralAnnotations),
62
+ method: S2.optional(S2.String.annotations({
63
+ [AST.TitleAnnotationId]: "Method",
64
+ [OptionsAnnotationId]: [
65
+ "GET",
66
+ "POST"
67
+ ]
68
+ })),
69
+ port: S2.optional(S2.Number.annotations({
70
+ [AST.TitleAnnotationId]: "Port"
71
+ }))
72
+ }).pipe(S2.mutable);
73
+ var QuerySchema = S2.Struct({
74
+ type: S2.optional(S2.String.annotations({
75
+ [AST.TitleAnnotationId]: "Type"
76
+ })),
77
+ props: S2.optional(S2.Record({
78
+ key: S2.String,
79
+ value: S2.Any
80
+ }))
81
+ }).annotations({
82
+ [AST.TitleAnnotationId]: "Query"
83
+ });
84
+ var SubscriptionTriggerSchema = S2.Struct({
85
+ type: S2.Literal("subscription").annotations(typeLiteralAnnotations),
86
+ // TODO(burdon): Define query DSL (from ECHO). Reconcile with Table.Query.
87
+ filter: QuerySchema,
88
+ options: S2.optional(S2.Struct({
89
+ // Watch changes to object (not just creation).
90
+ deep: S2.optional(S2.Boolean.annotations({
91
+ [AST.TitleAnnotationId]: "Nested"
92
+ })),
93
+ // Debounce changes (delay in ms).
94
+ delay: S2.optional(S2.Number.annotations({
95
+ [AST.TitleAnnotationId]: "Delay"
96
+ }))
97
+ }).annotations({
98
+ [AST.TitleAnnotationId]: "Options"
99
+ }))
100
+ }).pipe(S2.mutable);
101
+ var TriggerSchema = S2.Union(
102
+ //
103
+ TimerTriggerSchema,
104
+ WebhookTriggerSchema,
105
+ SubscriptionTriggerSchema,
106
+ EmailTriggerSchema
107
+ ).annotations({
108
+ [AST.TitleAnnotationId]: "Trigger"
109
+ });
110
+ var FunctionTriggerSchema = S2.Struct({
111
+ // TODO(burdon): What type does this reference.
112
+ function: S2.optional(S2.String.annotations({
113
+ [AST.TitleAnnotationId]: "Function"
114
+ })),
115
+ enabled: S2.optional(S2.Boolean.annotations({
116
+ [AST.TitleAnnotationId]: "Enabled"
117
+ })),
118
+ // TODO(burdon): Flatten entire schema.
119
+ spec: S2.optional(TriggerSchema),
120
+ // TODO(burdon): Get meta from function.
121
+ // The `meta` property is merged into the event data passed to the function.
122
+ meta: S2.optional(S2.mutable(S2.Record({
123
+ key: S2.String,
124
+ value: S2.Any
125
+ })))
126
+ });
127
+ var FunctionTrigger = class extends TypedObject2({
128
+ typename: "dxos.org/type/FunctionTrigger",
129
+ version: "0.1.0"
130
+ })(FunctionTriggerSchema.fields) {
131
+ };
132
+ var FunctionDef = class extends TypedObject2({
133
+ typename: "dxos.org/type/FunctionDef",
134
+ version: "0.1.0"
135
+ })({
136
+ uri: S2.String,
137
+ description: S2.optional(S2.String),
138
+ route: S2.String,
139
+ handler: S2.String
140
+ }) {
141
+ };
142
+ var FunctionManifestSchema = S2.Struct({
143
+ functions: S2.optional(S2.mutable(S2.Array(RawObject(FunctionDef)))),
144
+ triggers: S2.optional(S2.mutable(S2.Array(RawObject(FunctionTrigger))))
145
+ });
146
+ var FUNCTION_TYPES = [
147
+ FunctionDef,
148
+ FunctionTrigger
149
+ ];
150
+
151
+ export {
152
+ ScriptType,
153
+ FunctionType,
154
+ TriggerKind,
155
+ TriggerSchema,
156
+ FunctionTriggerSchema,
157
+ FunctionTrigger,
158
+ FunctionDef,
159
+ FunctionManifestSchema,
160
+ FUNCTION_TYPES
161
+ };
162
+ //# sourceMappingURL=chunk-R4ERZ4GX.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/types/schema.ts", "../../../src/types/types.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { JsonSchemaType, Ref, S, TypedObject } from '@dxos/echo-schema';\nimport { TextType } from '@dxos/schema';\n\n/**\n * Source script.\n */\nexport class ScriptType extends TypedObject({\n typename: 'dxos.org/type/Script',\n version: '0.1.0',\n})({\n // TODO(burdon): Change to URI?\n name: S.optional(S.String),\n description: S.optional(S.String),\n // TODO(burdon): Change to hash of deployed content.\n // Whether source has changed since last deploy.\n changed: S.optional(S.Boolean),\n source: Ref(TextType),\n}) {}\n\n/**\n * Function deployment.\n */\n// TODO(burdon): Move to core/functions.\nexport class FunctionType extends TypedObject({\n typename: 'dxos.org/type/Function',\n version: '0.1.0',\n})({\n // TODO(burdon): Rename to id/uri?\n name: S.NonEmptyString,\n version: S.String,\n\n description: S.optional(S.String),\n\n // Reference to a source script if it exists within ECHO.\n // TODO(burdon): Don't ref ScriptType directly (core).\n source: S.optional(Ref(ScriptType)),\n\n inputSchema: S.optional(JsonSchemaType),\n\n // Local binding to a function name.\n binding: S.optional(S.String),\n}) {}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { AST, OptionsAnnotationId, RawObject, S, TypedObject } from '@dxos/echo-schema';\n\n/**\n * Type discriminator for TriggerType.\n * Every spec has a type field of type TriggerKind that we can use to understand which type we're working with.\n * https://www.typescriptlang.org/docs/handbook/2/narrowing.html#discriminated-unions\n */\nexport enum TriggerKind {\n Timer = 'timer',\n Webhook = 'webhook',\n Subscription = 'subscription',\n Email = 'email',\n}\n\n// TODO(burdon): Rename prop kind.\nconst typeLiteralAnnotations = { [AST.TitleAnnotationId]: 'Type' };\n\n/**\n * Cron timer.\n */\nconst TimerTriggerSchema = S.Struct({\n type: S.Literal(TriggerKind.Timer).annotations(typeLiteralAnnotations),\n cron: S.String.annotations({\n [AST.TitleAnnotationId]: 'Cron',\n [AST.ExamplesAnnotationId]: ['0 0 * * *'],\n }),\n}).pipe(S.mutable);\n\nexport type TimerTrigger = S.Schema.Type<typeof TimerTriggerSchema>;\n\nconst EmailTriggerSchema = S.Struct({\n type: S.Literal(TriggerKind.Email).annotations(typeLiteralAnnotations),\n}).pipe(S.mutable);\n\nexport type EmailTrigger = S.Schema.Type<typeof EmailTriggerSchema>;\n\n/**\n * Webhook.\n */\nconst WebhookTriggerSchema = S.Struct({\n type: S.Literal(TriggerKind.Webhook).annotations(typeLiteralAnnotations),\n method: S.optional(\n S.String.annotations({\n [AST.TitleAnnotationId]: 'Method',\n [OptionsAnnotationId]: ['GET', 'POST'],\n }),\n ),\n port: S.optional(\n S.Number.annotations({\n [AST.TitleAnnotationId]: 'Port',\n }),\n ),\n}).pipe(S.mutable);\n\nexport type WebhookTrigger = S.Schema.Type<typeof WebhookTriggerSchema>;\n\n// TODO(burdon): Use ECHO definition (from https://github.com/dxos/dxos/pull/8233).\nconst QuerySchema = S.Struct({\n type: S.optional(S.String.annotations({ [AST.TitleAnnotationId]: 'Type' })),\n props: S.optional(S.Record({ key: S.String, value: S.Any })),\n}).annotations({ [AST.TitleAnnotationId]: 'Query' });\n\n/**\n * Subscription.\n */\nconst SubscriptionTriggerSchema = S.Struct({\n type: S.Literal(TriggerKind.Subscription).annotations(typeLiteralAnnotations),\n // TODO(burdon): Define query DSL (from ECHO). Reconcile with Table.Query.\n filter: QuerySchema,\n options: S.optional(\n S.Struct({\n // Watch changes to object (not just creation).\n deep: S.optional(S.Boolean.annotations({ [AST.TitleAnnotationId]: 'Nested' })),\n // Debounce changes (delay in ms).\n delay: S.optional(S.Number.annotations({ [AST.TitleAnnotationId]: 'Delay' })),\n }).annotations({ [AST.TitleAnnotationId]: 'Options' }),\n ),\n}).pipe(S.mutable);\n\nexport type SubscriptionTrigger = S.Schema.Type<typeof SubscriptionTriggerSchema>;\n\n/**\n * Trigger schema (discriminated union).\n */\nexport const TriggerSchema = S.Union(\n //\n TimerTriggerSchema,\n WebhookTriggerSchema,\n SubscriptionTriggerSchema,\n EmailTriggerSchema,\n).annotations({\n [AST.TitleAnnotationId]: 'Trigger',\n});\n\nexport type TriggerType = S.Schema.Type<typeof TriggerSchema>;\n\n/**\n * Function trigger.\n */\nexport const FunctionTriggerSchema = S.Struct({\n // TODO(burdon): What type does this reference.\n function: S.optional(S.String.annotations({ [AST.TitleAnnotationId]: 'Function' })),\n\n enabled: S.optional(S.Boolean.annotations({ [AST.TitleAnnotationId]: 'Enabled' })),\n\n // TODO(burdon): Flatten entire schema.\n spec: S.optional(TriggerSchema),\n\n // TODO(burdon): Get meta from function.\n // The `meta` property is merged into the event data passed to the function.\n meta: S.optional(S.mutable(S.Record({ key: S.String, value: S.Any }))),\n});\n\nexport type FunctionTriggerType = S.Schema.Type<typeof FunctionTriggerSchema>;\n\n/**\n * Function trigger.\n */\nexport class FunctionTrigger extends TypedObject({\n typename: 'dxos.org/type/FunctionTrigger',\n version: '0.1.0',\n})(FunctionTriggerSchema.fields) {}\n\n/**\n * Function definition.\n * @deprecated (Use dxos.org/type/Function)\n */\n// TODO(burdon): Reconcile with FunctionType.\nexport class FunctionDef extends TypedObject({\n typename: 'dxos.org/type/FunctionDef',\n version: '0.1.0',\n})({\n uri: S.String,\n description: S.optional(S.String),\n route: S.String,\n handler: S.String,\n}) {}\n\n/**\n * Function manifest file.\n */\nexport const FunctionManifestSchema = S.Struct({\n functions: S.optional(S.mutable(S.Array(RawObject(FunctionDef)))),\n triggers: S.optional(S.mutable(S.Array(RawObject(FunctionTrigger)))),\n});\n\nexport type FunctionManifest = S.Schema.Type<typeof FunctionManifestSchema>;\n\nexport const FUNCTION_TYPES = [FunctionDef, FunctionTrigger];\n"],
5
+ "mappings": "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",
6
+ "names": ["JsonSchemaType", "Ref", "S", "TypedObject", "TextType", "ScriptType", "TypedObject", "typename", "version", "name", "S", "optional", "String", "description", "changed", "Boolean", "source", "Ref", "TextType", "FunctionType", "NonEmptyString", "inputSchema", "JsonSchemaType", "binding", "AST", "OptionsAnnotationId", "RawObject", "S", "TypedObject", "TriggerKind", "typeLiteralAnnotations", "AST", "TitleAnnotationId", "TimerTriggerSchema", "S", "Struct", "type", "Literal", "annotations", "cron", "String", "ExamplesAnnotationId", "pipe", "mutable", "EmailTriggerSchema", "WebhookTriggerSchema", "method", "optional", "OptionsAnnotationId", "port", "Number", "QuerySchema", "props", "Record", "key", "value", "Any", "SubscriptionTriggerSchema", "filter", "options", "deep", "Boolean", "delay", "TriggerSchema", "Union", "FunctionTriggerSchema", "function", "enabled", "spec", "meta", "FunctionTrigger", "TypedObject", "typename", "version", "fields", "FunctionDef", "uri", "description", "route", "handler", "FunctionManifestSchema", "functions", "Array", "RawObject", "triggers", "FUNCTION_TYPES"]
7
+ }
@@ -0,0 +1,12 @@
1
+ import "@dxos/node-std/globals";
2
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
3
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
4
+ }) : x)(function(x) {
5
+ if (typeof require !== "undefined") return require.apply(this, arguments);
6
+ throw Error('Dynamic require of "' + x + '" is not supported');
7
+ });
8
+
9
+ export {
10
+ __require
11
+ };
12
+ //# sourceMappingURL=chunk-XRCXIG74.mjs.map
@@ -0,0 +1,128 @@
1
+ import "@dxos/node-std/globals";
2
+
3
+ // packages/core/functions/src/edge/functions.ts
4
+ import { EdgeHttpClient } from "@dxos/edge-client";
5
+ import { invariant } from "@dxos/invariant";
6
+ import { log } from "@dxos/log";
7
+ var __dxlog_file = "/home/runner/work/dxos/dxos/packages/core/functions/src/edge/functions.ts";
8
+ var FUNCTIONS_META_KEY = "dxos.org/service/function";
9
+ var FUNCTIONS_PRESET_META_KEY = "dxos.org/service/function-preset";
10
+ var uploadWorkerFunction = async ({ client, name, version, source, spaceId, functionId }) => {
11
+ const edgeUrl = client.config.values.runtime?.services?.edge?.url;
12
+ invariant(edgeUrl, "Edge is not configured.", {
13
+ F: __dxlog_file,
14
+ L: 38,
15
+ S: void 0,
16
+ A: [
17
+ "edgeUrl",
18
+ "'Edge is not configured.'"
19
+ ]
20
+ });
21
+ const edgeClient = new EdgeHttpClient(edgeUrl);
22
+ const edgeIdentity = createEdgeIdentity(client);
23
+ edgeClient.setIdentity(edgeIdentity);
24
+ const response = await edgeClient.uploadFunction({
25
+ spaceId,
26
+ functionId
27
+ }, {
28
+ name,
29
+ version,
30
+ script: source
31
+ });
32
+ log("Uploaded", {
33
+ functionId,
34
+ source,
35
+ name,
36
+ identityKey: edgeIdentity.identityKey,
37
+ response
38
+ }, {
39
+ F: __dxlog_file,
40
+ L: 44,
41
+ S: void 0,
42
+ C: (f, a) => f(...a)
43
+ });
44
+ return response;
45
+ };
46
+ var getUserFunctionUrlInMetadata = (meta) => {
47
+ return meta.keys.find((key) => key.source === FUNCTIONS_META_KEY)?.id;
48
+ };
49
+ var setUserFunctionUrlInMetadata = (meta, functionUrl) => {
50
+ const key = meta.keys.find((key2) => key2.source === FUNCTIONS_META_KEY);
51
+ if (key) {
52
+ if (key.id !== functionUrl) {
53
+ throw new Error("Metadata mismatch");
54
+ }
55
+ } else {
56
+ meta.keys.push({
57
+ source: FUNCTIONS_META_KEY,
58
+ id: functionUrl
59
+ });
60
+ }
61
+ };
62
+ var getInvocationUrl = (functionUrl, edgeUrl, options = {}) => {
63
+ const baseUrl = new URL("functions/", edgeUrl);
64
+ const relativeUrl = functionUrl.replace(/^\//, "");
65
+ const url = new URL(`./${relativeUrl}`, baseUrl.toString());
66
+ options.spaceId && url.searchParams.set("spaceId", options.spaceId);
67
+ options.subjectId && url.searchParams.set("subjectId", options.subjectId);
68
+ url.protocol = isSecure(url.protocol) ? "https" : "http";
69
+ return url.toString();
70
+ };
71
+ var isSecure = (protocol) => {
72
+ return protocol === "https:" || protocol === "wss:";
73
+ };
74
+ var createEdgeIdentity = (client) => {
75
+ const identity = client.halo.identity.get();
76
+ const device = client.halo.device;
77
+ if (!identity || !device) {
78
+ throw new Error("Identity not available");
79
+ }
80
+ return {
81
+ identityKey: identity.identityKey.toHex(),
82
+ peerKey: device.deviceKey.toHex(),
83
+ presentCredentials: async ({ challenge }) => {
84
+ const identityService = client.services.services.IdentityService;
85
+ const authCredential = await identityService.createAuthCredential();
86
+ return identityService.signPresentation({
87
+ presentation: {
88
+ credentials: [
89
+ authCredential
90
+ ]
91
+ },
92
+ nonce: challenge
93
+ });
94
+ }
95
+ };
96
+ };
97
+ var incrementSemverPatch = (version) => {
98
+ const [major, minor, patch] = version.split(".");
99
+ const patchNum = Number(patch);
100
+ invariant(!Number.isNaN(patchNum), "Unexpected function version format.", {
101
+ F: __dxlog_file,
102
+ L: 109,
103
+ S: void 0,
104
+ A: [
105
+ "!Number.isNaN(patchNum)",
106
+ "'Unexpected function version format.'"
107
+ ]
108
+ });
109
+ return [
110
+ major,
111
+ minor,
112
+ String(patchNum + 1)
113
+ ].join(".");
114
+ };
115
+ var publicKeyToDid = (key) => {
116
+ return `did:key:${key.toHex()}`;
117
+ };
118
+
119
+ export {
120
+ FUNCTIONS_PRESET_META_KEY,
121
+ uploadWorkerFunction,
122
+ getUserFunctionUrlInMetadata,
123
+ setUserFunctionUrlInMetadata,
124
+ getInvocationUrl,
125
+ incrementSemverPatch,
126
+ publicKeyToDid
127
+ };
128
+ //# sourceMappingURL=chunk-YJEIETRB.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 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 { type ObjectMeta } from '@dxos/echo-schema';\nimport { EdgeHttpClient, type EdgeIdentity } from '@dxos/edge-client';\nimport { invariant } from '@dxos/invariant';\nimport type { PublicKey, SpaceId } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type UploadFunctionResponseBody } from '@dxos/protocols';\n\n// TODO: use URL scheme for source?\nconst FUNCTIONS_META_KEY = 'dxos.org/service/function';\n\nexport const FUNCTIONS_PRESET_META_KEY = 'dxos.org/service/function-preset';\n\nexport type UploadWorkerArgs = {\n client: Client;\n name?: string;\n source: string;\n version: string;\n functionId?: string;\n spaceId: SpaceId;\n};\n\nexport const uploadWorkerFunction = async ({\n client,\n name,\n version,\n source,\n spaceId,\n functionId,\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({ spaceId, functionId }, { name, version, script: source });\n\n log('Uploaded', {\n functionId,\n source,\n name,\n identityKey: edgeIdentity.identityKey,\n response,\n });\n\n return response;\n};\n\nexport const getUserFunctionUrlInMetadata = (meta: ObjectMeta) => {\n return meta.keys.find((key) => key.source === FUNCTIONS_META_KEY)?.id;\n};\n\nexport const setUserFunctionUrlInMetadata = (meta: ObjectMeta, functionUrl: string) => {\n const key = meta.keys.find((key) => key.source === FUNCTIONS_META_KEY);\n if (key) {\n if (key.id !== functionUrl) {\n throw new Error('Metadata mismatch');\n }\n } else {\n meta.keys.push({ source: FUNCTIONS_META_KEY, id: functionUrl });\n }\n};\n\nexport const getInvocationUrl = (functionUrl: string, edgeUrl: string, options: InvocationOptions = {}) => {\n const baseUrl = new URL('functions/', edgeUrl);\n\n // Leading slashes cause the URL to be treated as an absolute path.\n const relativeUrl = functionUrl.replace(/^\\//, '');\n const url = new URL(`./${relativeUrl}`, baseUrl.toString());\n options.spaceId && url.searchParams.set('spaceId', options.spaceId);\n options.subjectId && url.searchParams.set('subjectId', options.subjectId);\n url.protocol = isSecure(url.protocol) ? 'https' : 'http';\n return url.toString();\n};\n\nconst isSecure = (protocol: string) => {\n return protocol === 'https:' || protocol === 'wss:';\n};\n\nconst createEdgeIdentity = (client: Client): EdgeIdentity => {\n const identity = client.halo.identity.get();\n const device = client.halo.device;\n if (!identity || !device) {\n throw new Error('Identity not available');\n }\n return {\n identityKey: identity.identityKey.toHex(),\n peerKey: device.deviceKey.toHex(),\n presentCredentials: async ({ challenge }) => {\n const identityService = client.services.services.IdentityService!;\n const authCredential = await identityService.createAuthCredential();\n return identityService.signPresentation({\n presentation: { credentials: [authCredential] },\n nonce: challenge,\n });\n },\n };\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.');\n return [major, minor, String(patchNum + 1)].join('.');\n};\n\nexport const publicKeyToDid = (key: PublicKey): DID => {\n return `did:key:${key.toHex()}`;\n};\n\nexport type InvocationOptions = {\n spaceId?: SpaceId;\n subjectId?: string;\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["EdgeHttpClient", "invariant", "log", "FUNCTIONS_META_KEY", "FUNCTIONS_PRESET_META_KEY", "uploadWorkerFunction", "client", "name", "version", "source", "spaceId", "functionId", "edgeUrl", "config", "values", "runtime", "services", "edge", "url", "edgeClient", "edgeIdentity", "createEdgeIdentity", "setIdentity", "response", "uploadFunction", "script", "identityKey", "getUserFunctionUrlInMetadata", "meta", "keys", "find", "key", "id", "setUserFunctionUrlInMetadata", "functionUrl", "Error", "push", "getInvocationUrl", "options", "baseUrl", "URL", "relativeUrl", "replace", "toString", "searchParams", "set", "subjectId", "protocol", "isSecure", "identity", "halo", "get", "device", "toHex", "peerKey", "deviceKey", "presentCredentials", "challenge", "identityService", "IdentityService", "authCredential", "createAuthCredential", "signPresentation", "presentation", "credentials", "nonce", "incrementSemverPatch", "major", "minor", "patch", "split", "patchNum", "Number", "isNaN", "String", "join", "publicKeyToDid"]
7
+ }
@@ -0,0 +1,21 @@
1
+ import "@dxos/node-std/globals";
2
+ import {
3
+ FUNCTIONS_PRESET_META_KEY,
4
+ getInvocationUrl,
5
+ getUserFunctionUrlInMetadata,
6
+ incrementSemverPatch,
7
+ publicKeyToDid,
8
+ setUserFunctionUrlInMetadata,
9
+ uploadWorkerFunction
10
+ } from "../chunk-YJEIETRB.mjs";
11
+ import "../chunk-XRCXIG74.mjs";
12
+ export {
13
+ FUNCTIONS_PRESET_META_KEY,
14
+ getInvocationUrl,
15
+ getUserFunctionUrlInMetadata,
16
+ incrementSemverPatch,
17
+ publicKeyToDid,
18
+ setUserFunctionUrlInMetadata,
19
+ uploadWorkerFunction
20
+ };
21
+ //# sourceMappingURL=index.mjs.map
@@ -1,19 +1,31 @@
1
1
  import "@dxos/node-std/globals";
2
+ import {
3
+ FUNCTIONS_PRESET_META_KEY,
4
+ getInvocationUrl,
5
+ getUserFunctionUrlInMetadata,
6
+ incrementSemverPatch,
7
+ publicKeyToDid,
8
+ setUserFunctionUrlInMetadata,
9
+ uploadWorkerFunction
10
+ } from "./chunk-YJEIETRB.mjs";
2
11
  import {
3
12
  FunctionRegistry,
4
13
  TriggerRegistry,
5
14
  createSubscriptionTrigger,
6
15
  createTimerTrigger
7
- } from "./chunk-Y2OPAP26.mjs";
16
+ } from "./chunk-FTGUA7ZJ.mjs";
8
17
  import {
9
18
  FUNCTION_TYPES,
10
19
  FunctionDef,
11
20
  FunctionManifestSchema,
12
21
  FunctionTrigger,
13
22
  FunctionTriggerSchema,
23
+ FunctionType,
24
+ ScriptType,
14
25
  TriggerKind,
15
26
  TriggerSchema
16
- } from "./chunk-N5D5R4Q4.mjs";
27
+ } from "./chunk-R4ERZ4GX.mjs";
28
+ import "./chunk-XRCXIG74.mjs";
17
29
 
18
30
  // packages/core/functions/src/handler.ts
19
31
  import { PublicKey } from "@dxos/client";
@@ -27,7 +39,7 @@ var subscriptionHandler = (handler, types) => {
27
39
  if (!space) {
28
40
  log.error("Invalid space", void 0, {
29
41
  F: __dxlog_file,
30
- L: 132,
42
+ L: 133,
31
43
  S: void 0,
32
44
  C: (f, a) => f(...a)
33
45
  });
@@ -40,7 +52,7 @@ var subscriptionHandler = (handler, types) => {
40
52
  data
41
53
  }, {
42
54
  F: __dxlog_file,
43
- L: 142,
55
+ L: 143,
44
56
  S: void 0,
45
57
  C: (f, a) => f(...a)
46
58
  });
@@ -50,7 +62,7 @@ var subscriptionHandler = (handler, types) => {
50
62
  objects: objects?.length
51
63
  }, {
52
64
  F: __dxlog_file,
53
- L: 144,
65
+ L: 145,
54
66
  S: void 0,
55
67
  C: (f, a) => f(...a)
56
68
  });
@@ -80,17 +92,26 @@ var registerTypes = (space, types = []) => {
80
92
  }
81
93
  };
82
94
  export {
95
+ FUNCTIONS_PRESET_META_KEY,
83
96
  FUNCTION_TYPES,
84
97
  FunctionDef,
85
98
  FunctionManifestSchema,
86
99
  FunctionRegistry,
87
100
  FunctionTrigger,
88
101
  FunctionTriggerSchema,
102
+ FunctionType,
103
+ ScriptType,
89
104
  TriggerKind,
90
105
  TriggerRegistry,
91
106
  TriggerSchema,
92
107
  createSubscriptionTrigger,
93
108
  createTimerTrigger,
94
- subscriptionHandler
109
+ getInvocationUrl,
110
+ getUserFunctionUrlInMetadata,
111
+ incrementSemverPatch,
112
+ publicKeyToDid,
113
+ setUserFunctionUrlInMetadata,
114
+ subscriptionHandler,
115
+ uploadWorkerFunction
95
116
  };
96
117
  //# sourceMappingURL=index.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/handler.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Schema as S } from '@effect/schema';\n\nimport { type Client, PublicKey } from '@dxos/client';\nimport { type Space, type SpaceId } from '@dxos/client/echo';\nimport type { CoreDatabase, ReactiveEchoObject } from '@dxos/echo-db';\nimport { log } from '@dxos/log';\nimport { nonNullable } from '@dxos/util';\n\n// TODO(burdon): Model after http request. Ref Lambda/OpenFaaS.\n// https://docs.aws.amazon.com/lambda/latest/dg/typescript-handler.html\n// https://www.serverless.com/framework/docs/providers/aws/guide/serverless.yml/#functions\n// https://www.npmjs.com/package/aws-lambda\n\n/**\n * Function handler.\n */\nexport type FunctionHandler<TData = {}, TMeta = {}> = (params: {\n context: FunctionContext;\n event: FunctionEvent<TData, TMeta>;\n\n /**\n * @deprecated\n */\n response: FunctionResponse;\n}) => Promise<Response | FunctionResponse | void>;\n\n/**\n * Function context.\n */\nexport interface FunctionContext {\n getSpace: (spaceId: SpaceId) => Promise<SpaceAPI>;\n\n /**\n * Space from which the function was invoked.\n */\n space: SpaceAPI | undefined;\n\n ai: FunctionContextAi;\n\n /**\n * @deprecated\n */\n // TODO(burdon): Limit access to individual space.\n client: Client;\n /**\n * @deprecated\n */\n // TODO(burdon): Replace with storage service abstraction.\n dataDir?: string;\n}\n\nexport interface FunctionContextAi {\n // TODO(dmaretskyi): Refer to cloudflare AI docs for more comprehensive typedefs.\n run(model: string, inputs: any, options?: any): Promise<any>;\n}\n\n/**\n * Event payload.\n */\nexport type FunctionEvent<TData = {}, TMeta = {}> = {\n data: FunctionEventMeta<TMeta> & TData;\n};\n\n/**\n * Metadata from trigger.\n */\nexport type FunctionEventMeta<TMeta = {}> = {\n meta: TMeta;\n};\n\n/**\n * Function response.\n */\nexport type FunctionResponse = {\n status(code: number): FunctionResponse;\n};\n\n//\n// API.\n//\n\n/**\n * Space interface available to functions.\n */\nexport interface SpaceAPI {\n get id(): SpaceId;\n get crud(): CoreDatabase;\n}\n\nconst __assertFunctionSpaceIsCompatibleWithTheClientSpace = () => {\n // eslint-disable-next-line unused-imports/no-unused-vars\n const y: SpaceAPI = {} as Space;\n};\n\n//\n// Subscription utils.\n//\n\nexport type RawSubscriptionData = {\n spaceKey?: string;\n objects?: string[];\n};\n\nexport type SubscriptionData = {\n space?: Space;\n objects?: ReactiveEchoObject<any>[];\n};\n\n/**\n * Handler wrapper for subscription events; extracts space and objects.\n *\n * To test:\n * ```\n * curl -s -X POST -H \"Content-Type: application/json\" --data '{\"space\": \"0446...1cbb\"}' http://localhost:7100/dev/email-extractor\n * ```\n *\n * NOTE: Get space key from devtools or `dx space list --json`\n */\n// TODO(burdon): Evolve into plugin definition like Composer.\nexport const subscriptionHandler = <TMeta>(\n handler: FunctionHandler<SubscriptionData, TMeta>,\n types?: S.Schema<any>[],\n): FunctionHandler<RawSubscriptionData, TMeta> => {\n return async ({ event: { data }, context, response, ...rest }) => {\n const { client } = context;\n const space = data.spaceKey ? client.spaces.get(PublicKey.from(data.spaceKey)) : undefined;\n if (!space) {\n log.error('Invalid space');\n return response.status(500);\n }\n\n registerTypes(space, types);\n const objects = space\n ? data.objects?.map<ReactiveEchoObject<any> | undefined>((id) => space!.db.getObjectById(id)).filter(nonNullable)\n : [];\n\n if (!!data.spaceKey && !space) {\n log.warn('invalid space', { data });\n } else {\n log.info('handler', { space: space?.key.truncate(), objects: objects?.length });\n }\n\n return handler({ event: { data: { ...data, space, objects } }, context, response, ...rest });\n };\n};\n\n// TODO(burdon): Evolve types as part of function metadata.\nconst registerTypes = (space: Space, types: S.Schema<any>[] = []) => {\n const registry = space.db.graph.schemaRegistry;\n for (const type of types) {\n if (!registry.hasSchema(type)) {\n registry.addSchema([type]);\n }\n }\n};\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAMA,SAAsBA,iBAAiB;AAGvC,SAASC,WAAW;AACpB,SAASC,mBAAmB;;AAiHrB,IAAMC,sBAAsB,CACjCC,SACAC,UAAAA;AAEA,SAAO,OAAO,EAAEC,OAAO,EAAEC,KAAI,GAAIC,SAASC,UAAU,GAAGC,KAAAA,MAAM;AAC3D,UAAM,EAAEC,OAAM,IAAKH;AACnB,UAAMI,QAAQL,KAAKM,WAAWF,OAAOG,OAAOC,IAAIC,UAAUC,KAAKV,KAAKM,QAAQ,CAAA,IAAKK;AACjF,QAAI,CAACN,OAAO;AACVO,UAAIC,MAAM,iBAAA,QAAA;;;;;;AACV,aAAOX,SAASY,OAAO,GAAA;IACzB;AAEAC,kBAAcV,OAAOP,KAAAA;AACrB,UAAMkB,UAAUX,QACZL,KAAKgB,SAASC,IAAyC,CAACC,OAAOb,MAAOc,GAAGC,cAAcF,EAAAA,CAAAA,EAAKG,OAAOC,WAAAA,IACnG,CAAA;AAEJ,QAAI,CAAC,CAACtB,KAAKM,YAAY,CAACD,OAAO;AAC7BO,UAAIW,KAAK,iBAAiB;QAAEvB;MAAK,GAAA;;;;;;IACnC,OAAO;AACLY,UAAIY,KAAK,WAAW;QAAEnB,OAAOA,OAAOoB,IAAIC,SAAAA;QAAYV,SAASA,SAASW;MAAO,GAAA;;;;;;IAC/E;AAEA,WAAO9B,QAAQ;MAAEE,OAAO;QAAEC,MAAM;UAAE,GAAGA;UAAMK;UAAOW;QAAQ;MAAE;MAAGf;MAASC;MAAU,GAAGC;IAAK,CAAA;EAC5F;AACF;AAGA,IAAMY,gBAAgB,CAACV,OAAcP,QAAyB,CAAA,MAAE;AAC9D,QAAM8B,WAAWvB,MAAMc,GAAGU,MAAMC;AAChC,aAAWC,QAAQjC,OAAO;AACxB,QAAI,CAAC8B,SAASI,UAAUD,IAAAA,GAAO;AAC7BH,eAASK,UAAU;QAACF;OAAK;IAC3B;EACF;AACF;",
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Schema as S } from '@effect/schema';\n\nimport { type Client, PublicKey } from '@dxos/client';\nimport { type Space, type SpaceId } from '@dxos/client/echo';\nimport type { CoreDatabase, ReactiveEchoObject } from '@dxos/echo-db';\nimport { log } from '@dxos/log';\nimport { nonNullable } from '@dxos/util';\n\n// TODO(burdon): Model after http request. Ref Lambda/OpenFaaS.\n// https://docs.aws.amazon.com/lambda/latest/dg/typescript-handler.html\n// https://www.serverless.com/framework/docs/providers/aws/guide/serverless.yml/#functions\n// https://www.npmjs.com/package/aws-lambda\n\n/**\n * Function handler.\n */\nexport type FunctionHandler<TData = {}, TMeta = {}> = (params: {\n context: FunctionContext;\n event: FunctionEvent<TData, TMeta>;\n\n /**\n * @deprecated\n */\n response: FunctionResponse;\n}) => Promise<Response | FunctionResponse | void>;\n\n/**\n * Function context.\n */\nexport interface FunctionContext {\n getSpace: (spaceId: SpaceId) => Promise<SpaceAPI>;\n\n /**\n * Space from which the function was invoked.\n */\n space: SpaceAPI | undefined;\n\n ai: FunctionContextAi;\n\n /**\n * @deprecated\n */\n // TODO(burdon): Limit access to individual space.\n client: Client;\n /**\n * @deprecated\n */\n // TODO(burdon): Replace with storage service abstraction.\n dataDir?: string;\n}\n\nexport interface FunctionContextAi {\n // TODO(dmaretskyi): Refer to cloudflare AI docs for more comprehensive typedefs.\n run(model: string, inputs: any, options?: any): Promise<any>;\n}\n\n/**\n * Event payload.\n */\n// TODO(dmaretskyi): Update type definitions to match the actual payload.\nexport type FunctionEvent<TData = {}, TMeta = {}> = {\n data: FunctionEventMeta<TMeta> & TData;\n};\n\n/**\n * Metadata from trigger.\n */\nexport type FunctionEventMeta<TMeta = {}> = {\n meta: TMeta;\n};\n\n/**\n * Function response.\n */\nexport type FunctionResponse = {\n status(code: number): FunctionResponse;\n};\n\n//\n// API.\n//\n\n/**\n * Space interface available to functions.\n */\nexport interface SpaceAPI {\n get id(): SpaceId;\n get crud(): CoreDatabase;\n}\n\nconst __assertFunctionSpaceIsCompatibleWithTheClientSpace = () => {\n // eslint-disable-next-line unused-imports/no-unused-vars\n const y: SpaceAPI = {} as Space;\n};\n\n//\n// Subscription utils.\n//\n\nexport type RawSubscriptionData = {\n spaceKey?: string;\n objects?: string[];\n};\n\nexport type SubscriptionData = {\n space?: Space;\n objects?: ReactiveEchoObject<any>[];\n};\n\n/**\n * Handler wrapper for subscription events; extracts space and objects.\n *\n * To test:\n * ```\n * curl -s -X POST -H \"Content-Type: application/json\" --data '{\"space\": \"0446...1cbb\"}' http://localhost:7100/dev/email-extractor\n * ```\n *\n * NOTE: Get space key from devtools or `dx space list --json`\n */\n// TODO(burdon): Evolve into plugin definition like Composer.\nexport const subscriptionHandler = <TMeta>(\n handler: FunctionHandler<SubscriptionData, TMeta>,\n types?: S.Schema<any>[],\n): FunctionHandler<RawSubscriptionData, TMeta> => {\n return async ({ event: { data }, context, response, ...rest }) => {\n const { client } = context;\n const space = data.spaceKey ? client.spaces.get(PublicKey.from(data.spaceKey)) : undefined;\n if (!space) {\n log.error('Invalid space');\n return response.status(500);\n }\n\n registerTypes(space, types);\n const objects = space\n ? data.objects?.map<ReactiveEchoObject<any> | undefined>((id) => space!.db.getObjectById(id)).filter(nonNullable)\n : [];\n\n if (!!data.spaceKey && !space) {\n log.warn('invalid space', { data });\n } else {\n log.info('handler', { space: space?.key.truncate(), objects: objects?.length });\n }\n\n return handler({ event: { data: { ...data, space, objects } }, context, response, ...rest });\n };\n};\n\n// TODO(burdon): Evolve types as part of function metadata.\nconst registerTypes = (space: Space, types: S.Schema<any>[] = []) => {\n const registry = space.db.graph.schemaRegistry;\n for (const type of types) {\n if (!registry.hasSchema(type)) {\n registry.addSchema([type]);\n }\n }\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,SAAsBA,iBAAiB;AAGvC,SAASC,WAAW;AACpB,SAASC,mBAAmB;;AAkHrB,IAAMC,sBAAsB,CACjCC,SACAC,UAAAA;AAEA,SAAO,OAAO,EAAEC,OAAO,EAAEC,KAAI,GAAIC,SAASC,UAAU,GAAGC,KAAAA,MAAM;AAC3D,UAAM,EAAEC,OAAM,IAAKH;AACnB,UAAMI,QAAQL,KAAKM,WAAWF,OAAOG,OAAOC,IAAIC,UAAUC,KAAKV,KAAKM,QAAQ,CAAA,IAAKK;AACjF,QAAI,CAACN,OAAO;AACVO,UAAIC,MAAM,iBAAA,QAAA;;;;;;AACV,aAAOX,SAASY,OAAO,GAAA;IACzB;AAEAC,kBAAcV,OAAOP,KAAAA;AACrB,UAAMkB,UAAUX,QACZL,KAAKgB,SAASC,IAAyC,CAACC,OAAOb,MAAOc,GAAGC,cAAcF,EAAAA,CAAAA,EAAKG,OAAOC,WAAAA,IACnG,CAAA;AAEJ,QAAI,CAAC,CAACtB,KAAKM,YAAY,CAACD,OAAO;AAC7BO,UAAIW,KAAK,iBAAiB;QAAEvB;MAAK,GAAA;;;;;;IACnC,OAAO;AACLY,UAAIY,KAAK,WAAW;QAAEnB,OAAOA,OAAOoB,IAAIC,SAAAA;QAAYV,SAASA,SAASW;MAAO,GAAA;;;;;;IAC/E;AAEA,WAAO9B,QAAQ;MAAEE,OAAO;QAAEC,MAAM;UAAE,GAAGA;UAAMK;UAAOW;QAAQ;MAAE;MAAGf;MAASC;MAAU,GAAGC;IAAK,CAAA;EAC5F;AACF;AAGA,IAAMY,gBAAgB,CAACV,OAAcP,QAAyB,CAAA,MAAE;AAC9D,QAAM8B,WAAWvB,MAAMc,GAAGU,MAAMC;AAChC,aAAWC,QAAQjC,OAAO;AACxB,QAAI,CAAC8B,SAASI,UAAUD,IAAAA,GAAO;AAC7BH,eAASK,UAAU;QAACF;OAAK;IAC3B;EACF;AACF;",
6
6
  "names": ["PublicKey", "log", "nonNullable", "subscriptionHandler", "handler", "types", "event", "data", "context", "response", "rest", "client", "space", "spaceKey", "spaces", "get", "PublicKey", "from", "undefined", "log", "error", "status", "registerTypes", "objects", "map", "id", "db", "getObjectById", "filter", "nonNullable", "warn", "info", "key", "truncate", "length", "registry", "graph", "schemaRegistry", "type", "hasSchema", "addSchema"]
7
7
  }