@convex-dev/workpool 0.2.19-alpha.2 → 0.2.19-alpha.3

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 (194) hide show
  1. package/README.md +1 -0
  2. package/dist/{commonjs/client → client}/index.d.ts +13 -11
  3. package/dist/client/index.d.ts.map +1 -0
  4. package/dist/{commonjs/client → client}/index.js +6 -7
  5. package/dist/client/index.js.map +1 -0
  6. package/dist/{commonjs/client → client}/utils.d.ts +2 -2
  7. package/dist/client/utils.d.ts.map +1 -0
  8. package/dist/client/utils.js.map +1 -0
  9. package/dist/component/_generated/api.d.ts +151 -0
  10. package/dist/component/_generated/api.d.ts.map +1 -0
  11. package/dist/component/_generated/api.js.map +1 -0
  12. package/dist/component/_generated/dataModel.d.ts +60 -0
  13. package/dist/component/_generated/server.d.ts +149 -0
  14. package/dist/component/_generated/server.d.ts.map +1 -0
  15. package/dist/component/_generated/server.js.map +1 -0
  16. package/dist/{commonjs/component → component}/complete.d.ts +2 -2
  17. package/dist/component/complete.d.ts.map +1 -0
  18. package/dist/{commonjs/component → component}/complete.js +1 -1
  19. package/dist/component/complete.js.map +1 -0
  20. package/dist/component/convex.config.d.ts.map +1 -0
  21. package/dist/component/convex.config.js.map +1 -0
  22. package/dist/component/crons.d.ts.map +1 -0
  23. package/dist/{esm/component → component}/crons.js +4 -4
  24. package/dist/component/crons.js.map +1 -0
  25. package/dist/component/danger.d.ts.map +1 -0
  26. package/dist/component/danger.js.map +1 -0
  27. package/dist/{esm/component → component}/kick.d.ts +2 -2
  28. package/dist/component/kick.d.ts.map +1 -0
  29. package/dist/component/kick.js.map +1 -0
  30. package/dist/{esm/component → component}/lib.d.ts +1 -1
  31. package/dist/component/lib.d.ts.map +1 -0
  32. package/dist/{commonjs/component → component}/lib.js +3 -4
  33. package/dist/component/lib.js.map +1 -0
  34. package/dist/component/logging.d.ts.map +1 -0
  35. package/dist/component/logging.js.map +1 -0
  36. package/dist/{commonjs/component → component}/loop.d.ts +2 -2
  37. package/dist/component/loop.d.ts.map +1 -0
  38. package/dist/{commonjs/component → component}/loop.js +1 -1
  39. package/dist/component/loop.js.map +1 -0
  40. package/dist/{esm/component → component}/recovery.d.ts +2 -2
  41. package/dist/component/recovery.d.ts.map +1 -0
  42. package/dist/{commonjs/component → component}/recovery.js +1 -1
  43. package/dist/component/recovery.js.map +1 -0
  44. package/dist/{commonjs/component → component}/schema.d.ts.map +1 -1
  45. package/dist/component/schema.js.map +1 -0
  46. package/dist/component/shared.d.ts.map +1 -0
  47. package/dist/component/shared.js.map +1 -0
  48. package/dist/{esm/component → component}/stats.d.ts +4 -4
  49. package/dist/component/stats.d.ts.map +1 -0
  50. package/dist/{commonjs/component → component}/stats.js +0 -3
  51. package/dist/component/stats.js.map +1 -0
  52. package/dist/component/worker.d.ts.map +1 -0
  53. package/dist/component/worker.js.map +1 -0
  54. package/package.json +42 -39
  55. package/src/client/index.ts +32 -29
  56. package/src/client/utils.ts +7 -7
  57. package/src/component/_generated/api.d.ts +1 -0
  58. package/src/component/complete.test.ts +6 -6
  59. package/src/component/complete.ts +9 -5
  60. package/src/component/crons.ts +4 -4
  61. package/src/component/kick.test.ts +3 -3
  62. package/src/component/kick.ts +2 -2
  63. package/src/component/lib.test.ts +6 -6
  64. package/src/component/lib.ts +15 -5
  65. package/src/component/logging.test.ts +1 -1
  66. package/src/component/loop.test.ts +7 -7
  67. package/src/component/loop.ts +8 -8
  68. package/src/component/recovery.test.ts +9 -9
  69. package/src/component/recovery.ts +2 -2
  70. package/src/component/stats.test.ts +11 -11
  71. package/src/component/stats.ts +4 -7
  72. package/src/test.ts +3 -0
  73. package/dist/commonjs/client/index.d.ts.map +0 -1
  74. package/dist/commonjs/client/index.js.map +0 -1
  75. package/dist/commonjs/client/utils.d.ts.map +0 -1
  76. package/dist/commonjs/client/utils.js.map +0 -1
  77. package/dist/commonjs/component/_generated/api.d.ts +0 -12
  78. package/dist/commonjs/component/_generated/api.d.ts.map +0 -1
  79. package/dist/commonjs/component/_generated/api.js.map +0 -1
  80. package/dist/commonjs/component/_generated/server.d.ts +0 -64
  81. package/dist/commonjs/component/_generated/server.d.ts.map +0 -1
  82. package/dist/commonjs/component/_generated/server.js.map +0 -1
  83. package/dist/commonjs/component/complete.d.ts.map +0 -1
  84. package/dist/commonjs/component/complete.js.map +0 -1
  85. package/dist/commonjs/component/convex.config.d.ts.map +0 -1
  86. package/dist/commonjs/component/convex.config.js.map +0 -1
  87. package/dist/commonjs/component/crons.d.ts.map +0 -1
  88. package/dist/commonjs/component/crons.js +0 -61
  89. package/dist/commonjs/component/crons.js.map +0 -1
  90. package/dist/commonjs/component/danger.d.ts.map +0 -1
  91. package/dist/commonjs/component/danger.js.map +0 -1
  92. package/dist/commonjs/component/kick.d.ts +0 -9
  93. package/dist/commonjs/component/kick.d.ts.map +0 -1
  94. package/dist/commonjs/component/kick.js.map +0 -1
  95. package/dist/commonjs/component/lib.d.ts +0 -79
  96. package/dist/commonjs/component/lib.d.ts.map +0 -1
  97. package/dist/commonjs/component/lib.js.map +0 -1
  98. package/dist/commonjs/component/logging.d.ts.map +0 -1
  99. package/dist/commonjs/component/logging.js.map +0 -1
  100. package/dist/commonjs/component/loop.d.ts.map +0 -1
  101. package/dist/commonjs/component/loop.js.map +0 -1
  102. package/dist/commonjs/component/recovery.d.ts +0 -53
  103. package/dist/commonjs/component/recovery.d.ts.map +0 -1
  104. package/dist/commonjs/component/recovery.js.map +0 -1
  105. package/dist/commonjs/component/schema.js.map +0 -1
  106. package/dist/commonjs/component/shared.d.ts.map +0 -1
  107. package/dist/commonjs/component/shared.js.map +0 -1
  108. package/dist/commonjs/component/stats.d.ts +0 -45
  109. package/dist/commonjs/component/stats.d.ts.map +0 -1
  110. package/dist/commonjs/component/stats.js.map +0 -1
  111. package/dist/commonjs/component/worker.d.ts.map +0 -1
  112. package/dist/commonjs/component/worker.js.map +0 -1
  113. package/dist/commonjs/package.json +0 -3
  114. package/dist/esm/client/index.d.ts +0 -429
  115. package/dist/esm/client/index.d.ts.map +0 -1
  116. package/dist/esm/client/index.js +0 -317
  117. package/dist/esm/client/index.js.map +0 -1
  118. package/dist/esm/client/utils.d.ts +0 -16
  119. package/dist/esm/client/utils.d.ts.map +0 -1
  120. package/dist/esm/client/utils.js +0 -9
  121. package/dist/esm/client/utils.js.map +0 -1
  122. package/dist/esm/component/_generated/api.d.ts +0 -12
  123. package/dist/esm/component/_generated/api.d.ts.map +0 -1
  124. package/dist/esm/component/_generated/api.js +0 -22
  125. package/dist/esm/component/_generated/api.js.map +0 -1
  126. package/dist/esm/component/_generated/server.d.ts +0 -64
  127. package/dist/esm/component/_generated/server.d.ts.map +0 -1
  128. package/dist/esm/component/_generated/server.js +0 -74
  129. package/dist/esm/component/_generated/server.js.map +0 -1
  130. package/dist/esm/component/complete.d.ts +0 -89
  131. package/dist/esm/component/complete.d.ts.map +0 -1
  132. package/dist/esm/component/complete.js +0 -88
  133. package/dist/esm/component/complete.js.map +0 -1
  134. package/dist/esm/component/convex.config.d.ts +0 -3
  135. package/dist/esm/component/convex.config.d.ts.map +0 -1
  136. package/dist/esm/component/convex.config.js +0 -4
  137. package/dist/esm/component/convex.config.js.map +0 -1
  138. package/dist/esm/component/crons.d.ts +0 -4
  139. package/dist/esm/component/crons.d.ts.map +0 -1
  140. package/dist/esm/component/crons.js.map +0 -1
  141. package/dist/esm/component/danger.d.ts +0 -11
  142. package/dist/esm/component/danger.d.ts.map +0 -1
  143. package/dist/esm/component/danger.js +0 -92
  144. package/dist/esm/component/danger.js.map +0 -1
  145. package/dist/esm/component/kick.d.ts.map +0 -1
  146. package/dist/esm/component/kick.js +0 -102
  147. package/dist/esm/component/kick.js.map +0 -1
  148. package/dist/esm/component/lib.d.ts.map +0 -1
  149. package/dist/esm/component/lib.js +0 -179
  150. package/dist/esm/component/lib.js.map +0 -1
  151. package/dist/esm/component/logging.d.ts +0 -16
  152. package/dist/esm/component/logging.d.ts.map +0 -1
  153. package/dist/esm/component/logging.js +0 -71
  154. package/dist/esm/component/logging.js.map +0 -1
  155. package/dist/esm/component/loop.d.ts +0 -14
  156. package/dist/esm/component/loop.d.ts.map +0 -1
  157. package/dist/esm/component/loop.js +0 -503
  158. package/dist/esm/component/loop.js.map +0 -1
  159. package/dist/esm/component/recovery.d.ts.map +0 -1
  160. package/dist/esm/component/recovery.js +0 -97
  161. package/dist/esm/component/recovery.js.map +0 -1
  162. package/dist/esm/component/schema.d.ts +0 -228
  163. package/dist/esm/component/schema.d.ts.map +0 -1
  164. package/dist/esm/component/schema.js +0 -79
  165. package/dist/esm/component/schema.js.map +0 -1
  166. package/dist/esm/component/shared.d.ts +0 -140
  167. package/dist/esm/component/shared.d.ts.map +0 -1
  168. package/dist/esm/component/shared.js +0 -79
  169. package/dist/esm/component/shared.js.map +0 -1
  170. package/dist/esm/component/stats.d.ts.map +0 -1
  171. package/dist/esm/component/stats.js +0 -129
  172. package/dist/esm/component/stats.js.map +0 -1
  173. package/dist/esm/component/worker.d.ts +0 -16
  174. package/dist/esm/component/worker.d.ts.map +0 -1
  175. package/dist/esm/component/worker.js +0 -76
  176. package/dist/esm/component/worker.js.map +0 -1
  177. package/dist/esm/package.json +0 -3
  178. /package/dist/{commonjs/client → client}/utils.js +0 -0
  179. /package/dist/{commonjs/component → component}/_generated/api.js +0 -0
  180. /package/dist/{commonjs/component → component}/_generated/server.js +0 -0
  181. /package/dist/{commonjs/component → component}/convex.config.d.ts +0 -0
  182. /package/dist/{commonjs/component → component}/convex.config.js +0 -0
  183. /package/dist/{commonjs/component → component}/crons.d.ts +0 -0
  184. /package/dist/{commonjs/component → component}/danger.d.ts +0 -0
  185. /package/dist/{commonjs/component → component}/danger.js +0 -0
  186. /package/dist/{commonjs/component → component}/kick.js +0 -0
  187. /package/dist/{commonjs/component → component}/logging.d.ts +0 -0
  188. /package/dist/{commonjs/component → component}/logging.js +0 -0
  189. /package/dist/{commonjs/component → component}/schema.d.ts +0 -0
  190. /package/dist/{commonjs/component → component}/schema.js +0 -0
  191. /package/dist/{commonjs/component → component}/shared.d.ts +0 -0
  192. /package/dist/{commonjs/component → component}/shared.js +0 -0
  193. /package/dist/{commonjs/component → component}/worker.d.ts +0 -0
  194. /package/dist/{commonjs/component → component}/worker.js +0 -0
@@ -1,88 +0,0 @@
1
- import { v } from "convex/values";
2
- import { internalMutation } from "./_generated/server.js";
3
- import { kickMainLoop } from "./kick.js";
4
- import { createLogger } from "./logging.js";
5
- import { vResultValidator } from "./shared.js";
6
- import { recordCompleted } from "./stats.js";
7
- export const completeArgs = v.object({
8
- jobs: v.array(v.object({
9
- runResult: vResultValidator,
10
- workId: v.id("work"),
11
- attempt: v.number(),
12
- })),
13
- });
14
- export async function completeHandler(ctx, args) {
15
- const globals = await ctx.db.query("globals").unique();
16
- const console = createLogger(globals?.logLevel);
17
- const pendingCompletions = [];
18
- await Promise.all(args.jobs.map(async (job) => {
19
- const work = await ctx.db.get(job.workId);
20
- if (!work) {
21
- console.warn(`[complete] ${job.workId} is done, but its work is gone`);
22
- return;
23
- }
24
- if (work.attempts !== job.attempt) {
25
- console.warn(`[complete] ${job.workId} mismatched attempt number`);
26
- return;
27
- }
28
- work.attempts++;
29
- await ctx.db.patch(work._id, { attempts: work.attempts });
30
- const pendingCompletion = await ctx.db
31
- .query("pendingCompletion")
32
- .withIndex("workId", (q) => q.eq("workId", job.workId))
33
- .unique();
34
- if (pendingCompletion) {
35
- console.warn(`[complete] ${job.workId} already in pendingCompletion`);
36
- return;
37
- }
38
- const maxAttempts = work.retryBehavior?.maxAttempts;
39
- const retry = job.runResult.kind === "failed" &&
40
- !!maxAttempts &&
41
- work.attempts < maxAttempts;
42
- if (!retry) {
43
- if (work.onComplete) {
44
- try {
45
- const handle = work.onComplete.fnHandle;
46
- await ctx.runMutation(handle, {
47
- workId: work._id,
48
- context: work.onComplete.context,
49
- result: job.runResult,
50
- });
51
- console.debug(`[complete] onComplete for ${job.workId} completed`);
52
- }
53
- catch (e) {
54
- console.error(`[complete] error running onComplete for ${job.workId}`, e);
55
- // TODO: store failures in a table for later debugging
56
- }
57
- }
58
- recordCompleted(console, work, job.runResult.kind);
59
- // This is the terminating state for work.
60
- await ctx.db.delete(job.workId);
61
- }
62
- if (job.runResult.kind !== "canceled") {
63
- pendingCompletions.push({
64
- runResult: stripResult(job.runResult),
65
- workId: job.workId,
66
- retry,
67
- });
68
- }
69
- }));
70
- if (pendingCompletions.length > 0) {
71
- const segment = await kickMainLoop(ctx, "complete");
72
- await Promise.all(pendingCompletions.map((completion) => ctx.db.insert("pendingCompletion", {
73
- ...completion,
74
- segment,
75
- })));
76
- }
77
- }
78
- function stripResult(result) {
79
- if (result.kind === "success") {
80
- return { kind: "success", returnValue: null };
81
- }
82
- return result;
83
- }
84
- export const complete = internalMutation({
85
- args: completeArgs,
86
- handler: completeHandler,
87
- });
88
- //# sourceMappingURL=complete.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"complete.js","sourceRoot":"","sources":["../../../src/component/complete.ts"],"names":[],"mappings":"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"}
@@ -1,3 +0,0 @@
1
- declare const component: import("convex/server").ComponentDefinition<any>;
2
- export default component;
3
- //# sourceMappingURL=convex.config.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"convex.config.d.ts","sourceRoot":"","sources":["../../../src/component/convex.config.ts"],"names":[],"mappings":"AAEA,QAAA,MAAM,SAAS,kDAA8B,CAAC;AAE9C,eAAe,SAAS,CAAC"}
@@ -1,4 +0,0 @@
1
- import { defineComponent } from "convex/server";
2
- const component = defineComponent("workpool");
3
- export default component;
4
- //# sourceMappingURL=convex.config.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"convex.config.js","sourceRoot":"","sources":["../../../src/component/convex.config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAEhD,MAAM,SAAS,GAAG,eAAe,CAAC,UAAU,CAAC,CAAC;AAE9C,eAAe,SAAS,CAAC"}
@@ -1,4 +0,0 @@
1
- declare const crons: import("convex/server").Crons;
2
- export declare const recover: import("convex/server").RegisteredMutation<"internal", {}, Promise<void>>;
3
- export default crons;
4
- //# sourceMappingURL=crons.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"crons.d.ts","sourceRoot":"","sources":["../../../src/component/crons.ts"],"names":[],"mappings":"AAMA,QAAA,MAAM,KAAK,+BAAa,CAAC;AAEzB,eAAO,MAAM,OAAO,2EAqDlB,CAAC;AAIH,eAAe,KAAK,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"crons.js","sourceRoot":"","sources":["../../../src/component/crons.ts"],"names":[],"mappings":"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"}
@@ -1,11 +0,0 @@
1
- export declare const clearPending: import("convex/server").RegisteredMutation<"internal", {
2
- olderThan?: number | undefined;
3
- before?: number | undefined;
4
- cursor?: string | undefined;
5
- }, Promise<void>>;
6
- export declare const clearOldWork: import("convex/server").RegisteredMutation<"internal", {
7
- olderThan?: number | undefined;
8
- before?: number | undefined;
9
- cursor?: string | undefined;
10
- }, Promise<void>>;
11
- //# sourceMappingURL=danger.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"danger.d.ts","sourceRoot":"","sources":["../../../src/component/danger.ts"],"names":[],"mappings":"AAQA,eAAO,MAAM,YAAY;;;;iBAgCvB,CAAC;AAEH,eAAO,MAAM,YAAY;;;;iBA2DvB,CAAC"}
@@ -1,92 +0,0 @@
1
- import { v } from "convex/values";
2
- import { internal } from "./_generated/api.js";
3
- import { internalMutation } from "./_generated/server.js";
4
- import { paginator } from "convex-helpers/server/pagination";
5
- import schema from "./schema.js";
6
- const DEFAULT_OLDER_THAN = 1000 * 60 * 60 * 24;
7
- export const clearPending = internalMutation({
8
- args: {
9
- olderThan: v.optional(v.number()),
10
- before: v.optional(v.number()),
11
- cursor: v.optional(v.string()),
12
- },
13
- handler: async (ctx, args) => {
14
- const time = args.before ?? Date.now() - (args.olderThan ?? DEFAULT_OLDER_THAN);
15
- const entries = await paginator(ctx.db, schema)
16
- .query("pendingStart")
17
- .withIndex("by_creation_time", (q) => q.lt("_creationTime", time))
18
- .paginate({
19
- cursor: args.cursor ?? null,
20
- numItems: 100,
21
- });
22
- await Promise.all(entries.page.map(async (entry) => {
23
- await ctx.db.delete(entry._id);
24
- const work = await ctx.db.get(entry.workId);
25
- if (work) {
26
- await ctx.db.delete(work._id);
27
- }
28
- }));
29
- if (!entries.isDone) {
30
- await ctx.scheduler.runAfter(0, internal.danger.clearPending, {
31
- before: time,
32
- cursor: entries.continueCursor,
33
- });
34
- }
35
- },
36
- });
37
- export const clearOldWork = internalMutation({
38
- args: {
39
- olderThan: v.optional(v.number()),
40
- before: v.optional(v.number()),
41
- cursor: v.optional(v.string()),
42
- },
43
- handler: async (ctx, args) => {
44
- const time = args.before ?? Date.now() - (args.olderThan ?? DEFAULT_OLDER_THAN);
45
- const entries = await paginator(ctx.db, schema)
46
- .query("work")
47
- .withIndex("by_creation_time", (q) => q.lt("_creationTime", time))
48
- .paginate({
49
- cursor: args.cursor ?? null,
50
- numItems: 100,
51
- });
52
- await Promise.all(entries.page.map(async (entry) => {
53
- const pendingStart = await ctx.db
54
- .query("pendingStart")
55
- .withIndex("workId", (q) => q.eq("workId", entry._id))
56
- .unique();
57
- if (pendingStart) {
58
- await ctx.db.delete(pendingStart._id);
59
- }
60
- const pendingCompletion = await ctx.db
61
- .query("pendingCompletion")
62
- .withIndex("workId", (q) => q.eq("workId", entry._id))
63
- .unique();
64
- if (pendingCompletion) {
65
- await ctx.db.delete(pendingCompletion._id);
66
- }
67
- const pendingCancelation = await ctx.db
68
- .query("pendingCancelation")
69
- .withIndex("workId", (q) => q.eq("workId", entry._id))
70
- .unique();
71
- if (pendingCancelation) {
72
- await ctx.db.delete(pendingCancelation._id);
73
- }
74
- console.debug(`cleared ${entry.fnName}: ${entry.fnArgs} (${Object.entries({
75
- pendingStart,
76
- pendingCompletion,
77
- pendingCancelation,
78
- })
79
- .filter(([_, v]) => v !== null)
80
- .map(([name]) => name)
81
- .join(", ")})`);
82
- await ctx.db.delete(entry._id);
83
- }));
84
- if (!entries.isDone) {
85
- await ctx.scheduler.runAfter(0, internal.danger.clearOldWork, {
86
- before: time,
87
- cursor: entries.continueCursor,
88
- });
89
- }
90
- },
91
- });
92
- //# sourceMappingURL=danger.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"danger.js","sourceRoot":"","sources":["../../../src/component/danger.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"kick.d.ts","sourceRoot":"","sources":["../../../src/component/kick.ts"],"names":[],"mappings":"AACA,OAAO,EAAoB,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAGvE,OAAO,EAEL,MAAM,EAOP,MAAM,aAAa,CAAC;AAErB;;;GAGG;AACH,wBAAsB,YAAY,CAChC,GAAG,EAAE,WAAW,EAChB,MAAM,EAAE,SAAS,GAAG,QAAQ,GAAG,UAAU,GAAG,MAAM,EAClD,MAAM,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,GACvB,OAAO,CAAC,MAAM,CAAC,CAiDjB;AAED,eAAO,MAAM,SAAS,2EAOpB,CAAC"}
@@ -1,102 +0,0 @@
1
- import { internal } from "./_generated/api.js";
2
- import { internalMutation } from "./_generated/server.js";
3
- import { createLogger, DEFAULT_LOG_LEVEL } from "./logging.js";
4
- import { INITIAL_STATE } from "./loop.js";
5
- import { boundScheduledTime, DEFAULT_MAX_PARALLELISM, fromSegment, getCurrentSegment, getNextSegment, SECOND, toSegment, } from "./shared.js";
6
- /**
7
- * Called from outside the loop.
8
- * Returns the soonest segment to enqueue work for the main loop.
9
- */
10
- export async function kickMainLoop(ctx, source, config) {
11
- const globals = await getOrUpdateGlobals(ctx, config);
12
- const console = createLogger(globals.logLevel);
13
- const runStatus = await getOrCreateRunStatus(ctx);
14
- const next = getNextSegment();
15
- // Only kick to run now if we're scheduled or idle.
16
- if (runStatus.state.kind === "running") {
17
- console.debug(`[${source}] main is actively running, so we don't need to kick it`);
18
- return next;
19
- }
20
- // main is scheduled to run later, so we should cancel it and reschedule.
21
- if (runStatus.state.kind === "scheduled") {
22
- if (source === "enqueue" && runStatus.state.saturated) {
23
- console.debug(`[${source}] main is saturated, so we don't need to kick it`);
24
- return next;
25
- }
26
- if (runStatus.state.segment <= toSegment(Date.now() + SECOND)) {
27
- console.debug(`[${source}] main is scheduled to run soon enough, so we don't need to kick it`);
28
- return next;
29
- }
30
- console.debug(`[${source}] main is scheduled to run later, so reschedule it to run now`);
31
- const scheduled = await ctx.db.system.get(runStatus.state.scheduledId);
32
- if (scheduled && scheduled.state.kind === "pending") {
33
- await ctx.scheduler.cancel(runStatus.state.scheduledId);
34
- }
35
- else {
36
- console.warn(`[${source}] main is marked as scheduled, but it's status is ${scheduled?.state.kind}`);
37
- }
38
- }
39
- else if (runStatus.state.kind === "idle") {
40
- console.debug(`[${source}] main was idle, so run it now`);
41
- }
42
- await ctx.db.patch(runStatus._id, { state: { kind: "running" } });
43
- const current = getCurrentSegment();
44
- const scheduledTime = boundScheduledTime(fromSegment(current), console);
45
- await ctx.scheduler.runAt(scheduledTime, internal.loop.main, {
46
- generation: runStatus.state.generation,
47
- segment: current,
48
- });
49
- return current;
50
- }
51
- export const forceKick = internalMutation({
52
- args: {},
53
- handler: async (ctx) => {
54
- const runStatus = await getOrCreateRunStatus(ctx);
55
- await ctx.db.delete(runStatus._id);
56
- await kickMainLoop(ctx, "kick");
57
- },
58
- });
59
- async function getOrCreateRunStatus(ctx) {
60
- let runStatus = await ctx.db.query("runStatus").unique();
61
- if (!runStatus) {
62
- const state = await ctx.db.query("internalState").unique();
63
- const id = await ctx.db.insert("runStatus", {
64
- state: {
65
- kind: "idle",
66
- generation: state?.generation ?? INITIAL_STATE.generation,
67
- },
68
- });
69
- runStatus = (await ctx.db.get(id));
70
- if (!state) {
71
- await ctx.db.insert("internalState", INITIAL_STATE);
72
- }
73
- }
74
- return runStatus;
75
- }
76
- async function getOrUpdateGlobals(ctx, config) {
77
- const globals = await ctx.db.query("globals").unique();
78
- if (!globals) {
79
- const id = await ctx.db.insert("globals", {
80
- maxParallelism: config?.maxParallelism ?? DEFAULT_MAX_PARALLELISM,
81
- logLevel: config?.logLevel ?? DEFAULT_LOG_LEVEL,
82
- });
83
- return (await ctx.db.get(id));
84
- }
85
- else if (config) {
86
- let updated = false;
87
- if (config.maxParallelism &&
88
- config.maxParallelism !== globals.maxParallelism) {
89
- globals.maxParallelism = config.maxParallelism;
90
- updated = true;
91
- }
92
- if (config.logLevel && config.logLevel !== globals.logLevel) {
93
- globals.logLevel = config.logLevel;
94
- updated = true;
95
- }
96
- if (updated) {
97
- await ctx.db.replace(globals._id, globals);
98
- }
99
- }
100
- return globals;
101
- }
102
- //# sourceMappingURL=kick.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"kick.js","sourceRoot":"","sources":["../../../src/component/kick.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"lib.d.ts","sourceRoot":"","sources":["../../../src/component/lib.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,EAAE,EAAE,MAAM,2BAA2B,CAAC;AAiC/C,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;;;sDASlB,CAAC;AAiCH,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;MAcvB,CAAC;AAEH,eAAO,MAAM,MAAM;;;iBAejB,CAAC;AAGH,eAAO,MAAM,SAAS;;;;iBAyCpB,CAAC;AAEH,eAAO,MAAM,MAAM;QAKuC,EAAE,CAAC,MAAM,CAAC;;;;;;;;;;GADlE,CAAC;AAwBH,eAAO,MAAM,WAAW;;;;;;;;;;;MAQtB,CAAC"}
@@ -1,179 +0,0 @@
1
- import { v } from "convex/values";
2
- import { api } from "./_generated/api.js";
3
- import { fnType } from "./shared.js";
4
- import { mutation, query } from "./_generated/server.js";
5
- import { kickMainLoop } from "./kick.js";
6
- import { createLogger, logLevel } from "./logging.js";
7
- import { boundScheduledTime, config, getNextSegment, max, onComplete, retryBehavior, status as statusValidator, toSegment, } from "./shared.js";
8
- import { recordEnqueued } from "./stats.js";
9
- const MAX_POSSIBLE_PARALLELISM = 100;
10
- const MAX_PARALLELISM_SOFT_LIMIT = 50;
11
- const itemArgs = {
12
- fnHandle: v.string(),
13
- fnName: v.string(),
14
- fnArgs: v.any(),
15
- fnType,
16
- runAt: v.number(),
17
- // TODO: annotation?
18
- onComplete: v.optional(onComplete),
19
- retryBehavior: v.optional(retryBehavior),
20
- };
21
- const enqueueArgs = {
22
- ...itemArgs,
23
- config,
24
- };
25
- export const enqueue = mutation({
26
- args: enqueueArgs,
27
- returns: v.id("work"),
28
- handler: async (ctx, { config, ...itemArgs }) => {
29
- validateConfig(config);
30
- const console = createLogger(config.logLevel);
31
- const kickSegment = await kickMainLoop(ctx, "enqueue", config);
32
- return await enqueueHandler(ctx, console, kickSegment, itemArgs);
33
- },
34
- });
35
- async function enqueueHandler(ctx, console, kickSegment, { runAt, ...workArgs }) {
36
- runAt = boundScheduledTime(runAt, console);
37
- const workId = await ctx.db.insert("work", {
38
- ...workArgs,
39
- attempts: 0,
40
- });
41
- await ctx.db.insert("pendingStart", {
42
- workId,
43
- segment: max(toSegment(runAt), kickSegment),
44
- });
45
- recordEnqueued(console, { workId, fnName: workArgs.fnName, runAt });
46
- return workId;
47
- }
48
- function validateConfig(config) {
49
- if (config.maxParallelism > MAX_POSSIBLE_PARALLELISM) {
50
- throw new Error(`maxParallelism must be <= ${MAX_PARALLELISM_SOFT_LIMIT}`);
51
- }
52
- else if (config.maxParallelism > MAX_PARALLELISM_SOFT_LIMIT) {
53
- createLogger(config.logLevel).warn(`maxParallelism should be <= ${MAX_PARALLELISM_SOFT_LIMIT}, but is set to ${config.maxParallelism}. This will be an error in a future version.`);
54
- }
55
- else if (config.maxParallelism < 1) {
56
- throw new Error("maxParallelism must be >= 1");
57
- }
58
- }
59
- export const enqueueBatch = mutation({
60
- args: {
61
- items: v.array(v.object(itemArgs)),
62
- config,
63
- },
64
- returns: v.array(v.id("work")),
65
- handler: async (ctx, { config, items }) => {
66
- validateConfig(config);
67
- const console = createLogger(config.logLevel);
68
- const kickSegment = await kickMainLoop(ctx, "enqueue", config);
69
- return Promise.all(items.map((item) => enqueueHandler(ctx, console, kickSegment, item)));
70
- },
71
- });
72
- export const cancel = mutation({
73
- args: {
74
- id: v.id("work"),
75
- logLevel,
76
- },
77
- handler: async (ctx, { id, logLevel }) => {
78
- const shouldCancel = await shouldCancelWorkItem(ctx, id, logLevel);
79
- if (shouldCancel) {
80
- const segment = await kickMainLoop(ctx, "cancel", { logLevel });
81
- await ctx.db.insert("pendingCancelation", {
82
- workId: id,
83
- segment,
84
- });
85
- }
86
- },
87
- });
88
- const PAGE_SIZE = 64;
89
- export const cancelAll = mutation({
90
- args: {
91
- logLevel,
92
- before: v.optional(v.number()),
93
- limit: v.optional(v.number()),
94
- },
95
- handler: async (ctx, { logLevel, before, limit }) => {
96
- const beforeTime = before ?? Date.now();
97
- const pageSize = limit ?? PAGE_SIZE;
98
- const pageOfWork = await ctx.db
99
- .query("work")
100
- .withIndex("by_creation_time", (q) => q.lte("_creationTime", beforeTime))
101
- .order("desc")
102
- .take(pageSize);
103
- const shouldCancel = await Promise.all(pageOfWork.map(async ({ _id }) => shouldCancelWorkItem(ctx, _id, logLevel)));
104
- let segment = getNextSegment();
105
- if (shouldCancel.some((c) => c)) {
106
- segment = await kickMainLoop(ctx, "cancel", { logLevel });
107
- }
108
- await Promise.all(pageOfWork.map(({ _id }, index) => {
109
- if (shouldCancel[index]) {
110
- return ctx.db.insert("pendingCancelation", {
111
- workId: _id,
112
- segment,
113
- });
114
- }
115
- }));
116
- if (pageOfWork.length === pageSize) {
117
- await ctx.scheduler.runAfter(0, api.lib.cancelAll, {
118
- logLevel,
119
- before: pageOfWork[pageOfWork.length - 1]._creationTime,
120
- limit: pageSize,
121
- });
122
- }
123
- },
124
- });
125
- export const status = query({
126
- args: { id: v.id("work") },
127
- returns: statusValidator,
128
- handler: statusHandler,
129
- });
130
- async function statusHandler(ctx, { id }) {
131
- const work = await ctx.db.get(id);
132
- if (!work) {
133
- return { state: "finished" };
134
- }
135
- const pendingStart = await ctx.db
136
- .query("pendingStart")
137
- .withIndex("workId", (q) => q.eq("workId", id))
138
- .unique();
139
- if (pendingStart) {
140
- return { state: "pending", previousAttempts: work.attempts };
141
- }
142
- const pendingCompletion = await ctx.db
143
- .query("pendingCompletion")
144
- .withIndex("workId", (q) => q.eq("workId", id))
145
- .unique();
146
- if (pendingCompletion?.retry) {
147
- return { state: "pending", previousAttempts: work.attempts };
148
- }
149
- // Assume it's in progress. It could be pending cancelation
150
- return { state: "running", previousAttempts: work.attempts };
151
- }
152
- export const statusBatch = query({
153
- args: { ids: v.array(v.id("work")) },
154
- returns: v.array(statusValidator),
155
- handler: async (ctx, { ids }) => {
156
- return await Promise.all(ids.map(async (id) => await statusHandler(ctx, { id })));
157
- },
158
- });
159
- async function shouldCancelWorkItem(ctx, workId, logLevel) {
160
- const console = createLogger(logLevel);
161
- // No-op if the work doesn't exist or has completed.
162
- const work = await ctx.db.get(workId);
163
- if (!work) {
164
- console.warn(`[cancel] work ${workId} doesn't exist`);
165
- return false;
166
- }
167
- const pendingCancelation = await ctx.db
168
- .query("pendingCancelation")
169
- .withIndex("workId", (q) => q.eq("workId", workId))
170
- .unique();
171
- if (pendingCancelation) {
172
- console.warn(`[cancel] work ${workId} has already been canceled`);
173
- return false;
174
- }
175
- return true;
176
- }
177
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
178
- const console = "THIS IS A REMINDER TO USE createLogger";
179
- //# sourceMappingURL=lib.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"lib.js","sourceRoot":"","sources":["../../../src/component/lib.ts"],"names":[],"mappings":"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"}
@@ -1,16 +0,0 @@
1
- import { type Infer } from "convex/values";
2
- export declare const DEFAULT_LOG_LEVEL: LogLevel;
3
- export declare const logLevel: import("convex/values").VUnion<"DEBUG" | "TRACE" | "INFO" | "REPORT" | "WARN" | "ERROR", [import("convex/values").VLiteral<"DEBUG", "required">, import("convex/values").VLiteral<"TRACE", "required">, import("convex/values").VLiteral<"INFO", "required">, import("convex/values").VLiteral<"REPORT", "required">, import("convex/values").VLiteral<"WARN", "required">, import("convex/values").VLiteral<"ERROR", "required">], "required", never>;
4
- export type LogLevel = Infer<typeof logLevel>;
5
- export type Logger = {
6
- debug: (...args: unknown[]) => void;
7
- info: (...args: unknown[]) => void;
8
- warn: (...args: unknown[]) => void;
9
- error: (...args: unknown[]) => void;
10
- time: (label: string) => void;
11
- timeEnd: (label: string) => void;
12
- event: (event: string, payload: Record<string, unknown>) => void;
13
- };
14
- export declare function shouldLog(config: LogLevel, level: LogLevel): boolean;
15
- export declare function createLogger(level?: LogLevel): Logger;
16
- //# sourceMappingURL=logging.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../../src/component/logging.ts"],"names":[],"mappings":"AAAA,OAAO,EAAK,KAAK,KAAK,EAAE,MAAM,eAAe,CAAC;AAE9C,eAAO,MAAM,iBAAiB,EAAE,QAAmB,CAAC;AAIpD,eAAO,MAAM,QAAQ,wbAOpB,CAAC;AACF,MAAM,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,QAAQ,CAAC,CAAC;AAE9C,MAAM,MAAM,MAAM,GAAG;IACnB,KAAK,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IACpC,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IACnC,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IACnC,KAAK,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IACpC,IAAI,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9B,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACjC,KAAK,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAC;CAClE,CAAC;AAUF,wBAAgB,SAAS,CAAC,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,WAE1D;AAQD,wBAAgB,YAAY,CAAC,KAAK,CAAC,EAAE,QAAQ,GAAG,MAAM,CAiDrD"}