@positronic/cloudflare 0.0.52 → 0.0.54

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 (40) hide show
  1. package/dist/src/api/brains.js +1003 -0
  2. package/dist/src/api/bundle.js +204 -0
  3. package/dist/src/api/index.js +149 -0
  4. package/dist/src/api/pages.js +681 -0
  5. package/dist/src/api/resources.js +778 -0
  6. package/dist/src/api/secrets.js +707 -0
  7. package/dist/src/api/types.js +1 -0
  8. package/dist/src/api/webhooks/coordination.js +267 -0
  9. package/dist/src/api/webhooks/index.js +277 -0
  10. package/dist/src/api/webhooks/system.js +248 -0
  11. package/dist/src/brain-runner-do.js +5 -5
  12. package/dist/src/dev-server.js +201 -9
  13. package/dist/src/index.js +2 -4
  14. package/dist/types/api/brains.d.ts +7 -0
  15. package/dist/types/api/brains.d.ts.map +1 -0
  16. package/dist/types/api/bundle.d.ts +7 -0
  17. package/dist/types/api/bundle.d.ts.map +1 -0
  18. package/dist/types/api/index.d.ts +8 -0
  19. package/dist/types/api/index.d.ts.map +1 -0
  20. package/dist/types/api/pages.d.ts +7 -0
  21. package/dist/types/api/pages.d.ts.map +1 -0
  22. package/dist/types/api/resources.d.ts +7 -0
  23. package/dist/types/api/resources.d.ts.map +1 -0
  24. package/dist/types/api/secrets.d.ts +7 -0
  25. package/dist/types/api/secrets.d.ts.map +1 -0
  26. package/dist/types/{api.d.ts → api/types.d.ts} +15 -9
  27. package/dist/types/api/types.d.ts.map +1 -0
  28. package/dist/types/api/webhooks/coordination.d.ts +32 -0
  29. package/dist/types/api/webhooks/coordination.d.ts.map +1 -0
  30. package/dist/types/api/webhooks/index.d.ts +7 -0
  31. package/dist/types/api/webhooks/index.d.ts.map +1 -0
  32. package/dist/types/api/webhooks/system.d.ts +7 -0
  33. package/dist/types/api/webhooks/system.d.ts.map +1 -0
  34. package/dist/types/dev-server.d.ts +5 -0
  35. package/dist/types/dev-server.d.ts.map +1 -1
  36. package/dist/types/index.d.ts +3 -5
  37. package/dist/types/index.d.ts.map +1 -1
  38. package/package.json +4 -4
  39. package/dist/src/api.js +0 -2839
  40. package/dist/types/api.d.ts.map +0 -1
@@ -0,0 +1,267 @@
1
+ function _array_like_to_array(arr, len) {
2
+ if (len == null || len > arr.length) len = arr.length;
3
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
4
+ return arr2;
5
+ }
6
+ function _array_with_holes(arr) {
7
+ if (Array.isArray(arr)) return arr;
8
+ }
9
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
10
+ try {
11
+ var info = gen[key](arg);
12
+ var value = info.value;
13
+ } catch (error) {
14
+ reject(error);
15
+ return;
16
+ }
17
+ if (info.done) {
18
+ resolve(value);
19
+ } else {
20
+ Promise.resolve(value).then(_next, _throw);
21
+ }
22
+ }
23
+ function _async_to_generator(fn) {
24
+ return function() {
25
+ var self = this, args = arguments;
26
+ return new Promise(function(resolve, reject) {
27
+ var gen = fn.apply(self, args);
28
+ function _next(value) {
29
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
30
+ }
31
+ function _throw(err) {
32
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
33
+ }
34
+ _next(undefined);
35
+ });
36
+ };
37
+ }
38
+ function _iterable_to_array_limit(arr, i) {
39
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
40
+ if (_i == null) return;
41
+ var _arr = [];
42
+ var _n = true;
43
+ var _d = false;
44
+ var _s, _e;
45
+ try {
46
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
47
+ _arr.push(_s.value);
48
+ if (i && _arr.length === i) break;
49
+ }
50
+ } catch (err) {
51
+ _d = true;
52
+ _e = err;
53
+ } finally{
54
+ try {
55
+ if (!_n && _i["return"] != null) _i["return"]();
56
+ } finally{
57
+ if (_d) throw _e;
58
+ }
59
+ }
60
+ return _arr;
61
+ }
62
+ function _non_iterable_rest() {
63
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
64
+ }
65
+ function _sliced_to_array(arr, i) {
66
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
67
+ }
68
+ function _unsupported_iterable_to_array(o, minLen) {
69
+ if (!o) return;
70
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
71
+ var n = Object.prototype.toString.call(o).slice(8, -1);
72
+ if (n === "Object" && o.constructor) n = o.constructor.name;
73
+ if (n === "Map" || n === "Set") return Array.from(n);
74
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
75
+ }
76
+ function _ts_generator(thisArg, body) {
77
+ var f, y, t, _ = {
78
+ label: 0,
79
+ sent: function() {
80
+ if (t[0] & 1) throw t[1];
81
+ return t[1];
82
+ },
83
+ trys: [],
84
+ ops: []
85
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
86
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
87
+ return this;
88
+ }), g;
89
+ function verb(n) {
90
+ return function(v) {
91
+ return step([
92
+ n,
93
+ v
94
+ ]);
95
+ };
96
+ }
97
+ function step(op) {
98
+ if (f) throw new TypeError("Generator is already executing.");
99
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
100
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
101
+ if (y = 0, t) op = [
102
+ op[0] & 2,
103
+ t.value
104
+ ];
105
+ switch(op[0]){
106
+ case 0:
107
+ case 1:
108
+ t = op;
109
+ break;
110
+ case 4:
111
+ _.label++;
112
+ return {
113
+ value: op[1],
114
+ done: false
115
+ };
116
+ case 5:
117
+ _.label++;
118
+ y = op[1];
119
+ op = [
120
+ 0
121
+ ];
122
+ continue;
123
+ case 7:
124
+ op = _.ops.pop();
125
+ _.trys.pop();
126
+ continue;
127
+ default:
128
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
129
+ _ = 0;
130
+ continue;
131
+ }
132
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
133
+ _.label = op[1];
134
+ break;
135
+ }
136
+ if (op[0] === 6 && _.label < t[1]) {
137
+ _.label = t[1];
138
+ t = op;
139
+ break;
140
+ }
141
+ if (t && _.label < t[2]) {
142
+ _.label = t[2];
143
+ _.ops.push(op);
144
+ break;
145
+ }
146
+ if (t[2]) _.ops.pop();
147
+ _.trys.pop();
148
+ continue;
149
+ }
150
+ op = body.call(thisArg, _);
151
+ } catch (e) {
152
+ op = [
153
+ 6,
154
+ e
155
+ ];
156
+ y = 0;
157
+ } finally{
158
+ f = t = 0;
159
+ }
160
+ if (op[0] & 5) throw op[1];
161
+ return {
162
+ value: op[0] ? op[1] : void 0,
163
+ done: true
164
+ };
165
+ }
166
+ }
167
+ /**
168
+ * Find a brain waiting for a webhook and resume it if found.
169
+ * Returns a JSON response object suitable for returning from a webhook endpoint.
170
+ */ export function findAndResumeBrain(context, slug, identifier, response) {
171
+ return _async_to_generator(function() {
172
+ var monitorId, monitorStub, brainRunId, namespace, doId, stub;
173
+ return _ts_generator(this, function(_state) {
174
+ switch(_state.label){
175
+ case 0:
176
+ monitorId = context.env.MONITOR_DO.idFromName('singleton');
177
+ monitorStub = context.env.MONITOR_DO.get(monitorId);
178
+ return [
179
+ 4,
180
+ monitorStub.findWaitingBrain(slug, identifier)
181
+ ];
182
+ case 1:
183
+ brainRunId = _state.sent();
184
+ if (!brainRunId) return [
185
+ 3,
186
+ 3
187
+ ];
188
+ // Found a brain waiting - resume it
189
+ namespace = context.env.BRAIN_RUNNER_DO;
190
+ doId = namespace.idFromName(brainRunId);
191
+ stub = namespace.get(doId);
192
+ return [
193
+ 4,
194
+ stub.resume(brainRunId, response)
195
+ ];
196
+ case 2:
197
+ _state.sent();
198
+ return [
199
+ 2,
200
+ {
201
+ received: true,
202
+ action: 'resumed',
203
+ identifier: identifier,
204
+ brainRunId: brainRunId
205
+ }
206
+ ];
207
+ case 3:
208
+ // No brain waiting for this webhook
209
+ return [
210
+ 2,
211
+ {
212
+ received: true,
213
+ action: 'not_found',
214
+ identifier: identifier,
215
+ message: 'No brain waiting for this webhook'
216
+ }
217
+ ];
218
+ }
219
+ });
220
+ })();
221
+ }
222
+ /**
223
+ * Parse form data into a plain object, handling array fields.
224
+ * Supports:
225
+ * - name[] syntax for explicit arrays
226
+ * - Multiple values with same key (converted to array)
227
+ */ export function parseFormData(formData) {
228
+ var result = {};
229
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
230
+ try {
231
+ for(var _iterator = formData.entries()[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
232
+ var _step_value = _sliced_to_array(_step.value, 2), key = _step_value[0], value = _step_value[1];
233
+ // Handle array fields (e.g., name[] for multi-select)
234
+ if (key.endsWith('[]')) {
235
+ var baseKey = key.slice(0, -2);
236
+ if (!result[baseKey]) {
237
+ result[baseKey] = [];
238
+ }
239
+ result[baseKey].push(value);
240
+ } else if (result[key] !== undefined) {
241
+ // Convert to array if same key appears multiple times
242
+ if (!Array.isArray(result[key])) {
243
+ result[key] = [
244
+ result[key]
245
+ ];
246
+ }
247
+ result[key].push(value);
248
+ } else {
249
+ result[key] = value;
250
+ }
251
+ }
252
+ } catch (err) {
253
+ _didIteratorError = true;
254
+ _iteratorError = err;
255
+ } finally{
256
+ try {
257
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
258
+ _iterator.return();
259
+ }
260
+ } finally{
261
+ if (_didIteratorError) {
262
+ throw _iteratorError;
263
+ }
264
+ }
265
+ }
266
+ return result;
267
+ }
@@ -0,0 +1,277 @@
1
+ function _array_like_to_array(arr, len) {
2
+ if (len == null || len > arr.length) len = arr.length;
3
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
4
+ return arr2;
5
+ }
6
+ function _array_with_holes(arr) {
7
+ if (Array.isArray(arr)) return arr;
8
+ }
9
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
10
+ try {
11
+ var info = gen[key](arg);
12
+ var value = info.value;
13
+ } catch (error) {
14
+ reject(error);
15
+ return;
16
+ }
17
+ if (info.done) {
18
+ resolve(value);
19
+ } else {
20
+ Promise.resolve(value).then(_next, _throw);
21
+ }
22
+ }
23
+ function _async_to_generator(fn) {
24
+ return function() {
25
+ var self = this, args = arguments;
26
+ return new Promise(function(resolve, reject) {
27
+ var gen = fn.apply(self, args);
28
+ function _next(value) {
29
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
30
+ }
31
+ function _throw(err) {
32
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
33
+ }
34
+ _next(undefined);
35
+ });
36
+ };
37
+ }
38
+ function _iterable_to_array_limit(arr, i) {
39
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
40
+ if (_i == null) return;
41
+ var _arr = [];
42
+ var _n = true;
43
+ var _d = false;
44
+ var _s, _e;
45
+ try {
46
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
47
+ _arr.push(_s.value);
48
+ if (i && _arr.length === i) break;
49
+ }
50
+ } catch (err) {
51
+ _d = true;
52
+ _e = err;
53
+ } finally{
54
+ try {
55
+ if (!_n && _i["return"] != null) _i["return"]();
56
+ } finally{
57
+ if (_d) throw _e;
58
+ }
59
+ }
60
+ return _arr;
61
+ }
62
+ function _non_iterable_rest() {
63
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
64
+ }
65
+ function _sliced_to_array(arr, i) {
66
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
67
+ }
68
+ function _unsupported_iterable_to_array(o, minLen) {
69
+ if (!o) return;
70
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
71
+ var n = Object.prototype.toString.call(o).slice(8, -1);
72
+ if (n === "Object" && o.constructor) n = o.constructor.name;
73
+ if (n === "Map" || n === "Set") return Array.from(n);
74
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
75
+ }
76
+ function _ts_generator(thisArg, body) {
77
+ var f, y, t, _ = {
78
+ label: 0,
79
+ sent: function() {
80
+ if (t[0] & 1) throw t[1];
81
+ return t[1];
82
+ },
83
+ trys: [],
84
+ ops: []
85
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
86
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
87
+ return this;
88
+ }), g;
89
+ function verb(n) {
90
+ return function(v) {
91
+ return step([
92
+ n,
93
+ v
94
+ ]);
95
+ };
96
+ }
97
+ function step(op) {
98
+ if (f) throw new TypeError("Generator is already executing.");
99
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
100
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
101
+ if (y = 0, t) op = [
102
+ op[0] & 2,
103
+ t.value
104
+ ];
105
+ switch(op[0]){
106
+ case 0:
107
+ case 1:
108
+ t = op;
109
+ break;
110
+ case 4:
111
+ _.label++;
112
+ return {
113
+ value: op[1],
114
+ done: false
115
+ };
116
+ case 5:
117
+ _.label++;
118
+ y = op[1];
119
+ op = [
120
+ 0
121
+ ];
122
+ continue;
123
+ case 7:
124
+ op = _.ops.pop();
125
+ _.trys.pop();
126
+ continue;
127
+ default:
128
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
129
+ _ = 0;
130
+ continue;
131
+ }
132
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
133
+ _.label = op[1];
134
+ break;
135
+ }
136
+ if (op[0] === 6 && _.label < t[1]) {
137
+ _.label = t[1];
138
+ t = op;
139
+ break;
140
+ }
141
+ if (t && _.label < t[2]) {
142
+ _.label = t[2];
143
+ _.ops.push(op);
144
+ break;
145
+ }
146
+ if (t[2]) _.ops.pop();
147
+ _.trys.pop();
148
+ continue;
149
+ }
150
+ op = body.call(thisArg, _);
151
+ } catch (e) {
152
+ op = [
153
+ 6,
154
+ e
155
+ ];
156
+ y = 0;
157
+ } finally{
158
+ f = t = 0;
159
+ }
160
+ if (op[0] & 5) throw op[1];
161
+ return {
162
+ value: op[0] ? op[1] : void 0,
163
+ done: true
164
+ };
165
+ }
166
+ }
167
+ import { Hono } from 'hono';
168
+ import { getWebhookManifest } from '../../brain-runner-do.js';
169
+ import { findAndResumeBrain } from './coordination.js';
170
+ import system from './system.js';
171
+ var webhooks = new Hono();
172
+ // Mount system webhooks at /webhooks/system/*
173
+ webhooks.route('/system', system);
174
+ // List all webhooks (user-defined only)
175
+ webhooks.get('/', function(context) {
176
+ return _async_to_generator(function() {
177
+ var webhookManifest, webhookList;
178
+ return _ts_generator(this, function(_state) {
179
+ webhookManifest = getWebhookManifest();
180
+ webhookList = Object.entries(webhookManifest).map(function(param) {
181
+ var _param = _sliced_to_array(param, 2), slug = _param[0], webhook = _param[1];
182
+ return {
183
+ slug: slug,
184
+ description: webhook.description
185
+ };
186
+ });
187
+ return [
188
+ 2,
189
+ context.json({
190
+ webhooks: webhookList,
191
+ count: webhookList.length
192
+ })
193
+ ];
194
+ });
195
+ })();
196
+ });
197
+ // Receive incoming webhook from external service (user-defined webhooks)
198
+ webhooks.post('/:slug', function(context) {
199
+ return _async_to_generator(function() {
200
+ var slug, webhookManifest, webhook, handlerResult, result, error;
201
+ return _ts_generator(this, function(_state) {
202
+ switch(_state.label){
203
+ case 0:
204
+ slug = context.req.param('slug');
205
+ webhookManifest = getWebhookManifest();
206
+ webhook = webhookManifest[slug];
207
+ if (!webhook) {
208
+ return [
209
+ 2,
210
+ context.json({
211
+ error: "Webhook '".concat(slug, "' not found")
212
+ }, 404)
213
+ ];
214
+ }
215
+ _state.label = 1;
216
+ case 1:
217
+ _state.trys.push([
218
+ 1,
219
+ 4,
220
+ ,
221
+ 5
222
+ ]);
223
+ return [
224
+ 4,
225
+ webhook.handler(context.req.raw)
226
+ ];
227
+ case 2:
228
+ handlerResult = _state.sent();
229
+ // Handle verification challenge (for Slack, Stripe, GitHub, Discord)
230
+ if (handlerResult.type === 'verification') {
231
+ return [
232
+ 2,
233
+ context.json({
234
+ challenge: handlerResult.challenge
235
+ })
236
+ ];
237
+ }
238
+ return [
239
+ 4,
240
+ findAndResumeBrain(context, slug, handlerResult.identifier, handlerResult.response)
241
+ ];
242
+ case 3:
243
+ result = _state.sent();
244
+ // For user webhooks, return 'queued' instead of 'not_found' when no brain is waiting
245
+ // This allows webhooks to be received even when no brain is actively waiting
246
+ if (result.action === 'not_found') {
247
+ return [
248
+ 2,
249
+ context.json({
250
+ received: true,
251
+ action: 'queued',
252
+ identifier: handlerResult.identifier
253
+ })
254
+ ];
255
+ }
256
+ return [
257
+ 2,
258
+ context.json(result)
259
+ ];
260
+ case 4:
261
+ error = _state.sent();
262
+ console.error("Error receiving webhook ".concat(slug, ":"), error);
263
+ return [
264
+ 2,
265
+ context.json({
266
+ error: 'Failed to process webhook'
267
+ }, 500)
268
+ ];
269
+ case 5:
270
+ return [
271
+ 2
272
+ ];
273
+ }
274
+ });
275
+ })();
276
+ });
277
+ export default webhooks;