@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.
- package/dist/commonjs/extensions/core/neonSyncEnvVars.d.ts +14 -0
- package/dist/commonjs/extensions/core/neonSyncEnvVars.js +202 -0
- package/dist/commonjs/extensions/core/neonSyncEnvVars.js.map +1 -0
- package/dist/commonjs/extensions/core/vercelSyncEnvVars.d.ts +4 -0
- package/dist/commonjs/extensions/core/vercelSyncEnvVars.js +8 -3
- package/dist/commonjs/extensions/core/vercelSyncEnvVars.js.map +1 -1
- package/dist/commonjs/extensions/core.d.ts +1 -0
- package/dist/commonjs/extensions/core.js +1 -0
- package/dist/commonjs/extensions/core.js.map +1 -1
- package/dist/commonjs/extensions/prisma.d.ts +167 -26
- package/dist/commonjs/extensions/prisma.js +425 -26
- package/dist/commonjs/extensions/prisma.js.map +1 -1
- package/dist/commonjs/imports/mlly-cjs.cjs.map +1 -0
- package/dist/commonjs/imports/mlly.d.ts +1 -0
- package/dist/commonjs/imports/mlly.js +7 -0
- package/dist/commonjs/version.js +1 -1
- package/dist/esm/extensions/core/neonSyncEnvVars.d.ts +14 -0
- package/dist/esm/extensions/core/neonSyncEnvVars.js +198 -0
- package/dist/esm/extensions/core/neonSyncEnvVars.js.map +1 -0
- package/dist/esm/extensions/core/vercelSyncEnvVars.d.ts +4 -0
- package/dist/esm/extensions/core/vercelSyncEnvVars.js +8 -3
- package/dist/esm/extensions/core/vercelSyncEnvVars.js.map +1 -1
- package/dist/esm/extensions/core.d.ts +1 -0
- package/dist/esm/extensions/core.js +1 -0
- package/dist/esm/extensions/core.js.map +1 -1
- package/dist/esm/extensions/prisma.d.ts +167 -26
- package/dist/esm/extensions/prisma.js +423 -26
- package/dist/esm/extensions/prisma.js.map +1 -1
- package/dist/esm/imports/mlly.d.ts +2 -0
- package/dist/esm/imports/mlly.js +5 -0
- package/dist/esm/imports/mlly.js.map +1 -0
- package/dist/esm/version.js +1 -1
- 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":";;;AA0EA,0CA+NC;AAxSD,wCAAyC;AA0BzC,wDAAwD;AAC3C,QAAA,aAAa,GAAG;IAC3B,QAAQ;IACR,qBAAqB;IACrB,eAAe;IACf,cAAc;IACd,qBAAqB;IACrB,uBAAuB;IACvB,0BAA0B;IAC1B,QAAQ;IACR,eAAe;IACf,cAAc;IACd,mBAAmB;IACnB,mBAAmB;IACnB,YAAY;IACZ,YAAY;IACZ,iBAAiB;CAClB,CAAC;AAEF,SAAS,uBAAuB,CAAC,OAMhC;IACC,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAE/D,OAAO;QACL,MAAM,EAAE,IAAI;QACZ,UAAU,EAAE,QAAQ;QACpB,UAAU,EAAE,QAAQ;QACpB,MAAM,EAAE,UAAU;QAClB,eAAe,EAAE,IAAI;QACrB,aAAa,EAAE,IAAI;QACnB,iBAAiB,EAAE,QAAQ;QAC3B,iBAAiB,EAAE,QAAQ;QAC3B,aAAa,EAAE,UAAU;QACzB,YAAY,EAAE,gBAAgB,kBAAkB,CAAC,IAAI,CAAC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,UAAU,IAAI,QAAQ,kBAAkB;QAClI,qBAAqB,EAAE,gBAAgB,kBAAkB,CAAC,IAAI,CAAC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,IAAI,IAAI,QAAQ,kBAAkB;QACrI,YAAY,EAAE,gBAAgB,kBAAkB,CAAC,IAAI,CAAC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,UAAU,IAAI,QAAQ,kBAAkB;QAClI,mBAAmB,EAAE,gBAAgB,kBAAkB,CAAC,IAAI,CAAC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,UAAU,IAAI,QAAQ,EAAE;QACzH,wBAAwB,EAAE,gBAAgB,kBAAkB,CAAC,IAAI,CAAC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,IAAI,IAAI,QAAQ,kBAAkB;QACxI,mBAAmB,EAAE,gBAAgB,kBAAkB,CAAC,IAAI,CAAC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,UAAU,IAAI,QAAQ,oDAAoD;KAC5K,CAAC;AACJ,CAAC;AAED,SAAgB,eAAe,CAAC,OAW/B;IACC,MAAM,IAAI,GAAG,IAAA,qBAAW,EAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QACrC,MAAM,SAAS,GACb,OAAO,EAAE,SAAS,IAAI,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,GAAG,CAAC,GAAG,CAAC,eAAe,CAAC;QAC/E,MAAM,eAAe,GACnB,OAAO,EAAE,eAAe,IAAI,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,GAAG,CAAC,GAAG,CAAC,iBAAiB,CAAC;QACzF,MAAM,MAAM,GAAG,OAAO,EAAE,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC;QAC7C,MAAM,YAAY,GAAG,OAAO,EAAE,YAAY,IAAI,EAAE,CAAC;QACjD,MAAM,aAAa,GAAG,qBAAa,CAAC;QAEpC,iDAAiD;QACjD,IAAI,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC;YACnB,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CACb,sFAAsF,CACvF,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,eAAe,EAAE,CAAC;YACrB,MAAM,IAAI,KAAK,CACb,+FAA+F,CAChG,CAAC;QACJ,CAAC;QAED,wDAAwD;QACxD,IAAI,GAAG,CAAC,WAAW,KAAK,MAAM,EAAE,CAAC;YAC/B,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CACb,wFAAwF,CACzF,CAAC;QACJ,CAAC;QAED,MAAM,cAAc,GAAG;YACrB,IAAI,EAAE,YAAY;YAClB,OAAO,EAAE,SAAS;YAClB,GAAG,EAAE,aAAa;YAClB,OAAO,EAAE,SAAS;SACV,CAAC;QAEX,MAAM,WAAW,GAAG,cAAc,CAAC,GAAG,CAAC,WAA0C,CAAC,CAAC;QAEnF,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CACb,wBAAwB,GAAG,CAAC,WAAW,qDAAqD,CAC7F,CAAC;QACJ,CAAC;QAED,IAAI,WAAW,KAAK,aAAa,EAAE,CAAC;YAClC,2CAA2C;YAC3C,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,CAAC;YACH,wCAAwC;YACxC,MAAM,kBAAkB,GAAG,IAAI,eAAe,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;YACnE,MAAM,WAAW,GAAG,6CAA6C,SAAS,aAAa,kBAAkB,EAAE,CAAC;YAC5G,MAAM,gBAAgB,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE;gBAChD,OAAO,EAAE;oBACP,aAAa,EAAE,UAAU,eAAe,EAAE;iBAC3C;aACF,CAAC,CAAC;YAEH,IAAI,CAAC,gBAAgB,CAAC,EAAE,EAAE,CAAC;gBACzB,MAAM,IAAI,KAAK,CAAC,kCAAkC,gBAAgB,CAAC,MAAM,EAAE,CAAC,CAAC;YAC/E,CAAC;YAED,MAAM,YAAY,GAAG,MAAM,gBAAgB,CAAC,IAAI,EAAE,CAAC;YACnD,MAAM,QAAQ,GAAiB,YAAY,CAAC,QAAQ,IAAI,EAAE,CAAC;YAE3D,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC1B,2BAA2B;gBAC3B,OAAO,EAAE,CAAC;YACZ,CAAC;YAED,gFAAgF;YAChF,MAAM,kBAAkB,GAAG,GAAG,WAAW,IAAI,MAAM,EAAE,CAAC;YACtD,MAAM,cAAc,GAAG,QAAQ,CAAC,IAAI,CAClC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,kBAAkB,IAAI,CAAC,CAAC,IAAI,KAAK,MAAM,CAC1D,CAAC;YAEF,IAAI,CAAC,cAAc,EAAE,CAAC;gBACpB,uBAAuB;gBACvB,OAAO,EAAE,CAAC;YACZ,CAAC;YAED,MAAM,YAAY,GAAG,cAAc,CAAC,EAAE,CAAC;YAEvC,uCAAuC;YACvC,MAAM,YAAY,GAAG,6CAA6C,SAAS,aAAa,YAAY,YAAY,CAAC;YACjH,MAAM,iBAAiB,GAAG,MAAM,KAAK,CAAC,YAAY,EAAE;gBAClD,OAAO,EAAE;oBACP,aAAa,EAAE,UAAU,eAAe,EAAE;iBAC3C;aACF,CAAC,CAAC;YAEH,IAAI,CAAC,iBAAiB,CAAC,EAAE,EAAE,CAAC;gBAC1B,MAAM,IAAI,KAAK,CAAC,0CAA0C,iBAAiB,CAAC,MAAM,EAAE,CAAC,CAAC;YACxF,CAAC;YAED,MAAM,aAAa,GAAG,MAAM,iBAAiB,CAAC,IAAI,EAAE,CAAC;YACrD,MAAM,SAAS,GAAmB,aAAa,CAAC,SAAS,IAAI,EAAE,CAAC;YAEhE,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC3B,OAAO,EAAE,CAAC;YACZ,CAAC;YAED,uEAAuE;YACvE,MAAM,aAAa,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;YACxE,MAAM,QAAQ,GAAG,aAAa,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC;YAE/C,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,OAAO,EAAE,CAAC;YACZ,CAAC;YAED,uCAAuC;YACvC,MAAM,YAAY,GAAG,6CAA6C,SAAS,aAAa,YAAY,YAAY,CAAC;YACjH,MAAM,iBAAiB,GAAG,MAAM,KAAK,CAAC,YAAY,EAAE;gBAClD,OAAO,EAAE;oBACP,aAAa,EAAE,UAAU,eAAe,EAAE;iBAC3C;aACF,CAAC,CAAC;YAEH,IAAI,CAAC,iBAAiB,CAAC,EAAE,EAAE,CAAC;gBAC1B,MAAM,IAAI,KAAK,CAAC,0CAA0C,iBAAiB,CAAC,MAAM,EAAE,CAAC,CAAC;YACxF,CAAC;YAED,MAAM,aAAa,GAAG,MAAM,iBAAiB,CAAC,IAAI,EAAE,CAAC;YACrD,MAAM,SAAS,GAAmB,aAAa,CAAC,SAAS,IAAI,EAAE,CAAC;YAEhE,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC3B,OAAO,EAAE,CAAC;YACZ,CAAC;YAED,mDAAmD;YACnD,MAAM,cAAc,GAAG,OAAO,EAAE,YAAY;gBAC1C,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,KAAK,OAAO,CAAC,YAAY,CAAC;gBAC1D,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAEjB,IAAI,CAAC,cAAc,EAAE,CAAC;gBACpB,MAAM,IAAI,KAAK,CACb,8BAA8B,OAAO,EAAE,YAAY,wBAAwB,CAC5E,CAAC;YACJ,CAAC;YAED,2CAA2C;YAC3C,MAAM,cAAc,GAAG,OAAO,EAAE,QAAQ,IAAI,cAAc,CAAC,UAAU,CAAC;YACtE,MAAM,eAAe,GAAG,6CAA6C,SAAS,aAAa,YAAY,UAAU,cAAc,kBAAkB,CAAC;YAClJ,MAAM,oBAAoB,GAAG,MAAM,KAAK,CAAC,eAAe,EAAE;gBACxD,OAAO,EAAE;oBACP,aAAa,EAAE,UAAU,eAAe,EAAE;iBAC3C;aACF,CAAC,CAAC;YAEH,IAAI,CAAC,oBAAoB,CAAC,EAAE,EAAE,CAAC;gBAC7B,MAAM,IAAI,KAAK,CACb,uCAAuC,oBAAoB,CAAC,MAAM,yBAAyB,cAAc,8BAA8B,CACxI,CAAC;YACJ,CAAC;YAED,MAAM,gBAAgB,GAAa,MAAM,oBAAoB,CAAC,IAAI,EAAE,CAAC;YACrE,MAAM,QAAQ,GAAG,gBAAgB,CAAC,QAAQ,CAAC;YAE3C,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,MAAM,IAAI,KAAK,CACb,gDAAgD,cAAc,0CAA0C,CACzG,CAAC;YACJ,CAAC;YAED,qEAAqE;YACrE,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC;YAC9B,MAAM,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;YAE/D,MAAM,cAAc,GAAG,uBAAuB,CAAC;gBAC7C,IAAI,EAAE,cAAc;gBACpB,QAAQ;gBACR,QAAQ,EAAE,cAAc,CAAC,IAAI;gBAC7B,IAAI,EAAE,OAAO;gBACb,UAAU;aACX,CAAC,CAAC;YAEH,wBAAwB;YACxB,MAAM,UAAU,GAAa,EAAE,CAAC;YAEhC,KAAK,MAAM,UAAU,IAAI,aAAa,EAAE,CAAC;gBACvC,MAAM,WAAW,GAAG,GAAG,YAAY,GAAG,UAAU,EAAE,CAAC;gBACnD,IAAI,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC;oBAC/B,UAAU,CAAC,IAAI,CAAC;wBACd,IAAI,EAAE,WAAW;wBACjB,KAAK,EAAE,cAAc,CAAC,UAAU,CAAC;qBAClC,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YAED,OAAO,UAAU,CAAC;QACpB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,mDAAmD,EAAE,KAAK,CAAC,CAAC;YAC1E,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO;QACL,IAAI,EAAE,0BAA0B;QAChC,KAAK,CAAC,eAAe,CAAC,OAAO,EAAE,QAAQ;YACrC,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAClD,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -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
|
|
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":";;AAaA,
|
|
1
|
+
{"version":3,"file":"vercelSyncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/vercelSyncEnvVars.ts"],"names":[],"mappings":"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"}
|
|
@@ -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
|
|
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
|
-
*
|
|
5
|
+
* Legacy mode configuration for Prisma 5.x/6.x with the `prisma-client-js` provider.
|
|
13
6
|
*
|
|
14
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
19
|
-
*
|
|
20
|
-
*
|
|
21
|
-
* }
|
|
23
|
+
* **Examples:**
|
|
24
|
+
* - Single file: `"./prisma/schema.prisma"`
|
|
25
|
+
* - Multi-file (Prisma 6.7+): `"./prisma"`
|
|
22
26
|
*
|
|
23
|
-
*
|
|
24
|
-
|
|
25
|
-
|
|
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
|
-
*
|
|
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
|
-
*
|
|
34
|
-
*
|
|
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
|
|
42
|
-
|
|
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
|
-
|
|
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
|
+
}
|