@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.
- package/README.md +1 -0
- package/dist/{commonjs/client → client}/index.d.ts +13 -11
- package/dist/client/index.d.ts.map +1 -0
- package/dist/{commonjs/client → client}/index.js +6 -7
- package/dist/client/index.js.map +1 -0
- package/dist/{commonjs/client → client}/utils.d.ts +2 -2
- package/dist/client/utils.d.ts.map +1 -0
- package/dist/client/utils.js.map +1 -0
- package/dist/component/_generated/api.d.ts +151 -0
- package/dist/component/_generated/api.d.ts.map +1 -0
- package/dist/component/_generated/api.js.map +1 -0
- package/dist/component/_generated/dataModel.d.ts +60 -0
- package/dist/component/_generated/server.d.ts +149 -0
- package/dist/component/_generated/server.d.ts.map +1 -0
- package/dist/component/_generated/server.js.map +1 -0
- package/dist/{commonjs/component → component}/complete.d.ts +2 -2
- package/dist/component/complete.d.ts.map +1 -0
- package/dist/{commonjs/component → component}/complete.js +1 -1
- package/dist/component/complete.js.map +1 -0
- package/dist/component/convex.config.d.ts.map +1 -0
- package/dist/component/convex.config.js.map +1 -0
- package/dist/component/crons.d.ts.map +1 -0
- package/dist/{esm/component → component}/crons.js +4 -4
- package/dist/component/crons.js.map +1 -0
- package/dist/component/danger.d.ts.map +1 -0
- package/dist/component/danger.js.map +1 -0
- package/dist/{esm/component → component}/kick.d.ts +2 -2
- package/dist/component/kick.d.ts.map +1 -0
- package/dist/component/kick.js.map +1 -0
- package/dist/{esm/component → component}/lib.d.ts +1 -1
- package/dist/component/lib.d.ts.map +1 -0
- package/dist/{commonjs/component → component}/lib.js +3 -4
- package/dist/component/lib.js.map +1 -0
- package/dist/component/logging.d.ts.map +1 -0
- package/dist/component/logging.js.map +1 -0
- package/dist/{commonjs/component → component}/loop.d.ts +2 -2
- package/dist/component/loop.d.ts.map +1 -0
- package/dist/{commonjs/component → component}/loop.js +1 -1
- package/dist/component/loop.js.map +1 -0
- package/dist/{esm/component → component}/recovery.d.ts +2 -2
- package/dist/component/recovery.d.ts.map +1 -0
- package/dist/{commonjs/component → component}/recovery.js +1 -1
- package/dist/component/recovery.js.map +1 -0
- package/dist/{commonjs/component → component}/schema.d.ts.map +1 -1
- package/dist/component/schema.js.map +1 -0
- package/dist/component/shared.d.ts.map +1 -0
- package/dist/component/shared.js.map +1 -0
- package/dist/{esm/component → component}/stats.d.ts +4 -4
- package/dist/component/stats.d.ts.map +1 -0
- package/dist/{commonjs/component → component}/stats.js +0 -3
- package/dist/component/stats.js.map +1 -0
- package/dist/component/worker.d.ts.map +1 -0
- package/dist/component/worker.js.map +1 -0
- package/package.json +42 -39
- package/src/client/index.ts +32 -29
- package/src/client/utils.ts +7 -7
- package/src/component/_generated/api.d.ts +1 -0
- package/src/component/complete.test.ts +6 -6
- package/src/component/complete.ts +9 -5
- package/src/component/crons.ts +4 -4
- package/src/component/kick.test.ts +3 -3
- package/src/component/kick.ts +2 -2
- package/src/component/lib.test.ts +6 -6
- package/src/component/lib.ts +15 -5
- package/src/component/logging.test.ts +1 -1
- package/src/component/loop.test.ts +7 -7
- package/src/component/loop.ts +8 -8
- package/src/component/recovery.test.ts +9 -9
- package/src/component/recovery.ts +2 -2
- package/src/component/stats.test.ts +11 -11
- package/src/component/stats.ts +4 -7
- package/src/test.ts +3 -0
- package/dist/commonjs/client/index.d.ts.map +0 -1
- package/dist/commonjs/client/index.js.map +0 -1
- package/dist/commonjs/client/utils.d.ts.map +0 -1
- package/dist/commonjs/client/utils.js.map +0 -1
- package/dist/commonjs/component/_generated/api.d.ts +0 -12
- package/dist/commonjs/component/_generated/api.d.ts.map +0 -1
- package/dist/commonjs/component/_generated/api.js.map +0 -1
- package/dist/commonjs/component/_generated/server.d.ts +0 -64
- package/dist/commonjs/component/_generated/server.d.ts.map +0 -1
- package/dist/commonjs/component/_generated/server.js.map +0 -1
- package/dist/commonjs/component/complete.d.ts.map +0 -1
- package/dist/commonjs/component/complete.js.map +0 -1
- package/dist/commonjs/component/convex.config.d.ts.map +0 -1
- package/dist/commonjs/component/convex.config.js.map +0 -1
- package/dist/commonjs/component/crons.d.ts.map +0 -1
- package/dist/commonjs/component/crons.js +0 -61
- package/dist/commonjs/component/crons.js.map +0 -1
- package/dist/commonjs/component/danger.d.ts.map +0 -1
- package/dist/commonjs/component/danger.js.map +0 -1
- package/dist/commonjs/component/kick.d.ts +0 -9
- package/dist/commonjs/component/kick.d.ts.map +0 -1
- package/dist/commonjs/component/kick.js.map +0 -1
- package/dist/commonjs/component/lib.d.ts +0 -79
- package/dist/commonjs/component/lib.d.ts.map +0 -1
- package/dist/commonjs/component/lib.js.map +0 -1
- package/dist/commonjs/component/logging.d.ts.map +0 -1
- package/dist/commonjs/component/logging.js.map +0 -1
- package/dist/commonjs/component/loop.d.ts.map +0 -1
- package/dist/commonjs/component/loop.js.map +0 -1
- package/dist/commonjs/component/recovery.d.ts +0 -53
- package/dist/commonjs/component/recovery.d.ts.map +0 -1
- package/dist/commonjs/component/recovery.js.map +0 -1
- package/dist/commonjs/component/schema.js.map +0 -1
- package/dist/commonjs/component/shared.d.ts.map +0 -1
- package/dist/commonjs/component/shared.js.map +0 -1
- package/dist/commonjs/component/stats.d.ts +0 -45
- package/dist/commonjs/component/stats.d.ts.map +0 -1
- package/dist/commonjs/component/stats.js.map +0 -1
- package/dist/commonjs/component/worker.d.ts.map +0 -1
- package/dist/commonjs/component/worker.js.map +0 -1
- package/dist/commonjs/package.json +0 -3
- package/dist/esm/client/index.d.ts +0 -429
- package/dist/esm/client/index.d.ts.map +0 -1
- package/dist/esm/client/index.js +0 -317
- package/dist/esm/client/index.js.map +0 -1
- package/dist/esm/client/utils.d.ts +0 -16
- package/dist/esm/client/utils.d.ts.map +0 -1
- package/dist/esm/client/utils.js +0 -9
- package/dist/esm/client/utils.js.map +0 -1
- package/dist/esm/component/_generated/api.d.ts +0 -12
- package/dist/esm/component/_generated/api.d.ts.map +0 -1
- package/dist/esm/component/_generated/api.js +0 -22
- package/dist/esm/component/_generated/api.js.map +0 -1
- package/dist/esm/component/_generated/server.d.ts +0 -64
- package/dist/esm/component/_generated/server.d.ts.map +0 -1
- package/dist/esm/component/_generated/server.js +0 -74
- package/dist/esm/component/_generated/server.js.map +0 -1
- package/dist/esm/component/complete.d.ts +0 -89
- package/dist/esm/component/complete.d.ts.map +0 -1
- package/dist/esm/component/complete.js +0 -88
- package/dist/esm/component/complete.js.map +0 -1
- package/dist/esm/component/convex.config.d.ts +0 -3
- package/dist/esm/component/convex.config.d.ts.map +0 -1
- package/dist/esm/component/convex.config.js +0 -4
- package/dist/esm/component/convex.config.js.map +0 -1
- package/dist/esm/component/crons.d.ts +0 -4
- package/dist/esm/component/crons.d.ts.map +0 -1
- package/dist/esm/component/crons.js.map +0 -1
- package/dist/esm/component/danger.d.ts +0 -11
- package/dist/esm/component/danger.d.ts.map +0 -1
- package/dist/esm/component/danger.js +0 -92
- package/dist/esm/component/danger.js.map +0 -1
- package/dist/esm/component/kick.d.ts.map +0 -1
- package/dist/esm/component/kick.js +0 -102
- package/dist/esm/component/kick.js.map +0 -1
- package/dist/esm/component/lib.d.ts.map +0 -1
- package/dist/esm/component/lib.js +0 -179
- package/dist/esm/component/lib.js.map +0 -1
- package/dist/esm/component/logging.d.ts +0 -16
- package/dist/esm/component/logging.d.ts.map +0 -1
- package/dist/esm/component/logging.js +0 -71
- package/dist/esm/component/logging.js.map +0 -1
- package/dist/esm/component/loop.d.ts +0 -14
- package/dist/esm/component/loop.d.ts.map +0 -1
- package/dist/esm/component/loop.js +0 -503
- package/dist/esm/component/loop.js.map +0 -1
- package/dist/esm/component/recovery.d.ts.map +0 -1
- package/dist/esm/component/recovery.js +0 -97
- package/dist/esm/component/recovery.js.map +0 -1
- package/dist/esm/component/schema.d.ts +0 -228
- package/dist/esm/component/schema.d.ts.map +0 -1
- package/dist/esm/component/schema.js +0 -79
- package/dist/esm/component/schema.js.map +0 -1
- package/dist/esm/component/shared.d.ts +0 -140
- package/dist/esm/component/shared.d.ts.map +0 -1
- package/dist/esm/component/shared.js +0 -79
- package/dist/esm/component/shared.js.map +0 -1
- package/dist/esm/component/stats.d.ts.map +0 -1
- package/dist/esm/component/stats.js +0 -129
- package/dist/esm/component/stats.js.map +0 -1
- package/dist/esm/component/worker.d.ts +0 -16
- package/dist/esm/component/worker.d.ts.map +0 -1
- package/dist/esm/component/worker.js +0 -76
- package/dist/esm/component/worker.js.map +0 -1
- package/dist/esm/package.json +0 -3
- /package/dist/{commonjs/client → client}/utils.js +0 -0
- /package/dist/{commonjs/component → component}/_generated/api.js +0 -0
- /package/dist/{commonjs/component → component}/_generated/server.js +0 -0
- /package/dist/{commonjs/component → component}/convex.config.d.ts +0 -0
- /package/dist/{commonjs/component → component}/convex.config.js +0 -0
- /package/dist/{commonjs/component → component}/crons.d.ts +0 -0
- /package/dist/{commonjs/component → component}/danger.d.ts +0 -0
- /package/dist/{commonjs/component → component}/danger.js +0 -0
- /package/dist/{commonjs/component → component}/kick.js +0 -0
- /package/dist/{commonjs/component → component}/logging.d.ts +0 -0
- /package/dist/{commonjs/component → component}/logging.js +0 -0
- /package/dist/{commonjs/component → component}/schema.d.ts +0 -0
- /package/dist/{commonjs/component → component}/schema.js +0 -0
- /package/dist/{commonjs/component → component}/shared.d.ts +0 -0
- /package/dist/{commonjs/component → component}/shared.js +0 -0
- /package/dist/{commonjs/component → component}/worker.d.ts +0 -0
- /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 +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 +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 +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"}
|