-
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Expand file tree
/
Copy pathtriggerTask.server.ts
More file actions
121 lines (110 loc) · 3.96 KB
/
triggerTask.server.ts
File metadata and controls
121 lines (110 loc) · 3.96 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
import { TriggerTaskRequestBody } from "@trigger.dev/core/v3";
import { RunEngineVersion, TaskRun } from "@trigger.dev/database";
import { env } from "~/env.server";
import { IdempotencyKeyConcern } from "~/runEngine/concerns/idempotencyKeys.server";
import { DefaultPayloadProcessor } from "~/runEngine/concerns/payloads.server";
import { DefaultQueueManager } from "~/runEngine/concerns/queues.server";
import { DefaultRunNumberIncrementer } from "~/runEngine/concerns/runNumbers.server";
import { DefaultTraceEventsConcern } from "~/runEngine/concerns/traceEvents.server";
import { RunEngineTriggerTaskService } from "~/runEngine/services/triggerTask.server";
import { DefaultTriggerTaskValidator } from "~/runEngine/validators/triggerTaskValidator";
import { AuthenticatedEnvironment } from "~/services/apiAuth.server";
import { determineEngineVersion } from "../engineVersion.server";
import { tracer } from "../tracer.server";
import { WithRunEngine } from "./baseService.server";
import { TriggerTaskServiceV1 } from "./triggerTaskV1.server";
export type TriggerTaskServiceOptions = {
idempotencyKey?: string;
idempotencyKeyExpiresAt?: Date;
triggerVersion?: string;
traceContext?: Record<string, unknown>;
spanParentAsLink?: boolean;
parentAsLinkType?: "replay" | "trigger";
batchId?: string;
batchIndex?: number;
customIcon?: string;
runFriendlyId?: string;
skipChecks?: boolean;
oneTimeUseToken?: string;
scheduleId?: string;
scheduleInstanceId?: string;
queueTimestamp?: Date;
overrideCreatedAt?: Date;
replayedFromTaskRunFriendlyId?: string;
planType?: string;
};
export class OutOfEntitlementError extends Error {
constructor() {
super("You can't trigger a task because you have run out of credits.");
}
}
export type TriggerTaskServiceResult = {
run: TaskRun;
isCached: boolean;
};
export const MAX_ATTEMPTS = 2;
export class TriggerTaskService extends WithRunEngine {
public async call(
taskId: string,
environment: AuthenticatedEnvironment,
body: TriggerTaskRequestBody,
options: TriggerTaskServiceOptions = {},
version?: RunEngineVersion
): Promise<TriggerTaskServiceResult | undefined> {
return await this.traceWithEnv("call()", environment, async (span) => {
span.setAttribute("taskId", taskId);
const v = await determineEngineVersion({
environment,
workerVersion: body.options?.lockToVersion,
engineVersion: version,
});
switch (v) {
case "V1": {
return await this.callV1(taskId, environment, body, options);
}
case "V2": {
return await this.callV2(taskId, environment, body, options);
}
}
});
}
private async callV1(
taskId: string,
environment: AuthenticatedEnvironment,
body: TriggerTaskRequestBody,
options: TriggerTaskServiceOptions = {}
): Promise<TriggerTaskServiceResult | undefined> {
const service = new TriggerTaskServiceV1(this._prisma);
return await service.call(taskId, environment, body, options);
}
private async callV2(
taskId: string,
environment: AuthenticatedEnvironment,
body: TriggerTaskRequestBody,
options: TriggerTaskServiceOptions = {}
): Promise<TriggerTaskServiceResult | undefined> {
const traceEventConcern = new DefaultTraceEventsConcern();
const service = new RunEngineTriggerTaskService({
prisma: this._prisma,
engine: this._engine,
queueConcern: new DefaultQueueManager(this._prisma, this._engine),
validator: new DefaultTriggerTaskValidator(),
payloadProcessor: new DefaultPayloadProcessor(),
idempotencyKeyConcern: new IdempotencyKeyConcern(
this._prisma,
this._engine,
traceEventConcern
),
runNumberIncrementer: new DefaultRunNumberIncrementer(),
traceEventConcern,
tracer: tracer,
metadataMaximumSize: env.TASK_RUN_METADATA_MAXIMUM_SIZE,
});
return await service.call({
taskId,
environment,
body,
options,
});
}
}