@trigger.dev/build 0.0.0-v4-prerelease-20251107123438 → 0.0.0-v4-prerelease-20251204163219

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 (33) hide show
  1. package/dist/commonjs/extensions/core/neonSyncEnvVars.d.ts +14 -0
  2. package/dist/commonjs/extensions/core/neonSyncEnvVars.js +202 -0
  3. package/dist/commonjs/extensions/core/neonSyncEnvVars.js.map +1 -0
  4. package/dist/commonjs/extensions/core/vercelSyncEnvVars.d.ts +4 -0
  5. package/dist/commonjs/extensions/core/vercelSyncEnvVars.js +8 -3
  6. package/dist/commonjs/extensions/core/vercelSyncEnvVars.js.map +1 -1
  7. package/dist/commonjs/extensions/core.d.ts +1 -0
  8. package/dist/commonjs/extensions/core.js +1 -0
  9. package/dist/commonjs/extensions/core.js.map +1 -1
  10. package/dist/commonjs/extensions/prisma.d.ts +167 -26
  11. package/dist/commonjs/extensions/prisma.js +425 -26
  12. package/dist/commonjs/extensions/prisma.js.map +1 -1
  13. package/dist/commonjs/imports/mlly-cjs.cjs.map +1 -0
  14. package/dist/commonjs/imports/mlly.d.ts +1 -0
  15. package/dist/commonjs/imports/mlly.js +7 -0
  16. package/dist/commonjs/version.js +1 -1
  17. package/dist/esm/extensions/core/neonSyncEnvVars.d.ts +14 -0
  18. package/dist/esm/extensions/core/neonSyncEnvVars.js +198 -0
  19. package/dist/esm/extensions/core/neonSyncEnvVars.js.map +1 -0
  20. package/dist/esm/extensions/core/vercelSyncEnvVars.d.ts +4 -0
  21. package/dist/esm/extensions/core/vercelSyncEnvVars.js +8 -3
  22. package/dist/esm/extensions/core/vercelSyncEnvVars.js.map +1 -1
  23. package/dist/esm/extensions/core.d.ts +1 -0
  24. package/dist/esm/extensions/core.js +1 -0
  25. package/dist/esm/extensions/core.js.map +1 -1
  26. package/dist/esm/extensions/prisma.d.ts +167 -26
  27. package/dist/esm/extensions/prisma.js +423 -26
  28. package/dist/esm/extensions/prisma.js.map +1 -1
  29. package/dist/esm/imports/mlly.d.ts +2 -0
  30. package/dist/esm/imports/mlly.js +5 -0
  31. package/dist/esm/imports/mlly.js.map +1 -0
  32. package/dist/esm/version.js +1 -1
  33. package/package.json +9 -5
@@ -0,0 +1,14 @@
1
+ import { BuildExtension } from "@trigger.dev/core/v3/build";
2
+ export declare const NEON_ENV_VARS: string[];
3
+ export declare function syncNeonEnvVars(options?: {
4
+ projectId?: string;
5
+ /**
6
+ * Neon API access token for authentication.
7
+ * It's recommended to use the NEON_ACCESS_TOKEN environment variable instead of hardcoding this value.
8
+ */
9
+ neonAccessToken?: string;
10
+ branch?: string;
11
+ databaseName?: string;
12
+ roleName?: string;
13
+ envVarPrefix?: string;
14
+ }): BuildExtension;
@@ -0,0 +1,202 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NEON_ENV_VARS = void 0;
4
+ exports.syncNeonEnvVars = syncNeonEnvVars;
5
+ const core_js_1 = require("../core.js");
6
+ // List of Neon DB related environment variables to sync
7
+ exports.NEON_ENV_VARS = [
8
+ "PGUSER",
9
+ "POSTGRES_URL_NO_SSL",
10
+ "POSTGRES_HOST",
11
+ "POSTGRES_URL",
12
+ "POSTGRES_PRISMA_URL",
13
+ "DATABASE_URL_UNPOOLED",
14
+ "POSTGRES_URL_NON_POOLING",
15
+ "PGHOST",
16
+ "POSTGRES_USER",
17
+ "DATABASE_URL",
18
+ "POSTGRES_PASSWORD",
19
+ "POSTGRES_DATABASE",
20
+ "PGPASSWORD",
21
+ "PGDATABASE",
22
+ "PGHOST_UNPOOLED",
23
+ ];
24
+ function buildNeonEnvVarMappings(options) {
25
+ const { user, password, database, host, poolerHost } = options;
26
+ return {
27
+ PGUSER: user,
28
+ PGPASSWORD: password,
29
+ PGDATABASE: database,
30
+ PGHOST: poolerHost,
31
+ PGHOST_UNPOOLED: host,
32
+ POSTGRES_USER: user,
33
+ POSTGRES_PASSWORD: password,
34
+ POSTGRES_DATABASE: database,
35
+ POSTGRES_HOST: poolerHost,
36
+ DATABASE_URL: `postgresql://${encodeURIComponent(user)}:${encodeURIComponent(password)}@${poolerHost}/${database}?sslmode=require`,
37
+ DATABASE_URL_UNPOOLED: `postgresql://${encodeURIComponent(user)}:${encodeURIComponent(password)}@${host}/${database}?sslmode=require`,
38
+ POSTGRES_URL: `postgresql://${encodeURIComponent(user)}:${encodeURIComponent(password)}@${poolerHost}/${database}?sslmode=require`,
39
+ POSTGRES_URL_NO_SSL: `postgresql://${encodeURIComponent(user)}:${encodeURIComponent(password)}@${poolerHost}/${database}`,
40
+ POSTGRES_URL_NON_POOLING: `postgresql://${encodeURIComponent(user)}:${encodeURIComponent(password)}@${host}/${database}?sslmode=require`,
41
+ POSTGRES_PRISMA_URL: `postgresql://${encodeURIComponent(user)}:${encodeURIComponent(password)}@${poolerHost}/${database}?sslmode=require&pgbouncer=true&connect_timeout=15`,
42
+ };
43
+ }
44
+ function syncNeonEnvVars(options) {
45
+ const sync = (0, core_js_1.syncEnvVars)(async (ctx) => {
46
+ const projectId = options?.projectId ?? process.env.NEON_PROJECT_ID ?? ctx.env.NEON_PROJECT_ID;
47
+ const neonAccessToken = options?.neonAccessToken ?? process.env.NEON_ACCESS_TOKEN ?? ctx.env.NEON_ACCESS_TOKEN;
48
+ const branch = options?.branch ?? ctx.branch;
49
+ const envVarPrefix = options?.envVarPrefix ?? "";
50
+ const outputEnvVars = exports.NEON_ENV_VARS;
51
+ // Skip the whole process for Vercel environments
52
+ if (ctx.env.VERCEL) {
53
+ return [];
54
+ }
55
+ if (!projectId) {
56
+ throw new Error("syncNeonEnvVars: you did not pass in a projectId or set the NEON_PROJECT_ID env var.");
57
+ }
58
+ if (!neonAccessToken) {
59
+ throw new Error("syncNeonEnvVars: you did not pass in an neonAccessToken or set the NEON_ACCESS_TOKEN env var.");
60
+ }
61
+ // Skip branch-specific logic for production environment
62
+ if (ctx.environment === "prod") {
63
+ return [];
64
+ }
65
+ if (!branch) {
66
+ throw new Error("syncNeonEnvVars: you did not pass in a branch and no branch was detected from context.");
67
+ }
68
+ const environmentMap = {
69
+ prod: "production",
70
+ staging: "preview",
71
+ dev: "development",
72
+ preview: "preview",
73
+ };
74
+ const environment = environmentMap[ctx.environment];
75
+ if (!environment) {
76
+ throw new Error(`Invalid environment '${ctx.environment}'. Expected 'prod', 'staging', 'dev', or 'preview'.`);
77
+ }
78
+ if (environment === "development") {
79
+ // Skip syncing for development environment
80
+ return [];
81
+ }
82
+ try {
83
+ // Step 1: Search for the branch in Neon
84
+ const branchSearchParams = new URLSearchParams({ search: branch });
85
+ const branchesUrl = `https://console.neon.tech/api/v2/projects/${projectId}/branches?${branchSearchParams}`;
86
+ const branchesResponse = await fetch(branchesUrl, {
87
+ headers: {
88
+ Authorization: `Bearer ${neonAccessToken}`,
89
+ },
90
+ });
91
+ if (!branchesResponse.ok) {
92
+ throw new Error(`Failed to fetch Neon branches: ${branchesResponse.status}`);
93
+ }
94
+ const branchesData = await branchesResponse.json();
95
+ const branches = branchesData.branches || [];
96
+ if (branches.length === 0) {
97
+ // No matching branch found
98
+ return [];
99
+ }
100
+ // Neon branch names are prefixed with environment (e.g., "preview/branch-name")
101
+ const expectedBranchName = `${environment}/${branch}`;
102
+ const matchingBranch = branches.find((b) => b.name === expectedBranchName || b.name === branch);
103
+ if (!matchingBranch) {
104
+ // No exact match found
105
+ return [];
106
+ }
107
+ const neonBranchId = matchingBranch.id;
108
+ // Step 2: Get endpoints for the branch
109
+ const endpointsUrl = `https://console.neon.tech/api/v2/projects/${projectId}/branches/${neonBranchId}/endpoints`;
110
+ const endpointsResponse = await fetch(endpointsUrl, {
111
+ headers: {
112
+ Authorization: `Bearer ${neonAccessToken}`,
113
+ },
114
+ });
115
+ if (!endpointsResponse.ok) {
116
+ throw new Error(`Failed to fetch Neon branch endpoints: ${endpointsResponse.status}`);
117
+ }
118
+ const endpointsData = await endpointsResponse.json();
119
+ const endpoints = endpointsData.endpoints || [];
120
+ if (endpoints.length === 0) {
121
+ return [];
122
+ }
123
+ // Find an endpoint with type containing 'write', or take the first one
124
+ const writeEndpoint = endpoints.find((ep) => ep.type.includes("write"));
125
+ const endpoint = writeEndpoint || endpoints[0];
126
+ if (!endpoint) {
127
+ return [];
128
+ }
129
+ // Step 3: Get databases for the branch
130
+ const databasesUrl = `https://console.neon.tech/api/v2/projects/${projectId}/branches/${neonBranchId}/databases`;
131
+ const databasesResponse = await fetch(databasesUrl, {
132
+ headers: {
133
+ Authorization: `Bearer ${neonAccessToken}`,
134
+ },
135
+ });
136
+ if (!databasesResponse.ok) {
137
+ throw new Error(`Failed to fetch Neon branch databases: ${databasesResponse.status}`);
138
+ }
139
+ const databasesData = await databasesResponse.json();
140
+ const databases = databasesData.databases || [];
141
+ if (databases.length === 0) {
142
+ return [];
143
+ }
144
+ // Find the specified database or use the first one
145
+ const targetDatabase = options?.databaseName
146
+ ? databases.find((db) => db.name === options.databaseName)
147
+ : databases[0];
148
+ if (!targetDatabase) {
149
+ throw new Error(`syncNeonEnvVars: Database '${options?.databaseName}' not found in branch.`);
150
+ }
151
+ // Step 4: Get the role (user) and password
152
+ const targetRoleName = options?.roleName ?? targetDatabase.owner_name;
153
+ const rolePasswordUrl = `https://console.neon.tech/api/v2/projects/${projectId}/branches/${neonBranchId}/roles/${targetRoleName}/reveal_password`;
154
+ const rolePasswordResponse = await fetch(rolePasswordUrl, {
155
+ headers: {
156
+ Authorization: `Bearer ${neonAccessToken}`,
157
+ },
158
+ });
159
+ if (!rolePasswordResponse.ok) {
160
+ throw new Error(`Failed to fetch Neon role password: ${rolePasswordResponse.status}. Make sure the role '${targetRoleName}' exists and has a password.`);
161
+ }
162
+ const rolePasswordData = await rolePasswordResponse.json();
163
+ const password = rolePasswordData.password;
164
+ if (!password) {
165
+ throw new Error(`syncNeonEnvVars: No password found for role '${targetRoleName}'. The role may not have a password set.`);
166
+ }
167
+ // Step 5: Build new environment variables based on the endpoint host
168
+ const newHost = endpoint.host;
169
+ const poolerHost = newHost.replace(/^([^.]+)\./, "$1-pooler.");
170
+ const envVarMappings = buildNeonEnvVarMappings({
171
+ user: targetRoleName,
172
+ password,
173
+ database: targetDatabase.name,
174
+ host: newHost,
175
+ poolerHost,
176
+ });
177
+ // Build output env vars
178
+ const newEnvVars = [];
179
+ for (const neonEnvVar of outputEnvVars) {
180
+ const prefixedKey = `${envVarPrefix}${neonEnvVar}`;
181
+ if (envVarMappings[neonEnvVar]) {
182
+ newEnvVars.push({
183
+ name: prefixedKey,
184
+ value: envVarMappings[neonEnvVar],
185
+ });
186
+ }
187
+ }
188
+ return newEnvVars;
189
+ }
190
+ catch (error) {
191
+ console.error("Error fetching Neon branch environment variables:", error);
192
+ throw error;
193
+ }
194
+ });
195
+ return {
196
+ name: "SyncNeonEnvVarsExtension",
197
+ async onBuildComplete(context, manifest) {
198
+ await sync.onBuildComplete?.(context, manifest);
199
+ },
200
+ };
201
+ }
202
+ //# sourceMappingURL=neonSyncEnvVars.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"neonSyncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/neonSyncEnvVars.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,10 @@
1
1
  import { BuildExtension } from "@trigger.dev/core/v3/build";
2
2
  export declare function syncVercelEnvVars(options?: {
3
3
  projectId?: string;
4
+ /**
5
+ * Vercel API access token for authentication.
6
+ * It's recommended to use the VERCEL_ACCESS_TOKEN environment variable instead of hardcoding this value.
7
+ */
4
8
  vercelAccessToken?: string;
5
9
  vercelTeamId?: string;
6
10
  branch?: string;
@@ -14,6 +14,7 @@ function syncVercelEnvVars(options) {
14
14
  process.env.VERCEL_PREVIEW_BRANCH ??
15
15
  ctx.env.VERCEL_PREVIEW_BRANCH ??
16
16
  ctx.branch;
17
+ const isVercelEnv = !!(ctx.env.VERCEL);
17
18
  if (!projectId) {
18
19
  throw new Error("syncVercelEnvVars: you did not pass in a projectId or set the VERCEL_PROJECT_ID env var.");
19
20
  }
@@ -48,18 +49,22 @@ function syncVercelEnvVars(options) {
48
49
  const isBranchable = ctx.environment === "preview";
49
50
  const filteredEnvs = data.envs
50
51
  .filter((env) => {
51
- if (!env.value)
52
- return false;
53
52
  if (!env.target.includes(vercelEnvironment))
54
53
  return false;
55
54
  if (isBranchable && env.gitBranch && env.gitBranch !== branch)
56
55
  return false;
56
+ // When running in Vercel, prefer process.env but fall back to API value
57
+ const value = isVercelEnv ? (process.env[env.key] ?? env.value) : env.value;
58
+ if (!value)
59
+ return false;
57
60
  return true;
58
61
  })
59
62
  .map((env) => {
63
+ // When running in Vercel, prefer process.env but fall back to API value
64
+ const value = isVercelEnv ? (process.env[env.key] ?? env.value) : env.value;
60
65
  return {
61
66
  name: env.key,
62
- value: env.value,
67
+ value,
63
68
  isParentEnv: isBranchable && !env.gitBranch,
64
69
  };
65
70
  });
@@ -1 +1 @@
1
- {"version":3,"file":"vercelSyncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/vercelSyncEnvVars.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"vercelSyncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/vercelSyncEnvVars.ts"],"names":[],"mappings":"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"}
@@ -3,4 +3,5 @@ export * from "./core/additionalPackages.js";
3
3
  export * from "./core/syncEnvVars.js";
4
4
  export * from "./core/aptGet.js";
5
5
  export * from "./core/ffmpeg.js";
6
+ export * from "./core/neonSyncEnvVars.js";
6
7
  export * from "./core/vercelSyncEnvVars.js";
@@ -19,5 +19,6 @@ __exportStar(require("./core/additionalPackages.js"), exports);
19
19
  __exportStar(require("./core/syncEnvVars.js"), exports);
20
20
  __exportStar(require("./core/aptGet.js"), exports);
21
21
  __exportStar(require("./core/ffmpeg.js"), exports);
22
+ __exportStar(require("./core/neonSyncEnvVars.js"), exports);
22
23
  __exportStar(require("./core/vercelSyncEnvVars.js"), exports);
23
24
  //# sourceMappingURL=core.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"core.js","sourceRoot":"","sources":["../../../src/extensions/core.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4DAA0C;AAC1C,+DAA6C;AAC7C,wDAAsC;AACtC,mDAAiC;AACjC,mDAAiC;AACjC,8DAA4C"}
1
+ {"version":3,"file":"core.js","sourceRoot":"","sources":["../../../src/extensions/core.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4DAA0C;AAC1C,+DAA6C;AAC7C,wDAAsC;AACtC,mDAAiC;AACjC,mDAAiC;AACjC,4DAA0C;AAC1C,8DAA4C"}
@@ -1,51 +1,192 @@
1
1
  import { BuildManifest, BuildTarget } from "@trigger.dev/core/v3";
2
2
  import { BuildContext, BuildExtension } from "@trigger.dev/core/v3/build";
3
- export type PrismaExtensionOptions = {
4
- schema: string;
5
- migrate?: boolean;
6
- version?: string;
7
- /**
8
- * Adds the `--sql` flag to the `prisma generate` command. This will generate the SQL files for the Prisma schema. Requires the `typedSql preview feature and prisma 5.19.0 or later.
9
- */
10
- typedSql?: boolean;
3
+ export type PrismaLegacyModeExtensionOptions = {
11
4
  /**
12
- * The client generator to use. Set this param to prevent all generators in the prisma schema from being generated.
5
+ * Legacy mode configuration for Prisma 5.x/6.x with the `prisma-client-js` provider.
13
6
  *
14
- * @example
7
+ * **Use this mode when:**
8
+ * - Using Prisma 5.x or 6.x with `prisma-client-js` provider
9
+ * - You want automatic `prisma generate` during deployment
10
+ * - You need migration support
15
11
  *
16
- * ### Prisma schema
12
+ * **Key features:**
13
+ * - Automatic client generation
14
+ * - Multi-file schema support (Prisma 6.7+)
15
+ * - Config file support (`prisma.config.ts`)
16
+ * - TypedSQL support
17
+ * - Automatic version detection
18
+ */
19
+ mode: "legacy";
20
+ /**
21
+ * Path to your Prisma schema file or directory.
17
22
  *
18
- * ```prisma
19
- * generator client {
20
- * provider = "prisma-client-js"
21
- * }
23
+ * **Examples:**
24
+ * - Single file: `"./prisma/schema.prisma"`
25
+ * - Multi-file (Prisma 6.7+): `"./prisma"`
22
26
  *
23
- * generator typegraphql {
24
- * provider = "typegraphql-prisma"
25
- * output = "./generated/type-graphql"
26
- * }
27
- * ```
27
+ * **Note:** Either `schema` or `configFile` must be specified, but not both.
28
+ */
29
+ schema?: string;
30
+ /**
31
+ * Path to your Prisma config file (`prisma.config.ts`).
28
32
  *
29
- * ### PrismaExtension
33
+ * Uses `@prisma/config` to automatically extract schema and migrations paths.
34
+ * Requires Prisma 6+ with config file support.
30
35
  *
36
+ * **Example:**
31
37
  * ```ts
32
38
  * prismaExtension({
33
- * schema: "./prisma/schema.prisma",
34
- * clientGenerator: "client"
39
+ * mode: "legacy",
40
+ * configFile: "./prisma.config.ts",
41
+ * migrate: true,
35
42
  * });
36
43
  * ```
44
+ *
45
+ * **Note:** Either `schema` or `configFile` must be specified, but not both.
46
+ */
47
+ configFile?: string;
48
+ /**
49
+ * Enable automatic database migrations during deployment.
50
+ *
51
+ * Runs `prisma migrate deploy` before generating the client.
52
+ * Requires `directUrlEnvVarName` to be set.
53
+ */
54
+ migrate?: boolean;
55
+ /**
56
+ * Override the auto-detected Prisma version.
57
+ *
58
+ * **Auto-detection:** Checks externals, then `@prisma/client` in node_modules, then `prisma` package.
59
+ */
60
+ version?: string;
61
+ /**
62
+ * Enable TypedSQL support. Adds `--sql` flag to `prisma generate`.
63
+ *
64
+ * Requires Prisma 5.19+ and `previewFeatures = ["typedSql"]` in your schema.
65
+ */
66
+ typedSql?: boolean;
67
+ /**
68
+ * Specify which generator to use when you have multiple generators.
69
+ *
70
+ * Adds `--generator=<name>` to only generate the specified generator.
71
+ * Useful for skipping extra generators like `typegraphql-prisma`.
37
72
  */
38
73
  clientGenerator?: string;
74
+ /**
75
+ * Environment variable name for the direct (unpooled) database connection.
76
+ *
77
+ * Required for migrations. Common values: `"DATABASE_URL_UNPOOLED"`, `"DIRECT_URL"`.
78
+ */
39
79
  directUrlEnvVarName?: string;
40
80
  };
41
- export declare function prismaExtension(options: PrismaExtensionOptions): PrismaExtension;
42
- export declare class PrismaExtension implements BuildExtension {
81
+ export type PrismaEngineOnlyModeExtensionOptions = {
82
+ /**
83
+ * Engine-only mode for custom Prisma client output paths.
84
+ *
85
+ * **Use this mode when:**
86
+ * - You're using a custom output path for Prisma Client
87
+ * - You want to control when `prisma generate` runs
88
+ * - You run `prisma generate` in your build pipeline
89
+ *
90
+ * **What it does:**
91
+ * - Installs engine binaries only (no client generation)
92
+ * - Sets `PRISMA_QUERY_ENGINE_LIBRARY` and `PRISMA_QUERY_ENGINE_SCHEMA_ENGINE` env vars
93
+ * - Auto-detects version from filesystem
94
+ *
95
+ * **You must:** Run `prisma generate` yourself and include correct `binaryTargets` in your schema.
96
+ */
97
+ mode: "engine-only";
98
+ /**
99
+ * Prisma version to use. Auto-detected from `@prisma/client` or `prisma` package if omitted.
100
+ *
101
+ * **Recommended:** Specify explicitly for reproducible builds.
102
+ */
103
+ version?: string;
104
+ /**
105
+ * Binary target platform for Prisma engines.
106
+ *
107
+ * **Default:** `"debian-openssl-3.0.x"` (for Trigger.dev Cloud)
108
+ * **Local Docker on ARM:** `"linux-arm64-openssl-3.0.x"`
109
+ */
110
+ binaryTarget?: string;
111
+ /**
112
+ * Suppress progress messages during the build.
113
+ */
114
+ silent?: boolean;
115
+ };
116
+ export type PrismaEngineModernModeExtensionOptions = {
117
+ /**
118
+ * Modern mode for Prisma 6.16+ (with `prisma-client` provider) and Prisma 7.
119
+ *
120
+ * **Use this mode when:**
121
+ * - Using Prisma 6.16+ with `provider = "prisma-client"` and `engineType = "client"`
122
+ * - Using Prisma 7 beta or later
123
+ * - Using database adapters (e.g., `@prisma/adapter-pg`)
124
+ *
125
+ * **What it does:**
126
+ * - Marks `@prisma/client` as external (zero config)
127
+ * - Works with TypeScript-only client (no Rust binaries)
128
+ *
129
+ * **You must:** Run `prisma generate` yourself and install database adapters.
130
+ */
131
+ mode: "modern";
132
+ };
133
+ export type PrismaExtensionOptions = PrismaLegacyModeExtensionOptions | PrismaEngineOnlyModeExtensionOptions | PrismaEngineModernModeExtensionOptions;
134
+ /**
135
+ * Prisma build extension for Trigger.dev deployments.
136
+ *
137
+ * **Three modes available:**
138
+ * - `"legacy"` - Prisma 5.x/6.x with `prisma-client-js`, automatic generation
139
+ * - `"engine-only"` - Custom output paths, manual generation control
140
+ * - `"modern"` - Prisma 6.16+/7.x with `prisma-client` provider
141
+ *
142
+ * @example Legacy mode (most common)
143
+ * ```ts
144
+ * prismaExtension({
145
+ * mode: "legacy",
146
+ * schema: "prisma/schema.prisma",
147
+ * migrate: true,
148
+ * typedSql: true,
149
+ * });
150
+ * ```
151
+ *
152
+ * @example Engine-only mode (custom output)
153
+ * ```ts
154
+ * prismaExtension({
155
+ * mode: "engine-only",
156
+ * version: "6.19.0",
157
+ * });
158
+ * ```
159
+ *
160
+ * @example Modern mode (Prisma 7)
161
+ * ```ts
162
+ * prismaExtension({
163
+ * mode: "modern",
164
+ * });
165
+ * ```
166
+ */
167
+ export declare function prismaExtension(options: PrismaExtensionOptions): BuildExtension;
168
+ export declare class PrismaLegacyModeExtension implements BuildExtension {
43
169
  private options;
44
170
  moduleExternals: string[];
45
171
  readonly name = "PrismaExtension";
46
172
  private _resolvedSchemaPath?;
47
- constructor(options: PrismaExtensionOptions);
173
+ private _loadedConfig?;
174
+ constructor(options: PrismaLegacyModeExtensionOptions);
48
175
  externalsForTarget(target: BuildTarget): string[];
49
176
  onBuildStart(context: BuildContext): Promise<void>;
50
177
  onBuildComplete(context: BuildContext, manifest: BuildManifest): Promise<void>;
51
178
  }
179
+ export declare class PrismaEngineOnlyModeExtension implements BuildExtension {
180
+ private options;
181
+ readonly name = "PrismaEngineOnlyModeExtension";
182
+ private _binaryTarget;
183
+ constructor(options: PrismaEngineOnlyModeExtensionOptions);
184
+ onBuildComplete(context: BuildContext, manifest: BuildManifest): Promise<void>;
185
+ }
186
+ export declare class PrismaEngineModernModeExtension implements BuildExtension {
187
+ private options;
188
+ moduleExternals: string[];
189
+ readonly name = "PrismaEngineModernModeExtension";
190
+ constructor(options: PrismaEngineModernModeExtensionOptions);
191
+ externalsForTarget(target: BuildTarget): string[];
192
+ }