@positronic/cloudflare 0.0.67 → 0.0.69

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 (37) hide show
  1. package/dist/src/api/auth-middleware.js +25 -0
  2. package/dist/src/api/brains.js +67 -16
  3. package/dist/src/api/secrets.js +3 -0
  4. package/dist/src/brain-runner-do.js +51 -5
  5. package/dist/src/create-r2-store.js +319 -0
  6. package/dist/src/dev-server.js +19 -1
  7. package/dist/src/governor-client-wrapper.js +364 -0
  8. package/dist/src/governor-do.js +387 -0
  9. package/dist/src/index.js +3 -0
  10. package/dist/src/monitor-do.js +25 -12
  11. package/dist/src/rate-limit-headers.js +199 -0
  12. package/dist/src/schedule-do.js +38 -22
  13. package/dist/src/token-estimator.js +39 -0
  14. package/dist/types/api/auth-middleware.d.ts +5 -0
  15. package/dist/types/api/auth-middleware.d.ts.map +1 -1
  16. package/dist/types/api/brains.d.ts.map +1 -1
  17. package/dist/types/api/secrets.d.ts.map +1 -1
  18. package/dist/types/brain-runner-do.d.ts +9 -1
  19. package/dist/types/brain-runner-do.d.ts.map +1 -1
  20. package/dist/types/create-r2-store.d.ts +14 -0
  21. package/dist/types/create-r2-store.d.ts.map +1 -0
  22. package/dist/types/dev-server.d.ts.map +1 -1
  23. package/dist/types/governor-client-wrapper.d.ts +15 -0
  24. package/dist/types/governor-client-wrapper.d.ts.map +1 -0
  25. package/dist/types/governor-do.d.ts +25 -0
  26. package/dist/types/governor-do.d.ts.map +1 -0
  27. package/dist/types/index.d.ts +3 -0
  28. package/dist/types/index.d.ts.map +1 -1
  29. package/dist/types/monitor-do.d.ts +13 -4
  30. package/dist/types/monitor-do.d.ts.map +1 -1
  31. package/dist/types/rate-limit-headers.d.ts +10 -0
  32. package/dist/types/rate-limit-headers.d.ts.map +1 -0
  33. package/dist/types/schedule-do.d.ts +11 -3
  34. package/dist/types/schedule-do.d.ts.map +1 -1
  35. package/dist/types/token-estimator.d.ts +9 -0
  36. package/dist/types/token-estimator.d.ts.map +1 -0
  37. package/package.json +5 -4
@@ -0,0 +1,319 @@
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 _type_of(obj) {
69
+ "@swc/helpers - typeof";
70
+ return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
71
+ }
72
+ function _unsupported_iterable_to_array(o, minLen) {
73
+ if (!o) return;
74
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
75
+ var n = Object.prototype.toString.call(o).slice(8, -1);
76
+ if (n === "Object" && o.constructor) n = o.constructor.name;
77
+ if (n === "Map" || n === "Set") return Array.from(n);
78
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
79
+ }
80
+ function _ts_generator(thisArg, body) {
81
+ var f, y, t, _ = {
82
+ label: 0,
83
+ sent: function() {
84
+ if (t[0] & 1) throw t[1];
85
+ return t[1];
86
+ },
87
+ trys: [],
88
+ ops: []
89
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
90
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
91
+ return this;
92
+ }), g;
93
+ function verb(n) {
94
+ return function(v) {
95
+ return step([
96
+ n,
97
+ v
98
+ ]);
99
+ };
100
+ }
101
+ function step(op) {
102
+ if (f) throw new TypeError("Generator is already executing.");
103
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
104
+ 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;
105
+ if (y = 0, t) op = [
106
+ op[0] & 2,
107
+ t.value
108
+ ];
109
+ switch(op[0]){
110
+ case 0:
111
+ case 1:
112
+ t = op;
113
+ break;
114
+ case 4:
115
+ _.label++;
116
+ return {
117
+ value: op[1],
118
+ done: false
119
+ };
120
+ case 5:
121
+ _.label++;
122
+ y = op[1];
123
+ op = [
124
+ 0
125
+ ];
126
+ continue;
127
+ case 7:
128
+ op = _.ops.pop();
129
+ _.trys.pop();
130
+ continue;
131
+ default:
132
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
133
+ _ = 0;
134
+ continue;
135
+ }
136
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
137
+ _.label = op[1];
138
+ break;
139
+ }
140
+ if (op[0] === 6 && _.label < t[1]) {
141
+ _.label = t[1];
142
+ t = op;
143
+ break;
144
+ }
145
+ if (t && _.label < t[2]) {
146
+ _.label = t[2];
147
+ _.ops.push(op);
148
+ break;
149
+ }
150
+ if (t[2]) _.ops.pop();
151
+ _.trys.pop();
152
+ continue;
153
+ }
154
+ op = body.call(thisArg, _);
155
+ } catch (e) {
156
+ op = [
157
+ 6,
158
+ e
159
+ ];
160
+ y = 0;
161
+ } finally{
162
+ f = t = 0;
163
+ }
164
+ if (op[0] & 5) throw op[1];
165
+ return {
166
+ value: op[0] ? op[1] : void 0,
167
+ done: true
168
+ };
169
+ }
170
+ }
171
+ /**
172
+ * Type guard for per-user field definitions in a store schema.
173
+ */ function isPerUserField(value) {
174
+ return value !== null && (typeof value === "undefined" ? "undefined" : _type_of(value)) === 'object' && 'perUser' in value && value.perUser === true && 'type' in value;
175
+ }
176
+ /**
177
+ * Create a StoreProvider backed by Cloudflare R2.
178
+ *
179
+ * Key resolution:
180
+ * shared: store/{brainTitle}/{key}.json
181
+ * per-user: store/{brainTitle}/user/{userId}/{key}.json
182
+ *
183
+ * The factory receives the store schema, brain title, and currentUser,
184
+ * and returns a typed Store<any> with full key resolution built in.
185
+ */ export function createR2Backend(bucket) {
186
+ return function(param) {
187
+ var schema = param.schema, brainTitle = param.brainTitle, currentUser = param.currentUser;
188
+ var resolveKey = function resolveKey(key) {
189
+ if (perUserKeys.has(key)) {
190
+ if (!currentUser) {
191
+ throw new Error('Store key "'.concat(key, '" is per-user but no currentUser was provided. ') + "Per-user store keys require a currentUser in run params.");
192
+ }
193
+ return "store/".concat(brainTitle, "/user/").concat(currentUser.id, "/").concat(key);
194
+ }
195
+ return "store/".concat(brainTitle, "/").concat(key);
196
+ };
197
+ // Parse which keys are per-user from the schema
198
+ var perUserKeys = new Set();
199
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
200
+ try {
201
+ for(var _iterator = Object.entries(schema)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
202
+ var _step_value = _sliced_to_array(_step.value, 2), key = _step_value[0], value = _step_value[1];
203
+ if (isPerUserField(value)) {
204
+ perUserKeys.add(key);
205
+ }
206
+ }
207
+ } catch (err) {
208
+ _didIteratorError = true;
209
+ _iteratorError = err;
210
+ } finally{
211
+ try {
212
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
213
+ _iterator.return();
214
+ }
215
+ } finally{
216
+ if (_didIteratorError) {
217
+ throw _iteratorError;
218
+ }
219
+ }
220
+ }
221
+ var store = {
222
+ get: function get(key) {
223
+ return _async_to_generator(function() {
224
+ var resolved, object, _;
225
+ return _ts_generator(this, function(_state) {
226
+ switch(_state.label){
227
+ case 0:
228
+ resolved = resolveKey(key);
229
+ return [
230
+ 4,
231
+ bucket.get("".concat(resolved, ".json"))
232
+ ];
233
+ case 1:
234
+ object = _state.sent();
235
+ if (object === null) return [
236
+ 2,
237
+ undefined
238
+ ];
239
+ _ = JSON.parse;
240
+ return [
241
+ 4,
242
+ object.text()
243
+ ];
244
+ case 2:
245
+ return [
246
+ 2,
247
+ _.apply(JSON, [
248
+ _state.sent()
249
+ ])
250
+ ];
251
+ }
252
+ });
253
+ })();
254
+ },
255
+ set: function set(key, value) {
256
+ return _async_to_generator(function() {
257
+ var resolved;
258
+ return _ts_generator(this, function(_state) {
259
+ switch(_state.label){
260
+ case 0:
261
+ resolved = resolveKey(key);
262
+ return [
263
+ 4,
264
+ bucket.put("".concat(resolved, ".json"), JSON.stringify(value))
265
+ ];
266
+ case 1:
267
+ _state.sent();
268
+ return [
269
+ 2
270
+ ];
271
+ }
272
+ });
273
+ })();
274
+ },
275
+ delete: function _delete(key) {
276
+ return _async_to_generator(function() {
277
+ var resolved;
278
+ return _ts_generator(this, function(_state) {
279
+ switch(_state.label){
280
+ case 0:
281
+ resolved = resolveKey(key);
282
+ return [
283
+ 4,
284
+ bucket.delete("".concat(resolved, ".json"))
285
+ ];
286
+ case 1:
287
+ _state.sent();
288
+ return [
289
+ 2
290
+ ];
291
+ }
292
+ });
293
+ })();
294
+ },
295
+ has: function has(key) {
296
+ return _async_to_generator(function() {
297
+ var resolved, object;
298
+ return _ts_generator(this, function(_state) {
299
+ switch(_state.label){
300
+ case 0:
301
+ resolved = resolveKey(key);
302
+ return [
303
+ 4,
304
+ bucket.head("".concat(resolved, ".json"))
305
+ ];
306
+ case 1:
307
+ object = _state.sent();
308
+ return [
309
+ 2,
310
+ object !== null
311
+ ];
312
+ }
313
+ });
314
+ })();
315
+ }
316
+ };
317
+ return store;
318
+ };
319
+ }
@@ -416,7 +416,7 @@ import { createRequire } from 'module';
416
416
  }();
417
417
  function generateProject(projectName, projectDir, onSuccess) {
418
418
  return _async_to_generator(function() {
419
- var devPath, newProjectTemplatePath, cazOptions, templateSourcePath, require, templatePackageJsonPath, copiedNewProjectPkg;
419
+ var devPath, newProjectTemplatePath, cazOptions, templateSourcePath, inferredDevPath, require, templatePackageJsonPath, realPath, potentialRoot, copiedNewProjectPkg;
420
420
  return _ts_generator(this, function(_state) {
421
421
  switch(_state.label){
422
422
  case 0:
@@ -425,6 +425,7 @@ function generateProject(projectName, projectDir, onSuccess) {
425
425
  cazOptions = {
426
426
  name: projectName
427
427
  };
428
+ inferredDevPath = false;
428
429
  _state.label = 1;
429
430
  case 1:
430
431
  _state.trys.push([
@@ -448,6 +449,19 @@ function generateProject(projectName, projectDir, onSuccess) {
448
449
  require = createRequire(import.meta.url);
449
450
  templatePackageJsonPath = require.resolve('@positronic/template-new-project/package.json');
450
451
  templateSourcePath = path.dirname(templatePackageJsonPath);
452
+ // Auto-detect local workspace: if the template resolves to a real path
453
+ // outside node_modules, we're running from a local monorepo (e.g. the user's
454
+ // project uses file: references to @positronic/cloudflare). In that case,
455
+ // set POSITRONIC_LOCAL_PATH so the template generates file: references too.
456
+ realPath = fs.realpathSync(templateSourcePath);
457
+ if (!realPath.includes("".concat(path.sep, "node_modules").concat(path.sep))) {
458
+ potentialRoot = path.resolve(realPath, '..', '..');
459
+ if (fs.existsSync(path.join(potentialRoot, 'packages', 'core')) && fs.existsSync(path.join(potentialRoot, 'packages', 'cloudflare'))) {
460
+ devPath = potentialRoot;
461
+ process.env.POSITRONIC_LOCAL_PATH = potentialRoot;
462
+ inferredDevPath = true;
463
+ }
464
+ }
451
465
  }
452
466
  // Always copy to a temporary directory to avoid CAZ modifying our source
453
467
  // CAZ only supports local paths, GitHub repos, or ZIP URLs - not npm package names
@@ -485,6 +499,10 @@ function generateProject(projectName, projectDir, onSuccess) {
485
499
  5
486
500
  ];
487
501
  case 4:
502
+ // Clean up the temporarily set env var
503
+ if (inferredDevPath) {
504
+ delete process.env.POSITRONIC_LOCAL_PATH;
505
+ }
488
506
  // Clean up the temporary copied new project package
489
507
  fs.rmSync(newProjectTemplatePath, {
490
508
  recursive: true,