@dxos/functions 0.5.3-main.f752aaa → 0.5.3-next.57eca40
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/chunk-366QG6IX.mjs +81 -0
- package/dist/lib/browser/chunk-366QG6IX.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +825 -471
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/types.mjs +12 -0
- package/dist/lib/browser/types.mjs.map +7 -0
- package/dist/lib/node/chunk-3VSJ57ZZ.cjs +97 -0
- package/dist/lib/node/chunk-3VSJ57ZZ.cjs.map +7 -0
- package/dist/lib/node/index.cjs +805 -461
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/types.cjs +33 -0
- package/dist/lib/node/types.cjs.map +7 -0
- package/dist/types/src/function/function-registry.d.ts +24 -0
- package/dist/types/src/function/function-registry.d.ts.map +1 -0
- package/dist/types/src/function/function-registry.test.d.ts +2 -0
- package/dist/types/src/function/function-registry.test.d.ts.map +1 -0
- package/dist/types/src/function/index.d.ts +2 -0
- package/dist/types/src/function/index.d.ts.map +1 -0
- package/dist/types/src/handler.d.ts +33 -12
- package/dist/types/src/handler.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +2 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/runtime/dev-server.d.ts +16 -13
- package/dist/types/src/runtime/dev-server.d.ts.map +1 -1
- package/dist/types/src/runtime/dev-server.test.d.ts +2 -0
- package/dist/types/src/runtime/dev-server.test.d.ts.map +1 -0
- package/dist/types/src/runtime/scheduler.d.ts +13 -27
- package/dist/types/src/runtime/scheduler.d.ts.map +1 -1
- package/dist/types/src/testing/functions-integration.test.d.ts +2 -0
- package/dist/types/src/testing/functions-integration.test.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +4 -0
- package/dist/types/src/testing/index.d.ts.map +1 -0
- package/dist/types/src/testing/setup.d.ts +5 -0
- package/dist/types/src/testing/setup.d.ts.map +1 -0
- package/dist/types/src/testing/test/handler.d.ts +4 -0
- package/dist/types/src/testing/test/handler.d.ts.map +1 -0
- package/dist/types/src/testing/test/index.d.ts +3 -0
- package/dist/types/src/testing/test/index.d.ts.map +1 -0
- package/dist/types/src/testing/types.d.ts +9 -0
- package/dist/types/src/testing/types.d.ts.map +1 -0
- package/dist/types/src/testing/util.d.ts +3 -0
- package/dist/types/src/testing/util.d.ts.map +1 -0
- package/dist/types/src/trigger/index.d.ts +2 -0
- package/dist/types/src/trigger/index.d.ts.map +1 -0
- package/dist/types/src/trigger/trigger-registry.d.ts +40 -0
- package/dist/types/src/trigger/trigger-registry.d.ts.map +1 -0
- package/dist/types/src/trigger/trigger-registry.test.d.ts +2 -0
- package/dist/types/src/trigger/trigger-registry.test.d.ts.map +1 -0
- package/dist/types/src/trigger/type/index.d.ts +5 -0
- package/dist/types/src/trigger/type/index.d.ts.map +1 -0
- package/dist/types/src/trigger/type/subscription-trigger.d.ts +4 -0
- package/dist/types/src/trigger/type/subscription-trigger.d.ts.map +1 -0
- package/dist/types/src/trigger/type/timer-trigger.d.ts +4 -0
- package/dist/types/src/trigger/type/timer-trigger.d.ts.map +1 -0
- package/dist/types/src/trigger/type/webhook-trigger.d.ts +4 -0
- package/dist/types/src/trigger/type/webhook-trigger.d.ts.map +1 -0
- package/dist/types/src/trigger/type/websocket-trigger.d.ts +13 -0
- package/dist/types/src/trigger/type/websocket-trigger.d.ts.map +1 -0
- package/dist/types/src/types.d.ts +143 -101
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +15 -0
- package/dist/types/src/util.d.ts.map +1 -0
- package/dist/types/src/util.test.d.ts +2 -0
- package/dist/types/src/util.test.d.ts.map +1 -0
- package/package.json +33 -15
- package/schema/functions.json +140 -104
- package/src/function/function-registry.test.ts +105 -0
- package/src/function/function-registry.ts +90 -0
- package/src/function/index.ts +5 -0
- package/src/handler.ts +54 -31
- package/src/index.ts +2 -0
- package/src/runtime/dev-server.test.ts +60 -0
- package/src/runtime/dev-server.ts +104 -53
- package/src/runtime/scheduler.test.ts +56 -73
- package/src/runtime/scheduler.ts +87 -271
- package/src/testing/functions-integration.test.ts +99 -0
- package/src/testing/index.ts +7 -0
- package/src/testing/setup.ts +45 -0
- package/src/testing/test/handler.ts +15 -0
- package/src/testing/test/index.ts +7 -0
- package/src/testing/types.ts +9 -0
- package/src/testing/util.ts +16 -0
- package/src/trigger/index.ts +5 -0
- package/src/trigger/trigger-registry.test.ts +255 -0
- package/src/trigger/trigger-registry.ts +189 -0
- package/src/trigger/type/index.ts +8 -0
- package/src/trigger/type/subscription-trigger.ts +80 -0
- package/src/trigger/type/timer-trigger.ts +44 -0
- package/src/trigger/type/webhook-trigger.ts +47 -0
- package/src/trigger/type/websocket-trigger.ts +91 -0
- package/src/types.ts +59 -32
- package/src/util.test.ts +43 -0
- package/src/util.ts +48 -0
package/dist/lib/node/index.cjs
CHANGED
|
@@ -29,87 +29,215 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
|
29
29
|
var node_exports = {};
|
|
30
30
|
__export(node_exports, {
|
|
31
31
|
DevServer: () => DevServer,
|
|
32
|
-
|
|
32
|
+
FunctionDef: () => import_chunk_3VSJ57ZZ.FunctionDef,
|
|
33
|
+
FunctionManifestSchema: () => import_chunk_3VSJ57ZZ.FunctionManifestSchema,
|
|
34
|
+
FunctionRegistry: () => FunctionRegistry,
|
|
35
|
+
FunctionTrigger: () => import_chunk_3VSJ57ZZ.FunctionTrigger,
|
|
33
36
|
Scheduler: () => Scheduler,
|
|
37
|
+
TriggerRegistry: () => TriggerRegistry,
|
|
34
38
|
subscriptionHandler: () => subscriptionHandler
|
|
35
39
|
});
|
|
36
40
|
module.exports = __toCommonJS(node_exports);
|
|
37
|
-
var
|
|
41
|
+
var import_chunk_3VSJ57ZZ = require("./chunk-3VSJ57ZZ.cjs");
|
|
42
|
+
var import_async = require("@dxos/async");
|
|
43
|
+
var import_echo = require("@dxos/client/echo");
|
|
44
|
+
var import_context = require("@dxos/context");
|
|
45
|
+
var import_keys = require("@dxos/keys");
|
|
38
46
|
var import_log = require("@dxos/log");
|
|
39
47
|
var import_util = require("@dxos/util");
|
|
48
|
+
var import_client = require("@dxos/client");
|
|
49
|
+
var import_log2 = require("@dxos/log");
|
|
50
|
+
var import_util2 = require("@dxos/util");
|
|
40
51
|
var import_express = __toESM(require("express"));
|
|
41
52
|
var import_get_port_please = require("get-port-please");
|
|
42
53
|
var import_node_path = require("node:path");
|
|
43
|
-
var
|
|
54
|
+
var import_async2 = require("@dxos/async");
|
|
55
|
+
var import_context2 = require("@dxos/context");
|
|
44
56
|
var import_invariant = require("@dxos/invariant");
|
|
45
|
-
var
|
|
57
|
+
var import_log3 = require("@dxos/log");
|
|
58
|
+
var import_node_path2 = __toESM(require("node:path"));
|
|
59
|
+
var import_async3 = require("@dxos/async");
|
|
60
|
+
var import_context3 = require("@dxos/context");
|
|
61
|
+
var import_log4 = require("@dxos/log");
|
|
62
|
+
var import_async4 = require("@dxos/async");
|
|
63
|
+
var import_echo2 = require("@dxos/client/echo");
|
|
64
|
+
var import_context4 = require("@dxos/context");
|
|
65
|
+
var import_echo_schema = require("@dxos/echo-schema");
|
|
66
|
+
var import_invariant2 = require("@dxos/invariant");
|
|
67
|
+
var import_keys2 = require("@dxos/keys");
|
|
68
|
+
var import_log5 = require("@dxos/log");
|
|
69
|
+
var import_util3 = require("@dxos/util");
|
|
70
|
+
var import_types = require("@braneframe/types");
|
|
71
|
+
var import_async5 = require("@dxos/async");
|
|
72
|
+
var import_echo_db = require("@dxos/echo-db");
|
|
73
|
+
var import_log6 = require("@dxos/log");
|
|
46
74
|
var import_cron = require("cron");
|
|
75
|
+
var import_async6 = require("@dxos/async");
|
|
76
|
+
var import_log7 = require("@dxos/log");
|
|
77
|
+
var import_get_port_please2 = require("get-port-please");
|
|
47
78
|
var import_node_http = __toESM(require("node:http"));
|
|
79
|
+
var import_log8 = require("@dxos/log");
|
|
48
80
|
var import_ws = __toESM(require("ws"));
|
|
49
|
-
var
|
|
50
|
-
var
|
|
51
|
-
var
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
81
|
+
var import_async7 = require("@dxos/async");
|
|
82
|
+
var import_log9 = require("@dxos/log");
|
|
83
|
+
var diff = (previous, next, comparator) => {
|
|
84
|
+
const remaining = [
|
|
85
|
+
...previous
|
|
86
|
+
];
|
|
87
|
+
const result = {
|
|
88
|
+
added: [],
|
|
89
|
+
updated: [],
|
|
90
|
+
removed: remaining
|
|
91
|
+
};
|
|
92
|
+
for (const object of next) {
|
|
93
|
+
const index = remaining.findIndex((item) => comparator(item, object));
|
|
94
|
+
if (index === -1) {
|
|
95
|
+
result.added.push(object);
|
|
96
|
+
} else {
|
|
97
|
+
result.updated.push(remaining[index]);
|
|
98
|
+
remaining.splice(index, 1);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
return result;
|
|
102
|
+
};
|
|
103
|
+
var intersection = (a, b, comparator) => a.filter((a2) => b.find((b2) => comparator(a2, b2)) !== void 0);
|
|
104
|
+
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/core/functions/src/function/function-registry.ts";
|
|
105
|
+
var FunctionRegistry = class extends import_context.Resource {
|
|
106
|
+
constructor(_client) {
|
|
107
|
+
super();
|
|
108
|
+
this._client = _client;
|
|
109
|
+
this._functionBySpaceKey = new import_util.ComplexMap(import_keys.PublicKey.hash);
|
|
110
|
+
this.registered = new import_async.Event();
|
|
111
|
+
}
|
|
112
|
+
getFunctions(space) {
|
|
113
|
+
return this._functionBySpaceKey.get(space.key) ?? [];
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Loads function definitions from the manifest into the space.
|
|
117
|
+
* We first load all the definitions from the space to deduplicate by functionId.
|
|
118
|
+
*/
|
|
119
|
+
async register(space, functions) {
|
|
120
|
+
(0, import_log.log)("register", {
|
|
121
|
+
space: space.key,
|
|
122
|
+
functions: functions?.length ?? 0
|
|
123
|
+
}, {
|
|
124
|
+
F: __dxlog_file,
|
|
125
|
+
L: 39,
|
|
126
|
+
S: this,
|
|
127
|
+
C: (f, a) => f(...a)
|
|
128
|
+
});
|
|
129
|
+
if (!functions?.length) {
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
if (!space.db.graph.runtimeSchemaRegistry.hasSchema(import_chunk_3VSJ57ZZ.FunctionDef)) {
|
|
133
|
+
space.db.graph.runtimeSchemaRegistry.registerSchema(import_chunk_3VSJ57ZZ.FunctionDef);
|
|
134
|
+
}
|
|
135
|
+
const { objects: existing } = await space.db.query(import_echo.Filter.schema(import_chunk_3VSJ57ZZ.FunctionDef)).run();
|
|
136
|
+
const { added, removed } = diff(existing, functions, (a, b) => a.uri === b.uri);
|
|
137
|
+
added.forEach((def) => space.db.add((0, import_echo.create)(import_chunk_3VSJ57ZZ.FunctionDef, def)));
|
|
138
|
+
removed.forEach((def) => space.db.remove(def));
|
|
139
|
+
}
|
|
140
|
+
async _open() {
|
|
141
|
+
const spacesSubscription = this._client.spaces.subscribe(async (spaces) => {
|
|
142
|
+
for (const space of spaces) {
|
|
143
|
+
if (this._functionBySpaceKey.has(space.key)) {
|
|
144
|
+
continue;
|
|
145
|
+
}
|
|
146
|
+
const registered = [];
|
|
147
|
+
this._functionBySpaceKey.set(space.key, registered);
|
|
148
|
+
await space.waitUntilReady();
|
|
149
|
+
if (this._ctx.disposed) {
|
|
150
|
+
break;
|
|
151
|
+
}
|
|
152
|
+
this._ctx.onDispose(space.db.query(import_echo.Filter.schema(import_chunk_3VSJ57ZZ.FunctionDef)).subscribe(({ objects }) => {
|
|
153
|
+
const { added } = diff(registered, objects, (a, b) => a.uri === b.uri);
|
|
154
|
+
if (added.length > 0) {
|
|
155
|
+
registered.push(...added);
|
|
156
|
+
this.registered.emit({
|
|
157
|
+
space,
|
|
158
|
+
added
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
}));
|
|
162
|
+
}
|
|
163
|
+
});
|
|
164
|
+
this._ctx.onDispose(() => spacesSubscription.unsubscribe());
|
|
165
|
+
}
|
|
166
|
+
async _close(_) {
|
|
167
|
+
this._functionBySpaceKey.clear();
|
|
168
|
+
}
|
|
169
|
+
};
|
|
170
|
+
var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/core/functions/src/handler.ts";
|
|
65
171
|
var subscriptionHandler = (handler) => {
|
|
66
|
-
return ({ event, context, ...rest }) => {
|
|
172
|
+
return ({ event: { data }, context, ...rest }) => {
|
|
67
173
|
const { client } = context;
|
|
68
|
-
const space =
|
|
69
|
-
const objects = space
|
|
70
|
-
if (!!
|
|
71
|
-
|
|
72
|
-
|
|
174
|
+
const space = data.spaceKey ? client.spaces.get(import_client.PublicKey.from(data.spaceKey)) : void 0;
|
|
175
|
+
const objects = space ? data.objects?.map((id) => space.db.getObjectById(id)).filter(import_util2.nonNullable) : [];
|
|
176
|
+
if (!!data.spaceKey && !space) {
|
|
177
|
+
import_log2.log.warn("invalid space", {
|
|
178
|
+
data
|
|
73
179
|
}, {
|
|
74
|
-
F:
|
|
75
|
-
L:
|
|
180
|
+
F: __dxlog_file2,
|
|
181
|
+
L: 91,
|
|
76
182
|
S: void 0,
|
|
77
183
|
C: (f, a) => f(...a)
|
|
78
184
|
});
|
|
79
185
|
} else {
|
|
80
|
-
|
|
186
|
+
import_log2.log.info("handler", {
|
|
81
187
|
space: space?.key.truncate(),
|
|
82
188
|
objects: objects?.length
|
|
83
189
|
}, {
|
|
84
|
-
F:
|
|
85
|
-
L:
|
|
190
|
+
F: __dxlog_file2,
|
|
191
|
+
L: 93,
|
|
86
192
|
S: void 0,
|
|
87
193
|
C: (f, a) => f(...a)
|
|
88
194
|
});
|
|
89
195
|
}
|
|
90
196
|
return handler({
|
|
91
197
|
event: {
|
|
92
|
-
|
|
93
|
-
|
|
198
|
+
data: {
|
|
199
|
+
...data,
|
|
200
|
+
space,
|
|
201
|
+
objects
|
|
202
|
+
}
|
|
94
203
|
},
|
|
95
204
|
context,
|
|
96
205
|
...rest
|
|
97
206
|
});
|
|
98
207
|
};
|
|
99
208
|
};
|
|
100
|
-
var
|
|
209
|
+
var __dxlog_file3 = "/home/runner/work/dxos/dxos/packages/core/functions/src/runtime/dev-server.ts";
|
|
101
210
|
var DevServer = class {
|
|
102
|
-
|
|
103
|
-
constructor(_client, _options) {
|
|
211
|
+
constructor(_client, _functionsRegistry, _options) {
|
|
104
212
|
this._client = _client;
|
|
213
|
+
this._functionsRegistry = _functionsRegistry;
|
|
105
214
|
this._options = _options;
|
|
215
|
+
this._ctx = createContext();
|
|
106
216
|
this._handlers = {};
|
|
107
217
|
this._seq = 0;
|
|
218
|
+
this.update = new import_async2.Event();
|
|
219
|
+
this._functionsRegistry.registered.on(async ({ added }) => {
|
|
220
|
+
added.forEach((def) => this._load(def));
|
|
221
|
+
await this._safeUpdateRegistration();
|
|
222
|
+
(0, import_log3.log)("new functions loaded", {
|
|
223
|
+
added
|
|
224
|
+
}, {
|
|
225
|
+
F: __dxlog_file3,
|
|
226
|
+
L: 52,
|
|
227
|
+
S: this,
|
|
228
|
+
C: (f, a) => f(...a)
|
|
229
|
+
});
|
|
230
|
+
});
|
|
231
|
+
}
|
|
232
|
+
get stats() {
|
|
233
|
+
return {
|
|
234
|
+
seq: this._seq
|
|
235
|
+
};
|
|
108
236
|
}
|
|
109
237
|
get endpoint() {
|
|
110
238
|
(0, import_invariant.invariant)(this._port, void 0, {
|
|
111
|
-
F:
|
|
112
|
-
L:
|
|
239
|
+
F: __dxlog_file3,
|
|
240
|
+
L: 63,
|
|
113
241
|
S: this,
|
|
114
242
|
A: [
|
|
115
243
|
"this._port",
|
|
@@ -124,44 +252,46 @@ var DevServer = class {
|
|
|
124
252
|
get functions() {
|
|
125
253
|
return Object.values(this._handlers);
|
|
126
254
|
}
|
|
127
|
-
async initialize() {
|
|
128
|
-
for (const def of this._options.manifest.functions) {
|
|
129
|
-
try {
|
|
130
|
-
await this._load(def);
|
|
131
|
-
} catch (err) {
|
|
132
|
-
import_log2.log.error("parsing function (check manifest)", err, {
|
|
133
|
-
F: __dxlog_file2,
|
|
134
|
-
L: 63,
|
|
135
|
-
S: this,
|
|
136
|
-
C: (f, a) => f(...a)
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
255
|
async start() {
|
|
256
|
+
(0, import_invariant.invariant)(!this._server, void 0, {
|
|
257
|
+
F: __dxlog_file3,
|
|
258
|
+
L: 76,
|
|
259
|
+
S: this,
|
|
260
|
+
A: [
|
|
261
|
+
"!this._server",
|
|
262
|
+
""
|
|
263
|
+
]
|
|
264
|
+
});
|
|
265
|
+
import_log3.log.info("starting...", void 0, {
|
|
266
|
+
F: __dxlog_file3,
|
|
267
|
+
L: 77,
|
|
268
|
+
S: this,
|
|
269
|
+
C: (f, a) => f(...a)
|
|
270
|
+
});
|
|
271
|
+
this._ctx = createContext();
|
|
142
272
|
const app = (0, import_express.default)();
|
|
143
273
|
app.use(import_express.default.json());
|
|
144
|
-
app.post("/:
|
|
145
|
-
const {
|
|
274
|
+
app.post("/:path", async (req, res) => {
|
|
275
|
+
const { path: path2 } = req.params;
|
|
146
276
|
try {
|
|
147
|
-
|
|
148
|
-
|
|
277
|
+
import_log3.log.info("calling", {
|
|
278
|
+
path: path2
|
|
149
279
|
}, {
|
|
150
|
-
F:
|
|
151
|
-
L:
|
|
280
|
+
F: __dxlog_file3,
|
|
281
|
+
L: 87,
|
|
152
282
|
S: this,
|
|
153
283
|
C: (f, a) => f(...a)
|
|
154
284
|
});
|
|
155
285
|
if (this._options.reload) {
|
|
156
|
-
const { def } = this._handlers[
|
|
286
|
+
const { def } = this._handlers["/" + path2];
|
|
157
287
|
await this._load(def, true);
|
|
158
288
|
}
|
|
159
|
-
res.statusCode = await this.
|
|
289
|
+
res.statusCode = await this.invoke("/" + path2, req.body);
|
|
160
290
|
res.end();
|
|
161
291
|
} catch (err) {
|
|
162
|
-
|
|
163
|
-
F:
|
|
164
|
-
L:
|
|
292
|
+
import_log3.log.catch(err, void 0, {
|
|
293
|
+
F: __dxlog_file3,
|
|
294
|
+
L: 97,
|
|
165
295
|
S: this,
|
|
166
296
|
C: (f, a) => f(...a)
|
|
167
297
|
});
|
|
@@ -180,93 +310,195 @@ var DevServer = class {
|
|
|
180
310
|
this._server = app.listen(this._port);
|
|
181
311
|
try {
|
|
182
312
|
const { registrationId, endpoint } = await this._client.services.services.FunctionRegistryService.register({
|
|
183
|
-
endpoint: this.endpoint
|
|
184
|
-
functions: this.functions.map(({ def: { name } }) => ({
|
|
185
|
-
name
|
|
186
|
-
}))
|
|
313
|
+
endpoint: this.endpoint
|
|
187
314
|
});
|
|
188
|
-
|
|
189
|
-
registrationId,
|
|
315
|
+
import_log3.log.info("registered", {
|
|
190
316
|
endpoint
|
|
191
317
|
}, {
|
|
192
|
-
F:
|
|
193
|
-
L:
|
|
318
|
+
F: __dxlog_file3,
|
|
319
|
+
L: 112,
|
|
194
320
|
S: this,
|
|
195
321
|
C: (f, a) => f(...a)
|
|
196
322
|
});
|
|
197
|
-
this._registrationId = registrationId;
|
|
198
323
|
this._proxy = endpoint;
|
|
324
|
+
this._functionServiceRegistration = registrationId;
|
|
325
|
+
await this._functionsRegistry.open(this._ctx);
|
|
199
326
|
} catch (err) {
|
|
200
327
|
await this.stop();
|
|
201
328
|
throw new Error("FunctionRegistryService not available (check plugin is configured).");
|
|
202
329
|
}
|
|
330
|
+
import_log3.log.info("started", {
|
|
331
|
+
port: this._port
|
|
332
|
+
}, {
|
|
333
|
+
F: __dxlog_file3,
|
|
334
|
+
L: 123,
|
|
335
|
+
S: this,
|
|
336
|
+
C: (f, a) => f(...a)
|
|
337
|
+
});
|
|
203
338
|
}
|
|
204
339
|
async stop() {
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
340
|
+
(0, import_invariant.invariant)(this._server, void 0, {
|
|
341
|
+
F: __dxlog_file3,
|
|
342
|
+
L: 127,
|
|
343
|
+
S: this,
|
|
344
|
+
A: [
|
|
345
|
+
"this._server",
|
|
346
|
+
""
|
|
347
|
+
]
|
|
348
|
+
});
|
|
349
|
+
import_log3.log.info("stopping...", void 0, {
|
|
350
|
+
F: __dxlog_file3,
|
|
351
|
+
L: 128,
|
|
352
|
+
S: this,
|
|
353
|
+
C: (f, a) => f(...a)
|
|
354
|
+
});
|
|
355
|
+
const trigger = new import_async2.Trigger();
|
|
356
|
+
this._server.close(async () => {
|
|
357
|
+
import_log3.log.info("server stopped", void 0, {
|
|
358
|
+
F: __dxlog_file3,
|
|
359
|
+
L: 132,
|
|
360
|
+
S: this,
|
|
361
|
+
C: (f, a) => f(...a)
|
|
362
|
+
});
|
|
363
|
+
try {
|
|
364
|
+
if (this._functionServiceRegistration) {
|
|
365
|
+
(0, import_invariant.invariant)(this._client.services.services.FunctionRegistryService, void 0, {
|
|
366
|
+
F: __dxlog_file3,
|
|
367
|
+
L: 135,
|
|
368
|
+
S: this,
|
|
369
|
+
A: [
|
|
370
|
+
"this._client.services.services.FunctionRegistryService",
|
|
371
|
+
""
|
|
372
|
+
]
|
|
373
|
+
});
|
|
374
|
+
await this._client.services.services.FunctionRegistryService.unregister({
|
|
375
|
+
registrationId: this._functionServiceRegistration
|
|
376
|
+
});
|
|
377
|
+
import_log3.log.info("unregistered", {
|
|
378
|
+
registrationId: this._functionServiceRegistration
|
|
379
|
+
}, {
|
|
380
|
+
F: __dxlog_file3,
|
|
381
|
+
L: 140,
|
|
382
|
+
S: this,
|
|
383
|
+
C: (f, a) => f(...a)
|
|
384
|
+
});
|
|
385
|
+
this._functionServiceRegistration = void 0;
|
|
386
|
+
this._proxy = void 0;
|
|
387
|
+
}
|
|
388
|
+
trigger.wake();
|
|
389
|
+
} catch (err) {
|
|
390
|
+
trigger.throw(err);
|
|
221
391
|
}
|
|
222
|
-
trigger.wake();
|
|
223
392
|
});
|
|
224
393
|
await trigger.wait();
|
|
225
394
|
this._port = void 0;
|
|
226
395
|
this._server = void 0;
|
|
396
|
+
import_log3.log.info("stopped", void 0, {
|
|
397
|
+
F: __dxlog_file3,
|
|
398
|
+
L: 154,
|
|
399
|
+
S: this,
|
|
400
|
+
C: (f, a) => f(...a)
|
|
401
|
+
});
|
|
227
402
|
}
|
|
228
403
|
/**
|
|
229
404
|
* Load function.
|
|
230
405
|
*/
|
|
231
|
-
async _load(def,
|
|
232
|
-
const {
|
|
233
|
-
const
|
|
234
|
-
|
|
235
|
-
|
|
406
|
+
async _load(def, force) {
|
|
407
|
+
const { uri, route, handler } = def;
|
|
408
|
+
const filePath = (0, import_node_path.join)(this._options.baseDir, handler);
|
|
409
|
+
import_log3.log.info("loading", {
|
|
410
|
+
uri,
|
|
411
|
+
force
|
|
236
412
|
}, {
|
|
237
|
-
F:
|
|
238
|
-
L:
|
|
413
|
+
F: __dxlog_file3,
|
|
414
|
+
L: 163,
|
|
239
415
|
S: this,
|
|
240
416
|
C: (f, a) => f(...a)
|
|
241
417
|
});
|
|
242
|
-
if (
|
|
243
|
-
Object.keys(__require.cache).filter((key) => key.startsWith(
|
|
418
|
+
if (force) {
|
|
419
|
+
Object.keys(import_chunk_3VSJ57ZZ.__require.cache).filter((key) => key.startsWith(filePath)).forEach((key) => {
|
|
420
|
+
delete import_chunk_3VSJ57ZZ.__require.cache[key];
|
|
421
|
+
});
|
|
244
422
|
}
|
|
245
|
-
const module2 = __require(
|
|
423
|
+
const module2 = (0, import_chunk_3VSJ57ZZ.__require)(filePath);
|
|
246
424
|
if (typeof module2.default !== "function") {
|
|
247
|
-
throw new Error(`Handler must export default function: ${
|
|
425
|
+
throw new Error(`Handler must export default function: ${uri}`);
|
|
248
426
|
}
|
|
249
|
-
this._handlers[
|
|
427
|
+
this._handlers[route] = {
|
|
250
428
|
def,
|
|
251
429
|
handler: module2.default
|
|
252
430
|
};
|
|
253
431
|
}
|
|
432
|
+
async _safeUpdateRegistration() {
|
|
433
|
+
(0, import_invariant.invariant)(this._functionServiceRegistration, void 0, {
|
|
434
|
+
F: __dxlog_file3,
|
|
435
|
+
L: 185,
|
|
436
|
+
S: this,
|
|
437
|
+
A: [
|
|
438
|
+
"this._functionServiceRegistration",
|
|
439
|
+
""
|
|
440
|
+
]
|
|
441
|
+
});
|
|
442
|
+
try {
|
|
443
|
+
await this._client.services.services.FunctionRegistryService.updateRegistration({
|
|
444
|
+
registrationId: this._functionServiceRegistration,
|
|
445
|
+
functions: this.functions.map(({ def: { id, route } }) => ({
|
|
446
|
+
id,
|
|
447
|
+
route
|
|
448
|
+
}))
|
|
449
|
+
});
|
|
450
|
+
} catch (e) {
|
|
451
|
+
import_log3.log.catch(e, void 0, {
|
|
452
|
+
F: __dxlog_file3,
|
|
453
|
+
L: 192,
|
|
454
|
+
S: this,
|
|
455
|
+
C: (f, a) => f(...a)
|
|
456
|
+
});
|
|
457
|
+
}
|
|
458
|
+
}
|
|
254
459
|
/**
|
|
255
|
-
* Invoke function
|
|
460
|
+
* Invoke function.
|
|
256
461
|
*/
|
|
257
|
-
async
|
|
462
|
+
async invoke(path2, data) {
|
|
258
463
|
const seq = ++this._seq;
|
|
259
464
|
const now = Date.now();
|
|
260
|
-
|
|
465
|
+
import_log3.log.info("req", {
|
|
466
|
+
seq,
|
|
467
|
+
path: path2
|
|
468
|
+
}, {
|
|
469
|
+
F: __dxlog_file3,
|
|
470
|
+
L: 203,
|
|
471
|
+
S: this,
|
|
472
|
+
C: (f, a) => f(...a)
|
|
473
|
+
});
|
|
474
|
+
const statusCode = await this._invoke(path2, {
|
|
475
|
+
data
|
|
476
|
+
});
|
|
477
|
+
import_log3.log.info("res", {
|
|
261
478
|
seq,
|
|
262
|
-
|
|
479
|
+
path: path2,
|
|
480
|
+
statusCode,
|
|
481
|
+
duration: Date.now() - now
|
|
263
482
|
}, {
|
|
264
|
-
F:
|
|
265
|
-
L:
|
|
483
|
+
F: __dxlog_file3,
|
|
484
|
+
L: 206,
|
|
266
485
|
S: this,
|
|
267
486
|
C: (f, a) => f(...a)
|
|
268
487
|
});
|
|
269
|
-
|
|
488
|
+
this.update.emit(statusCode);
|
|
489
|
+
return statusCode;
|
|
490
|
+
}
|
|
491
|
+
async _invoke(path2, event) {
|
|
492
|
+
const { handler } = this._handlers[path2] ?? {};
|
|
493
|
+
(0, import_invariant.invariant)(handler, `invalid path: ${path2}`, {
|
|
494
|
+
F: __dxlog_file3,
|
|
495
|
+
L: 213,
|
|
496
|
+
S: this,
|
|
497
|
+
A: [
|
|
498
|
+
"handler",
|
|
499
|
+
"`invalid path: ${path}`"
|
|
500
|
+
]
|
|
501
|
+
});
|
|
270
502
|
const context = {
|
|
271
503
|
client: this._client,
|
|
272
504
|
dataDir: this._options.dataDir
|
|
@@ -283,439 +515,551 @@ var DevServer = class {
|
|
|
283
515
|
event,
|
|
284
516
|
response
|
|
285
517
|
});
|
|
286
|
-
import_log2.log.info("res", {
|
|
287
|
-
seq,
|
|
288
|
-
name,
|
|
289
|
-
statusCode,
|
|
290
|
-
duration: Date.now() - now
|
|
291
|
-
}, {
|
|
292
|
-
F: __dxlog_file2,
|
|
293
|
-
L: 178,
|
|
294
|
-
S: this,
|
|
295
|
-
C: (f, a) => f(...a)
|
|
296
|
-
});
|
|
297
518
|
return statusCode;
|
|
298
519
|
}
|
|
299
520
|
};
|
|
300
|
-
var
|
|
521
|
+
var createContext = () => new import_context2.Context({
|
|
522
|
+
name: "DevServer"
|
|
523
|
+
});
|
|
524
|
+
var __dxlog_file4 = "/home/runner/work/dxos/dxos/packages/core/functions/src/runtime/scheduler.ts";
|
|
301
525
|
var Scheduler = class {
|
|
302
|
-
constructor(
|
|
303
|
-
this.
|
|
304
|
-
this.
|
|
526
|
+
constructor(functions, triggers, _options = {}) {
|
|
527
|
+
this.functions = functions;
|
|
528
|
+
this.triggers = triggers;
|
|
305
529
|
this._options = _options;
|
|
306
|
-
this.
|
|
530
|
+
this._ctx = createContext2();
|
|
531
|
+
this._callMutex = new import_async3.Mutex();
|
|
532
|
+
this.functions.registered.on(async ({ space, added }) => {
|
|
533
|
+
await this._safeActivateTriggers(space, this.triggers.getInactiveTriggers(space), added);
|
|
534
|
+
});
|
|
535
|
+
this.triggers.registered.on(async ({ space, triggers: triggers2 }) => {
|
|
536
|
+
await this._safeActivateTriggers(space, triggers2, this.functions.getFunctions(space));
|
|
537
|
+
});
|
|
307
538
|
}
|
|
308
539
|
async start() {
|
|
309
|
-
this.
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
await this.mount(new import_context.Context(), space, trigger);
|
|
314
|
-
}
|
|
315
|
-
}
|
|
316
|
-
});
|
|
540
|
+
await this._ctx.dispose();
|
|
541
|
+
this._ctx = createContext2();
|
|
542
|
+
await this.functions.open(this._ctx);
|
|
543
|
+
await this.triggers.open(this._ctx);
|
|
317
544
|
}
|
|
318
545
|
async stop() {
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
546
|
+
await this._ctx.dispose();
|
|
547
|
+
await this.functions.close();
|
|
548
|
+
await this.triggers.close();
|
|
322
549
|
}
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
L: 72,
|
|
332
|
-
S: this,
|
|
333
|
-
A: [
|
|
334
|
-
"def",
|
|
335
|
-
"`Function not found: ${trigger.function}`"
|
|
336
|
-
]
|
|
550
|
+
// TODO(burdon): Remove and update registries directly.
|
|
551
|
+
async register(space, manifest) {
|
|
552
|
+
await this.functions.register(space, manifest.functions);
|
|
553
|
+
await this.triggers.register(space, manifest);
|
|
554
|
+
}
|
|
555
|
+
async _safeActivateTriggers(space, triggers, functions) {
|
|
556
|
+
const mountTasks = triggers.map((trigger) => {
|
|
557
|
+
return this.activate(space, functions, trigger);
|
|
337
558
|
});
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
space: space.key,
|
|
346
|
-
trigger
|
|
559
|
+
await Promise.all(mountTasks).catch(import_log4.log.catch);
|
|
560
|
+
}
|
|
561
|
+
async activate(space, functions, fnTrigger) {
|
|
562
|
+
const definition = functions.find((def) => def.uri === fnTrigger.function);
|
|
563
|
+
if (!definition) {
|
|
564
|
+
import_log4.log.info("function is not found for trigger", {
|
|
565
|
+
fnTrigger
|
|
347
566
|
}, {
|
|
348
|
-
F:
|
|
567
|
+
F: __dxlog_file4,
|
|
349
568
|
L: 78,
|
|
350
569
|
S: this,
|
|
351
570
|
C: (f, a) => f(...a)
|
|
352
571
|
});
|
|
353
|
-
|
|
354
|
-
return;
|
|
355
|
-
}
|
|
356
|
-
if (trigger.timer) {
|
|
357
|
-
await this._createTimer(ctx, space, def, trigger.timer);
|
|
358
|
-
}
|
|
359
|
-
if (trigger.webhook) {
|
|
360
|
-
await this._createWebhook(ctx, space, def, trigger.webhook);
|
|
361
|
-
}
|
|
362
|
-
if (trigger.websocket) {
|
|
363
|
-
await this._createWebsocket(ctx, space, def, trigger.websocket);
|
|
364
|
-
}
|
|
365
|
-
if (trigger.subscription) {
|
|
366
|
-
await this._createSubscription(ctx, space, def, trigger.subscription);
|
|
367
|
-
}
|
|
368
|
-
}
|
|
369
|
-
}
|
|
370
|
-
async unmount(id, spaceKey) {
|
|
371
|
-
const key = {
|
|
372
|
-
id,
|
|
373
|
-
spaceKey
|
|
374
|
-
};
|
|
375
|
-
const { ctx } = this._mounts.get(key) ?? {};
|
|
376
|
-
if (ctx) {
|
|
377
|
-
this._mounts.delete(key);
|
|
378
|
-
await ctx.dispose();
|
|
572
|
+
return;
|
|
379
573
|
}
|
|
574
|
+
await this.triggers.activate({
|
|
575
|
+
space
|
|
576
|
+
}, fnTrigger, async (args) => {
|
|
577
|
+
return this._callMutex.executeSynchronized(() => {
|
|
578
|
+
return this._execFunction(definition, fnTrigger, {
|
|
579
|
+
meta: fnTrigger.meta,
|
|
580
|
+
data: {
|
|
581
|
+
...args,
|
|
582
|
+
spaceKey: space.key
|
|
583
|
+
}
|
|
584
|
+
});
|
|
585
|
+
});
|
|
586
|
+
});
|
|
587
|
+
(0, import_log4.log)("activated trigger", {
|
|
588
|
+
space: space.key,
|
|
589
|
+
trigger: fnTrigger
|
|
590
|
+
}, {
|
|
591
|
+
F: __dxlog_file4,
|
|
592
|
+
L: 91,
|
|
593
|
+
S: this,
|
|
594
|
+
C: (f, a) => f(...a)
|
|
595
|
+
});
|
|
380
596
|
}
|
|
381
|
-
|
|
382
|
-
|
|
597
|
+
async _execFunction(def, trigger, { data, meta }) {
|
|
598
|
+
let status = 0;
|
|
383
599
|
try {
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
},
|
|
387
|
-
F: __dxlog_file3,
|
|
388
|
-
L: 117,
|
|
389
|
-
S: this,
|
|
390
|
-
C: (f, a) => f(...a)
|
|
391
|
-
});
|
|
600
|
+
const payload = Object.assign({}, meta && {
|
|
601
|
+
meta
|
|
602
|
+
}, data);
|
|
392
603
|
const { endpoint, callback } = this._options;
|
|
393
604
|
if (endpoint) {
|
|
394
|
-
|
|
605
|
+
const url = import_node_path2.default.join(endpoint, def.route);
|
|
606
|
+
import_log4.log.info("exec", {
|
|
607
|
+
function: def.uri,
|
|
608
|
+
url,
|
|
609
|
+
triggerType: trigger.spec.type
|
|
610
|
+
}, {
|
|
611
|
+
F: __dxlog_file4,
|
|
612
|
+
L: 108,
|
|
613
|
+
S: this,
|
|
614
|
+
C: (f, a) => f(...a)
|
|
615
|
+
});
|
|
616
|
+
const response = await fetch(url, {
|
|
395
617
|
method: "POST",
|
|
396
618
|
headers: {
|
|
397
619
|
"Content-Type": "application/json"
|
|
398
620
|
},
|
|
399
|
-
body: JSON.stringify(
|
|
621
|
+
body: JSON.stringify(payload)
|
|
400
622
|
});
|
|
623
|
+
status = response.status;
|
|
401
624
|
} else if (callback) {
|
|
402
|
-
|
|
625
|
+
import_log4.log.info("exec", {
|
|
626
|
+
function: def.uri
|
|
627
|
+
}, {
|
|
628
|
+
F: __dxlog_file4,
|
|
629
|
+
L: 119,
|
|
630
|
+
S: this,
|
|
631
|
+
C: (f, a) => f(...a)
|
|
632
|
+
});
|
|
633
|
+
status = await callback(payload) ?? 200;
|
|
634
|
+
}
|
|
635
|
+
if (status && status >= 400) {
|
|
636
|
+
throw new Error(`Response: ${status}`);
|
|
403
637
|
}
|
|
404
|
-
|
|
405
|
-
function: def.
|
|
638
|
+
import_log4.log.info("done", {
|
|
639
|
+
function: def.uri,
|
|
640
|
+
status
|
|
406
641
|
}, {
|
|
407
|
-
F:
|
|
408
|
-
L:
|
|
642
|
+
F: __dxlog_file4,
|
|
643
|
+
L: 129,
|
|
409
644
|
S: this,
|
|
410
645
|
C: (f, a) => f(...a)
|
|
411
646
|
});
|
|
412
647
|
} catch (err) {
|
|
413
|
-
|
|
414
|
-
function: def.
|
|
648
|
+
import_log4.log.error("error", {
|
|
649
|
+
function: def.uri,
|
|
415
650
|
error: err.message
|
|
416
651
|
}, {
|
|
417
|
-
F:
|
|
418
|
-
L:
|
|
652
|
+
F: __dxlog_file4,
|
|
653
|
+
L: 131,
|
|
419
654
|
S: this,
|
|
420
655
|
C: (f, a) => f(...a)
|
|
421
656
|
});
|
|
657
|
+
status = 500;
|
|
422
658
|
}
|
|
659
|
+
return status;
|
|
423
660
|
}
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
661
|
+
};
|
|
662
|
+
var createContext2 = () => new import_context3.Context({
|
|
663
|
+
name: "FunctionScheduler"
|
|
664
|
+
});
|
|
665
|
+
var __dxlog_file5 = "/home/runner/work/dxos/dxos/packages/core/functions/src/trigger/type/subscription-trigger.ts";
|
|
666
|
+
var createSubscriptionTrigger = async (ctx, triggerCtx, spec, callback) => {
|
|
667
|
+
const objectIds = /* @__PURE__ */ new Set();
|
|
668
|
+
const task = new import_async5.UpdateScheduler(ctx, async () => {
|
|
669
|
+
if (objectIds.size > 0) {
|
|
670
|
+
const objects = Array.from(objectIds);
|
|
671
|
+
objectIds.clear();
|
|
672
|
+
await callback({
|
|
673
|
+
objects
|
|
674
|
+
});
|
|
675
|
+
}
|
|
676
|
+
}, {
|
|
677
|
+
maxFrequency: 4
|
|
678
|
+
});
|
|
679
|
+
const subscriptions = [];
|
|
680
|
+
const subscription = (0, import_echo_db.createSubscription)(({ added, updated }) => {
|
|
681
|
+
const sizeBefore = objectIds.size;
|
|
682
|
+
for (const object of added) {
|
|
683
|
+
objectIds.add(object.id);
|
|
684
|
+
}
|
|
685
|
+
for (const object of updated) {
|
|
686
|
+
objectIds.add(object.id);
|
|
687
|
+
}
|
|
688
|
+
if (objectIds.size > sizeBefore) {
|
|
689
|
+
import_log6.log.info("updated", {
|
|
690
|
+
added: added.length,
|
|
691
|
+
updated: updated.length
|
|
692
|
+
}, {
|
|
693
|
+
F: __dxlog_file5,
|
|
694
|
+
L: 45,
|
|
695
|
+
S: void 0,
|
|
696
|
+
C: (f, a) => f(...a)
|
|
697
|
+
});
|
|
698
|
+
task.trigger();
|
|
699
|
+
}
|
|
700
|
+
});
|
|
701
|
+
subscriptions.push(() => subscription.unsubscribe());
|
|
702
|
+
const { filter, options: { deep, delay } = {} } = spec;
|
|
703
|
+
const update = ({ objects }) => {
|
|
704
|
+
subscription.update(objects);
|
|
705
|
+
if (deep) {
|
|
706
|
+
import_log6.log.info("update", {
|
|
707
|
+
objects: objects.length
|
|
708
|
+
}, {
|
|
709
|
+
F: __dxlog_file5,
|
|
710
|
+
L: 59,
|
|
711
|
+
S: void 0,
|
|
712
|
+
C: (f, a) => f(...a)
|
|
713
|
+
});
|
|
714
|
+
for (const object of objects) {
|
|
715
|
+
const content = object.content;
|
|
716
|
+
if (content instanceof import_types.TextV0Type) {
|
|
717
|
+
subscriptions.push((0, import_echo_db.getAutomergeObjectCore)(content).updates.on((0, import_async5.debounce)(() => subscription.update([
|
|
718
|
+
object
|
|
719
|
+
]), 1e3)));
|
|
720
|
+
}
|
|
721
|
+
}
|
|
722
|
+
}
|
|
723
|
+
};
|
|
724
|
+
const query = triggerCtx.space.db.query(import_echo_db.Filter.or(filter.map(({ type, props }) => import_echo_db.Filter.typename(type, props))));
|
|
725
|
+
subscriptions.push(query.subscribe(delay ? (0, import_async5.debounce)(update, delay) : update));
|
|
726
|
+
ctx.onDispose(() => {
|
|
727
|
+
subscriptions.forEach((unsubscribe) => unsubscribe());
|
|
728
|
+
});
|
|
729
|
+
};
|
|
730
|
+
var __dxlog_file6 = "/home/runner/work/dxos/dxos/packages/core/functions/src/trigger/type/timer-trigger.ts";
|
|
731
|
+
var createTimerTrigger = async (ctx, triggerContext, spec, callback) => {
|
|
732
|
+
const task = new import_async6.DeferredTask(ctx, async () => {
|
|
733
|
+
await callback({});
|
|
734
|
+
});
|
|
735
|
+
let last = 0;
|
|
736
|
+
let run = 0;
|
|
737
|
+
const job = import_cron.CronJob.from({
|
|
738
|
+
cronTime: spec.cron,
|
|
739
|
+
runOnInit: false,
|
|
740
|
+
onTick: () => {
|
|
741
|
+
const now = Date.now();
|
|
742
|
+
const delta = last ? now - last : 0;
|
|
743
|
+
last = now;
|
|
744
|
+
run++;
|
|
745
|
+
import_log7.log.info("tick", {
|
|
746
|
+
space: triggerContext.space.key.truncate(),
|
|
747
|
+
count: run,
|
|
748
|
+
delta
|
|
749
|
+
}, {
|
|
750
|
+
F: __dxlog_file6,
|
|
751
|
+
L: 37,
|
|
752
|
+
S: void 0,
|
|
753
|
+
C: (f, a) => f(...a)
|
|
754
|
+
});
|
|
755
|
+
task.schedule();
|
|
756
|
+
}
|
|
757
|
+
});
|
|
758
|
+
job.start();
|
|
759
|
+
ctx.onDispose(() => job.stop());
|
|
760
|
+
};
|
|
761
|
+
var __dxlog_file7 = "/home/runner/work/dxos/dxos/packages/core/functions/src/trigger/type/webhook-trigger.ts";
|
|
762
|
+
var createWebhookTrigger = async (ctx, _, spec, callback) => {
|
|
763
|
+
const server = import_node_http.default.createServer(async (req, res) => {
|
|
764
|
+
if (req.method !== spec.method) {
|
|
765
|
+
res.statusCode = 405;
|
|
766
|
+
return res.end();
|
|
767
|
+
}
|
|
768
|
+
res.statusCode = await callback({});
|
|
769
|
+
res.end();
|
|
770
|
+
});
|
|
771
|
+
const port = await (0, import_get_port_please2.getPort)({
|
|
772
|
+
random: true
|
|
773
|
+
});
|
|
774
|
+
server.listen(port, () => {
|
|
775
|
+
import_log8.log.info("started webhook", {
|
|
776
|
+
port
|
|
434
777
|
}, {
|
|
435
|
-
F:
|
|
436
|
-
L:
|
|
437
|
-
S:
|
|
778
|
+
F: __dxlog_file7,
|
|
779
|
+
L: 40,
|
|
780
|
+
S: void 0,
|
|
438
781
|
C: (f, a) => f(...a)
|
|
439
782
|
});
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
783
|
+
spec.port = port;
|
|
784
|
+
});
|
|
785
|
+
ctx.onDispose(() => {
|
|
786
|
+
server.close();
|
|
787
|
+
});
|
|
788
|
+
};
|
|
789
|
+
var __dxlog_file8 = "/home/runner/work/dxos/dxos/packages/core/functions/src/trigger/type/websocket-trigger.ts";
|
|
790
|
+
var createWebsocketTrigger = async (ctx, triggerCtx, spec, callback, options = {
|
|
791
|
+
retryDelay: 2,
|
|
792
|
+
maxAttempts: 5
|
|
793
|
+
}) => {
|
|
794
|
+
const { url, init } = spec;
|
|
795
|
+
let ws;
|
|
796
|
+
for (let attempt = 1; attempt <= options.maxAttempts; attempt++) {
|
|
797
|
+
const open = new import_async7.Trigger();
|
|
798
|
+
ws = new import_ws.default(url);
|
|
799
|
+
Object.assign(ws, {
|
|
800
|
+
onopen: () => {
|
|
801
|
+
import_log9.log.info("opened", {
|
|
802
|
+
url
|
|
460
803
|
}, {
|
|
461
|
-
F:
|
|
462
|
-
L:
|
|
463
|
-
S:
|
|
804
|
+
F: __dxlog_file8,
|
|
805
|
+
L: 39,
|
|
806
|
+
S: void 0,
|
|
807
|
+
C: (f, a) => f(...a)
|
|
808
|
+
});
|
|
809
|
+
if (spec.init) {
|
|
810
|
+
ws.send(new TextEncoder().encode(JSON.stringify(init)));
|
|
811
|
+
}
|
|
812
|
+
open.wake(true);
|
|
813
|
+
},
|
|
814
|
+
onclose: (event) => {
|
|
815
|
+
import_log9.log.info("closed", {
|
|
816
|
+
url,
|
|
817
|
+
code: event.code
|
|
818
|
+
}, {
|
|
819
|
+
F: __dxlog_file8,
|
|
820
|
+
L: 48,
|
|
821
|
+
S: void 0,
|
|
464
822
|
C: (f, a) => f(...a)
|
|
465
823
|
});
|
|
466
|
-
|
|
824
|
+
if (event.code === 1006) {
|
|
825
|
+
setTimeout(async () => {
|
|
826
|
+
import_log9.log.info(`reconnecting in ${options.retryDelay}s...`, {
|
|
827
|
+
url
|
|
828
|
+
}, {
|
|
829
|
+
F: __dxlog_file8,
|
|
830
|
+
L: 53,
|
|
831
|
+
S: void 0,
|
|
832
|
+
C: (f, a) => f(...a)
|
|
833
|
+
});
|
|
834
|
+
await createWebsocketTrigger(ctx, triggerCtx, spec, callback, options);
|
|
835
|
+
}, options.retryDelay * 1e3);
|
|
836
|
+
}
|
|
837
|
+
open.wake(false);
|
|
838
|
+
},
|
|
839
|
+
onerror: (event) => {
|
|
840
|
+
import_log9.log.catch(event.error, {
|
|
841
|
+
url
|
|
842
|
+
}, {
|
|
843
|
+
F: __dxlog_file8,
|
|
844
|
+
L: 62,
|
|
845
|
+
S: void 0,
|
|
846
|
+
C: (f, a) => f(...a)
|
|
847
|
+
});
|
|
848
|
+
},
|
|
849
|
+
onmessage: async (event) => {
|
|
850
|
+
try {
|
|
851
|
+
import_log9.log.info("message", void 0, {
|
|
852
|
+
F: __dxlog_file8,
|
|
853
|
+
L: 67,
|
|
854
|
+
S: void 0,
|
|
855
|
+
C: (f, a) => f(...a)
|
|
856
|
+
});
|
|
857
|
+
const data = JSON.parse(new TextDecoder().decode(event.data));
|
|
858
|
+
await callback({
|
|
859
|
+
data
|
|
860
|
+
});
|
|
861
|
+
} catch (err) {
|
|
862
|
+
import_log9.log.catch(err, {
|
|
863
|
+
url
|
|
864
|
+
}, {
|
|
865
|
+
F: __dxlog_file8,
|
|
866
|
+
L: 71,
|
|
867
|
+
S: void 0,
|
|
868
|
+
C: (f, a) => f(...a)
|
|
869
|
+
});
|
|
870
|
+
}
|
|
467
871
|
}
|
|
468
872
|
});
|
|
469
|
-
|
|
470
|
-
|
|
873
|
+
const isOpen = await open.wait();
|
|
874
|
+
if (isOpen) {
|
|
875
|
+
break;
|
|
876
|
+
} else {
|
|
877
|
+
const wait = Math.pow(attempt, 2) * options.retryDelay;
|
|
878
|
+
if (attempt < options.maxAttempts) {
|
|
879
|
+
import_log9.log.warn(`failed to connect; trying again in ${wait}s`, {
|
|
880
|
+
attempt
|
|
881
|
+
}, {
|
|
882
|
+
F: __dxlog_file8,
|
|
883
|
+
L: 82,
|
|
884
|
+
S: void 0,
|
|
885
|
+
C: (f, a) => f(...a)
|
|
886
|
+
});
|
|
887
|
+
await (0, import_async7.sleep)(wait * 1e3);
|
|
888
|
+
}
|
|
889
|
+
}
|
|
471
890
|
}
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
891
|
+
ctx.onDispose(() => {
|
|
892
|
+
ws?.close();
|
|
893
|
+
});
|
|
894
|
+
};
|
|
895
|
+
var __dxlog_file9 = "/home/runner/work/dxos/dxos/packages/core/functions/src/trigger/trigger-registry.ts";
|
|
896
|
+
var triggerHandlers = {
|
|
897
|
+
subscription: createSubscriptionTrigger,
|
|
898
|
+
timer: createTimerTrigger,
|
|
899
|
+
webhook: createWebhookTrigger,
|
|
900
|
+
websocket: createWebsocketTrigger
|
|
901
|
+
};
|
|
902
|
+
var TriggerRegistry = class extends import_context4.Resource {
|
|
903
|
+
constructor(_client, _options) {
|
|
904
|
+
super();
|
|
905
|
+
this._client = _client;
|
|
906
|
+
this._options = _options;
|
|
907
|
+
this._triggersBySpaceKey = new import_util3.ComplexMap(import_keys2.PublicKey.hash);
|
|
908
|
+
this.registered = new import_async4.Event();
|
|
909
|
+
this.removed = new import_async4.Event();
|
|
910
|
+
}
|
|
911
|
+
getActiveTriggers(space) {
|
|
912
|
+
return this._getTriggers(space, (t) => t.activationCtx != null);
|
|
913
|
+
}
|
|
914
|
+
getInactiveTriggers(space) {
|
|
915
|
+
return this._getTriggers(space, (t) => t.activationCtx == null);
|
|
916
|
+
}
|
|
917
|
+
async activate(triggerCtx, trigger, callback) {
|
|
918
|
+
(0, import_log5.log)("activate", {
|
|
919
|
+
space: triggerCtx.space.key,
|
|
478
920
|
trigger
|
|
479
921
|
}, {
|
|
480
|
-
F:
|
|
481
|
-
L:
|
|
922
|
+
F: __dxlog_file9,
|
|
923
|
+
L: 75,
|
|
482
924
|
S: this,
|
|
483
925
|
C: (f, a) => f(...a)
|
|
484
926
|
});
|
|
485
|
-
const
|
|
486
|
-
|
|
487
|
-
await this._execFunction(def, {
|
|
488
|
-
space: space.key
|
|
489
|
-
});
|
|
490
|
-
});
|
|
491
|
-
server.listen(port, () => {
|
|
492
|
-
import_log3.log.info("started webhook", {
|
|
493
|
-
port
|
|
494
|
-
}, {
|
|
495
|
-
F: __dxlog_file3,
|
|
496
|
-
L: 189,
|
|
497
|
-
S: this,
|
|
498
|
-
C: (f, a) => f(...a)
|
|
499
|
-
});
|
|
927
|
+
const activationCtx = new import_context4.Context({
|
|
928
|
+
name: `trigger_${trigger.function}`
|
|
500
929
|
});
|
|
501
|
-
|
|
502
|
-
|
|
930
|
+
this._ctx.onDispose(() => activationCtx.dispose());
|
|
931
|
+
const registeredTrigger = this._triggersBySpaceKey.get(triggerCtx.space.key)?.find((reg) => reg.trigger.id === trigger.id);
|
|
932
|
+
(0, import_invariant2.invariant)(registeredTrigger, `Trigger is not registered: ${trigger.function}`, {
|
|
933
|
+
F: __dxlog_file9,
|
|
934
|
+
L: 81,
|
|
935
|
+
S: this,
|
|
936
|
+
A: [
|
|
937
|
+
"registeredTrigger",
|
|
938
|
+
"`Trigger is not registered: ${trigger.function}`"
|
|
939
|
+
]
|
|
503
940
|
});
|
|
941
|
+
registeredTrigger.activationCtx = activationCtx;
|
|
942
|
+
try {
|
|
943
|
+
const options = this._options?.[trigger.spec.type];
|
|
944
|
+
await triggerHandlers[trigger.spec.type](activationCtx, triggerCtx, trigger.spec, callback, options);
|
|
945
|
+
} catch (err) {
|
|
946
|
+
delete registeredTrigger.activationCtx;
|
|
947
|
+
throw err;
|
|
948
|
+
}
|
|
504
949
|
}
|
|
505
950
|
/**
|
|
506
|
-
*
|
|
951
|
+
* Loads triggers from the manifest into the space.
|
|
507
952
|
*/
|
|
508
|
-
async
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
}) {
|
|
512
|
-
import_log3.log.info("websocket", {
|
|
513
|
-
space: space.key,
|
|
514
|
-
trigger
|
|
953
|
+
async register(space, manifest) {
|
|
954
|
+
(0, import_log5.log)("register", {
|
|
955
|
+
space: space.key
|
|
515
956
|
}, {
|
|
516
|
-
F:
|
|
517
|
-
L:
|
|
957
|
+
F: __dxlog_file9,
|
|
958
|
+
L: 97,
|
|
518
959
|
S: this,
|
|
519
960
|
C: (f, a) => f(...a)
|
|
520
961
|
});
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
C: (f, a) => f(...a)
|
|
549
|
-
});
|
|
550
|
-
open.wake(false);
|
|
551
|
-
},
|
|
552
|
-
onerror: (event) => {
|
|
553
|
-
import_log3.log.catch(event.error, {
|
|
554
|
-
url
|
|
555
|
-
}, {
|
|
556
|
-
F: __dxlog_file3,
|
|
557
|
-
L: 237,
|
|
558
|
-
S: this,
|
|
559
|
-
C: (f, a) => f(...a)
|
|
560
|
-
});
|
|
561
|
-
},
|
|
562
|
-
onmessage: async (event) => {
|
|
563
|
-
try {
|
|
564
|
-
const data = JSON.parse(new TextDecoder().decode(event.data));
|
|
565
|
-
await this._execFunction(def, {
|
|
566
|
-
space: space.key,
|
|
567
|
-
data
|
|
568
|
-
});
|
|
569
|
-
} catch (err) {
|
|
570
|
-
import_log3.log.catch(err, {
|
|
571
|
-
url
|
|
572
|
-
}, {
|
|
573
|
-
F: __dxlog_file3,
|
|
574
|
-
L: 245,
|
|
575
|
-
S: this,
|
|
576
|
-
C: (f, a) => f(...a)
|
|
577
|
-
});
|
|
578
|
-
}
|
|
962
|
+
if (!manifest.triggers?.length) {
|
|
963
|
+
return;
|
|
964
|
+
}
|
|
965
|
+
if (!space.db.graph.runtimeSchemaRegistry.hasSchema(import_chunk_3VSJ57ZZ.FunctionTrigger)) {
|
|
966
|
+
space.db.graph.runtimeSchemaRegistry.registerSchema(import_chunk_3VSJ57ZZ.FunctionTrigger);
|
|
967
|
+
}
|
|
968
|
+
const { objects: existing } = await space.db.query(import_echo2.Filter.schema(import_chunk_3VSJ57ZZ.FunctionTrigger)).run();
|
|
969
|
+
const { added, removed } = diff(existing, manifest.triggers, (a, b) => {
|
|
970
|
+
const keys = b[import_echo_schema.ECHO_ATTR_META]?.keys ?? [
|
|
971
|
+
(0, import_echo_schema.foreignKey)("manifest", [
|
|
972
|
+
b.function,
|
|
973
|
+
b.spec.type
|
|
974
|
+
].join("-"))
|
|
975
|
+
];
|
|
976
|
+
return intersection((0, import_echo2.getMeta)(a)?.keys ?? [], keys, import_echo_schema.foreignKeyEquals).length > 0;
|
|
977
|
+
});
|
|
978
|
+
added.forEach((trigger) => {
|
|
979
|
+
const { meta, object } = (0, import_echo_schema.splitMeta)(trigger);
|
|
980
|
+
space.db.add((0, import_echo2.create)(import_chunk_3VSJ57ZZ.FunctionTrigger, object, meta));
|
|
981
|
+
});
|
|
982
|
+
removed.forEach((trigger) => space.db.remove(trigger));
|
|
983
|
+
}
|
|
984
|
+
async _open() {
|
|
985
|
+
const spaceListSubscription = this._client.spaces.subscribe(async (spaces) => {
|
|
986
|
+
for (const space of spaces) {
|
|
987
|
+
if (this._triggersBySpaceKey.has(space.key)) {
|
|
988
|
+
continue;
|
|
579
989
|
}
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
const wait = Math.pow(attempt, 2) * options.retryDelay;
|
|
586
|
-
if (attempt < options.maxAttempts) {
|
|
587
|
-
import_log3.log.warn(`failed to connect; trying again in ${wait}s`, {
|
|
588
|
-
attempt
|
|
589
|
-
}, {
|
|
590
|
-
F: __dxlog_file3,
|
|
591
|
-
L: 256,
|
|
592
|
-
S: this,
|
|
593
|
-
C: (f, a) => f(...a)
|
|
594
|
-
});
|
|
595
|
-
await (0, import_async2.sleep)(wait * 1e3);
|
|
990
|
+
const registered = [];
|
|
991
|
+
this._triggersBySpaceKey.set(space.key, registered);
|
|
992
|
+
await space.waitUntilReady();
|
|
993
|
+
if (this._ctx.disposed) {
|
|
994
|
+
break;
|
|
596
995
|
}
|
|
996
|
+
const functionsSubscription = space.db.query(import_echo2.Filter.schema(import_chunk_3VSJ57ZZ.FunctionTrigger)).subscribe(async (triggers) => {
|
|
997
|
+
await this._handleRemovedTriggers(space, triggers.objects, registered);
|
|
998
|
+
this._handleNewTriggers(space, triggers.objects, registered);
|
|
999
|
+
});
|
|
1000
|
+
this._ctx.onDispose(functionsSubscription);
|
|
597
1001
|
}
|
|
598
|
-
}
|
|
599
|
-
ctx.onDispose(() => {
|
|
600
|
-
ws?.close();
|
|
601
1002
|
});
|
|
1003
|
+
this._ctx.onDispose(() => spaceListSubscription.unsubscribe());
|
|
602
1004
|
}
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
trigger
|
|
610
|
-
}, {
|
|
611
|
-
F: __dxlog_file3,
|
|
612
|
-
L: 271,
|
|
613
|
-
S: this,
|
|
614
|
-
C: (f, a) => f(...a)
|
|
615
|
-
});
|
|
616
|
-
const objectIds = /* @__PURE__ */ new Set();
|
|
617
|
-
const task = new import_async2.DeferredTask(ctx, async () => {
|
|
618
|
-
await this._execFunction(def, {
|
|
619
|
-
space: space.key,
|
|
620
|
-
objects: Array.from(objectIds)
|
|
621
|
-
});
|
|
1005
|
+
async _close(_) {
|
|
1006
|
+
this._triggersBySpaceKey.clear();
|
|
1007
|
+
}
|
|
1008
|
+
_handleNewTriggers(space, allTriggers, registered) {
|
|
1009
|
+
const newTriggers = allTriggers.filter((candidate) => {
|
|
1010
|
+
return registered.find((reg) => reg.trigger.id === candidate.id) == null;
|
|
622
1011
|
});
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
1012
|
+
if (newTriggers.length > 0) {
|
|
1013
|
+
const newRegisteredTriggers = newTriggers.map((trigger) => ({
|
|
1014
|
+
trigger
|
|
1015
|
+
}));
|
|
1016
|
+
registered.push(...newRegisteredTriggers);
|
|
1017
|
+
(0, import_log5.log)("registered new triggers", () => ({
|
|
1018
|
+
spaceKey: space.key,
|
|
1019
|
+
functions: newTriggers.map((t) => t.function)
|
|
1020
|
+
}), {
|
|
1021
|
+
F: __dxlog_file9,
|
|
1022
|
+
L: 159,
|
|
631
1023
|
S: this,
|
|
632
1024
|
C: (f, a) => f(...a)
|
|
633
1025
|
});
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
objects: objects.length
|
|
649
|
-
}, {
|
|
650
|
-
F: __dxlog_file3,
|
|
651
|
-
L: 301,
|
|
652
|
-
S: this,
|
|
653
|
-
C: (f, a) => f(...a)
|
|
654
|
-
});
|
|
655
|
-
for (const object of objects) {
|
|
656
|
-
const content = object.content;
|
|
657
|
-
if (content instanceof import_types.TextV0Type) {
|
|
658
|
-
subscriptions.push((0, import_echo.getAutomergeObjectCore)(content).updates.on((0, import_async2.debounce)(() => subscription.update([
|
|
659
|
-
object
|
|
660
|
-
]), 1e3)));
|
|
661
|
-
}
|
|
662
|
-
}
|
|
1026
|
+
this.registered.emit({
|
|
1027
|
+
space,
|
|
1028
|
+
triggers: newTriggers
|
|
1029
|
+
});
|
|
1030
|
+
}
|
|
1031
|
+
}
|
|
1032
|
+
async _handleRemovedTriggers(space, allTriggers, registered) {
|
|
1033
|
+
const removed = [];
|
|
1034
|
+
for (let i = registered.length - 1; i >= 0; i--) {
|
|
1035
|
+
const wasRemoved = allTriggers.find((trigger) => trigger.id === registered[i].trigger.id) == null;
|
|
1036
|
+
if (wasRemoved) {
|
|
1037
|
+
const unregistered = registered.splice(i, 1)[0];
|
|
1038
|
+
await unregistered.activationCtx?.dispose();
|
|
1039
|
+
removed.push(unregistered.trigger);
|
|
663
1040
|
}
|
|
664
|
-
}
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
1041
|
+
}
|
|
1042
|
+
if (removed.length > 0) {
|
|
1043
|
+
this.removed.emit({
|
|
1044
|
+
space,
|
|
1045
|
+
triggers: removed
|
|
1046
|
+
});
|
|
1047
|
+
}
|
|
1048
|
+
}
|
|
1049
|
+
_getTriggers(space, predicate) {
|
|
1050
|
+
const allSpaceTriggers = this._triggersBySpaceKey.get(space.key) ?? [];
|
|
1051
|
+
return allSpaceTriggers.filter(predicate).map((trigger) => trigger.trigger);
|
|
670
1052
|
}
|
|
671
1053
|
};
|
|
672
|
-
var TimerTriggerSchema = S.struct({
|
|
673
|
-
cron: S.string
|
|
674
|
-
});
|
|
675
|
-
var WebhookTriggerSchema = S.struct({
|
|
676
|
-
port: S.number
|
|
677
|
-
});
|
|
678
|
-
var WebsocketTriggerSchema = S.struct({
|
|
679
|
-
url: S.string,
|
|
680
|
-
init: S.optional(S.record(S.string, S.any))
|
|
681
|
-
});
|
|
682
|
-
var SubscriptionTriggerSchema = S.struct({
|
|
683
|
-
spaceKey: S.optional(S.string),
|
|
684
|
-
// TODO(burdon): Define query DSL.
|
|
685
|
-
filter: S.array(S.struct({
|
|
686
|
-
type: S.string,
|
|
687
|
-
props: S.optional(S.record(S.string, S.any))
|
|
688
|
-
})),
|
|
689
|
-
options: S.optional(S.struct({
|
|
690
|
-
// Watch changes to object (not just creation).
|
|
691
|
-
deep: S.optional(S.boolean),
|
|
692
|
-
// Debounce changes (delay in ms).
|
|
693
|
-
delay: S.optional(S.number)
|
|
694
|
-
}))
|
|
695
|
-
});
|
|
696
|
-
var FunctionTriggerSchema = S.struct({
|
|
697
|
-
function: S.string.pipe(S.description("Function ID/URI.")),
|
|
698
|
-
timer: S.optional(TimerTriggerSchema),
|
|
699
|
-
webhook: S.optional(WebhookTriggerSchema),
|
|
700
|
-
websocket: S.optional(WebsocketTriggerSchema),
|
|
701
|
-
subscription: S.optional(SubscriptionTriggerSchema)
|
|
702
|
-
});
|
|
703
|
-
var FunctionDefSchema = S.struct({
|
|
704
|
-
id: S.string,
|
|
705
|
-
description: S.optional(S.string),
|
|
706
|
-
name: S.string,
|
|
707
|
-
// TODO(burdon): NPM/GitHub URL?
|
|
708
|
-
handler: S.string
|
|
709
|
-
});
|
|
710
|
-
var FunctionManifestSchema = S.struct({
|
|
711
|
-
functions: S.mutable(S.array(FunctionDefSchema)),
|
|
712
|
-
triggers: S.mutable(S.array(FunctionTriggerSchema))
|
|
713
|
-
});
|
|
714
1054
|
// Annotate the CommonJS export names for ESM import in node:
|
|
715
1055
|
0 && (module.exports = {
|
|
716
1056
|
DevServer,
|
|
1057
|
+
FunctionDef,
|
|
717
1058
|
FunctionManifestSchema,
|
|
1059
|
+
FunctionRegistry,
|
|
1060
|
+
FunctionTrigger,
|
|
718
1061
|
Scheduler,
|
|
1062
|
+
TriggerRegistry,
|
|
719
1063
|
subscriptionHandler
|
|
720
1064
|
});
|
|
721
1065
|
//# sourceMappingURL=index.cjs.map
|