@trigger.dev/build 0.0.0-v3-prerelease-20250108142426 → 0.0.0-v4-prerelease-20250917185130
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 +2 -2
- package/dist/commonjs/extensions/audioWaveform.js +1 -1
- package/dist/commonjs/extensions/audioWaveform.js.map +1 -1
- package/dist/commonjs/extensions/core/additionalFiles.js +2 -53
- package/dist/commonjs/extensions/core/additionalFiles.js.map +1 -1
- package/dist/commonjs/extensions/core/ffmpeg.d.ts +12 -1
- package/dist/commonjs/extensions/core/ffmpeg.js +34 -2
- package/dist/commonjs/extensions/core/ffmpeg.js.map +1 -1
- package/dist/commonjs/extensions/core/syncEnvVars.d.ts +2 -0
- package/dist/commonjs/extensions/core/syncEnvVars.js +33 -17
- package/dist/commonjs/extensions/core/syncEnvVars.js.map +1 -1
- package/dist/commonjs/extensions/core/vercelSyncEnvVars.d.ts +1 -0
- package/dist/commonjs/extensions/core/vercelSyncEnvVars.js +27 -11
- package/dist/commonjs/extensions/core/vercelSyncEnvVars.js.map +1 -1
- package/dist/commonjs/extensions/lightpanda.d.ts +7 -0
- package/dist/commonjs/extensions/lightpanda.js +30 -0
- package/dist/commonjs/extensions/lightpanda.js.map +1 -0
- package/dist/commonjs/extensions/playwright.d.ts +55 -0
- package/dist/commonjs/extensions/playwright.js +308 -0
- package/dist/commonjs/extensions/playwright.js.map +1 -0
- package/dist/commonjs/internal/additionalFiles.d.ts +6 -0
- package/dist/commonjs/internal/additionalFiles.js +63 -0
- package/dist/commonjs/internal/additionalFiles.js.map +1 -0
- package/dist/commonjs/internal.d.ts +1 -0
- package/dist/commonjs/internal.js +18 -0
- package/dist/commonjs/internal.js.map +1 -0
- package/dist/commonjs/version.js +1 -1
- package/dist/esm/extensions/audioWaveform.js +1 -1
- package/dist/esm/extensions/audioWaveform.js.map +1 -1
- package/dist/esm/extensions/core/additionalFiles.js +2 -53
- package/dist/esm/extensions/core/additionalFiles.js.map +1 -1
- package/dist/esm/extensions/core/ffmpeg.d.ts +12 -1
- package/dist/esm/extensions/core/ffmpeg.js +34 -2
- package/dist/esm/extensions/core/ffmpeg.js.map +1 -1
- package/dist/esm/extensions/core/syncEnvVars.d.ts +2 -0
- package/dist/esm/extensions/core/syncEnvVars.js +33 -17
- package/dist/esm/extensions/core/syncEnvVars.js.map +1 -1
- package/dist/esm/extensions/core/vercelSyncEnvVars.d.ts +1 -0
- package/dist/esm/extensions/core/vercelSyncEnvVars.js +27 -11
- package/dist/esm/extensions/core/vercelSyncEnvVars.js.map +1 -1
- package/dist/esm/extensions/lightpanda.d.ts +7 -0
- package/dist/esm/extensions/lightpanda.js +26 -0
- package/dist/esm/extensions/lightpanda.js.map +1 -0
- package/dist/esm/extensions/playwright.d.ts +55 -0
- package/dist/esm/extensions/playwright.js +305 -0
- package/dist/esm/extensions/playwright.js.map +1 -0
- package/dist/esm/internal/additionalFiles.d.ts +6 -0
- package/dist/esm/internal/additionalFiles.js +60 -0
- package/dist/esm/internal/additionalFiles.js.map +1 -0
- package/dist/esm/internal.d.ts +1 -0
- package/dist/esm/internal.js +2 -0
- package/dist/esm/internal.js.map +1 -0
- package/dist/esm/version.js +1 -1
- package/package.json +49 -6
package/README.md
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
# Official
|
|
1
|
+
# Official Build Package of Trigger.dev
|
|
2
2
|
|
|
3
|
-
View the full documentation
|
|
3
|
+
View the full documentation [here](https://trigger.dev/docs)
|
|
@@ -4,7 +4,7 @@ exports.audioWaveform = audioWaveform;
|
|
|
4
4
|
const AUDIOWAVEFORM_VERSION = "1.10.1";
|
|
5
5
|
const AUDIOWAVEFORM_CHECKSUM = "sha256:00b41ea4d6e7a5b4affcfe4ac99951ec89da81a8cba40af19e9b98c3a8f9b4b8";
|
|
6
6
|
function audioWaveform(options = {}) {
|
|
7
|
-
return new AudioWaveformExtension();
|
|
7
|
+
return new AudioWaveformExtension(options);
|
|
8
8
|
}
|
|
9
9
|
class AudioWaveformExtension {
|
|
10
10
|
options;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"audioWaveform.js","sourceRoot":"","sources":["../../../src/extensions/audioWaveform.ts"],"names":[],"mappings":";;AAYA,sCAEC;AAND,MAAM,qBAAqB,GAAG,QAAQ,CAAC;AACvC,MAAM,sBAAsB,GAC1B,yEAAyE,CAAC;AAE5E,SAAgB,aAAa,CAAC,UAAgC,EAAE;IAC9D,OAAO,IAAI,sBAAsB,
|
|
1
|
+
{"version":3,"file":"audioWaveform.js","sourceRoot":"","sources":["../../../src/extensions/audioWaveform.ts"],"names":[],"mappings":";;AAYA,sCAEC;AAND,MAAM,qBAAqB,GAAG,QAAQ,CAAC;AACvC,MAAM,sBAAsB,GAC1B,yEAAyE,CAAC;AAE5E,SAAgB,aAAa,CAAC,UAAgC,EAAE;IAC9D,OAAO,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAC;AAC7C,CAAC;AAED,MAAM,sBAAsB;IAGN;IAFJ,IAAI,GAAG,wBAAwB,CAAC;IAEhD,YAAoB,UAAgC,EAAE;QAAlC,YAAO,GAAP,OAAO,CAA2B;IAAG,CAAC;IAE1D,KAAK,CAAC,eAAe,CAAC,OAAqB,EAAE,QAAuB;QAClE,IAAI,OAAO,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO;YAC/B,CAAC,CAAC;gBACE,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;gBAC7B,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;aAChC;YACH,CAAC,CAAC;gBACE,OAAO,EAAE,qBAAqB;gBAC9B,QAAQ,EAAE,sBAAsB;aACjC,CAAC;QAEN,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,mCAAmC,EAAE;YACxD,GAAG,IAAI;SACR,CAAC,CAAC;QAEH,MAAM,YAAY,GAAG;YACnB,OACE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,cAAc,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAClD,2DAA2D,IAAI,CAAC,OAAO,kBACrE,IAAI,CAAC,OACP,mBAAmB;YACnB,6BAA6B,IAAI,CAAC,OAAO,yBAAyB;YAClE,2BAA2B;YAC3B,qCAAqC;SACtC,CAAC;QAEF,OAAO,CAAC,QAAQ,CAAC;YACf,EAAE,EAAE,eAAe;YACnB,KAAK,EAAE;gBACL,IAAI,EAAE,CAAC,KAAK,CAAC;gBACb,YAAY;aACb;SACF,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -1,64 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.additionalFiles = additionalFiles;
|
|
4
|
-
const
|
|
5
|
-
const tinyglobby_1 = require("tinyglobby");
|
|
6
|
-
const promises_1 = require("node:fs/promises");
|
|
4
|
+
const additionalFiles_js_1 = require("../../internal/additionalFiles.js");
|
|
7
5
|
function additionalFiles(options) {
|
|
8
6
|
return {
|
|
9
7
|
name: "additionalFiles",
|
|
10
8
|
async onBuildComplete(context, manifest) {
|
|
11
|
-
|
|
12
|
-
const staticAssets = await findStaticAssetFiles(options.files ?? [], manifest.outputPath, {
|
|
13
|
-
cwd: context.workingDir,
|
|
14
|
-
});
|
|
15
|
-
for (const { assets, matcher } of staticAssets) {
|
|
16
|
-
if (assets.length === 0) {
|
|
17
|
-
console.warn("No files found for matcher", matcher);
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
await copyStaticAssets(staticAssets);
|
|
9
|
+
await (0, additionalFiles_js_1.addAdditionalFilesToBuild)("additionalFiles", options, context, manifest);
|
|
21
10
|
},
|
|
22
11
|
};
|
|
23
12
|
}
|
|
24
|
-
async function findStaticAssetFiles(matchers, destinationPath, options) {
|
|
25
|
-
const result = [];
|
|
26
|
-
for (const matcher of matchers) {
|
|
27
|
-
const assets = await findStaticAssetsForMatcher(matcher, destinationPath, options);
|
|
28
|
-
result.push({ matcher, assets });
|
|
29
|
-
}
|
|
30
|
-
return result;
|
|
31
|
-
}
|
|
32
|
-
async function findStaticAssetsForMatcher(matcher, destinationPath, options) {
|
|
33
|
-
const result = [];
|
|
34
|
-
const files = await (0, tinyglobby_1.glob)({
|
|
35
|
-
patterns: [matcher],
|
|
36
|
-
cwd: options?.cwd,
|
|
37
|
-
ignore: options?.ignore ?? [],
|
|
38
|
-
onlyFiles: true,
|
|
39
|
-
absolute: true,
|
|
40
|
-
});
|
|
41
|
-
let matches = 0;
|
|
42
|
-
for (const file of files) {
|
|
43
|
-
matches++;
|
|
44
|
-
const pathInsideDestinationDir = (0, node_path_1.relative)(options?.cwd ?? process.cwd(), file)
|
|
45
|
-
.split(node_path_1.posix.sep)
|
|
46
|
-
.filter((p) => p !== "..")
|
|
47
|
-
.join(node_path_1.posix.sep);
|
|
48
|
-
const relativeDestinationPath = (0, node_path_1.join)(destinationPath, pathInsideDestinationDir);
|
|
49
|
-
result.push({
|
|
50
|
-
source: file,
|
|
51
|
-
destination: relativeDestinationPath,
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
return result;
|
|
55
|
-
}
|
|
56
|
-
async function copyStaticAssets(staticAssetFiles) {
|
|
57
|
-
for (const { assets } of staticAssetFiles) {
|
|
58
|
-
for (const { source, destination } of assets) {
|
|
59
|
-
await (0, promises_1.mkdir)((0, node_path_1.dirname)(destination), { recursive: true });
|
|
60
|
-
await (0, promises_1.copyFile)(source, destination);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
13
|
//# sourceMappingURL=additionalFiles.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"additionalFiles.js","sourceRoot":"","sources":["../../../../src/extensions/core/additionalFiles.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"additionalFiles.js","sourceRoot":"","sources":["../../../../src/extensions/core/additionalFiles.ts"],"names":[],"mappings":";;AAOA,0CAOC;AAbD,0EAA8E;AAM9E,SAAgB,eAAe,CAAC,OAA+B;IAC7D,OAAO;QACL,IAAI,EAAE,iBAAiB;QACvB,KAAK,CAAC,eAAe,CAAC,OAAO,EAAE,QAAQ;YACrC,MAAM,IAAA,8CAAyB,EAAC,iBAAiB,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;QACjF,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -1,10 +1,21 @@
|
|
|
1
1
|
import { BuildExtension } from "@trigger.dev/core/v3/build";
|
|
2
2
|
export type FfmpegOptions = {
|
|
3
|
+
/**
|
|
4
|
+
* The version of ffmpeg to install. If not provided, the latest version from apt will be installed.
|
|
5
|
+
* If set to '7' or starts with '7.', a static build of ffmpeg 7.x from johnvansickle.com will be used instead of apt.
|
|
6
|
+
* @example
|
|
7
|
+
* ffmpeg() // Installs latest ffmpeg from apt
|
|
8
|
+
* ffmpeg({ version: '7' }) // Installs static build of ffmpeg 7.x
|
|
9
|
+
* ffmpeg({ version: '7.0.1' }) // Installs static build of ffmpeg 7.x
|
|
10
|
+
* ffmpeg({ version: '6' }) // Version ignored, installs latest ffmpeg from apt
|
|
11
|
+
* ffmpeg({ version: '8' }) // Version ignored, installs latest ffmpeg from apt
|
|
12
|
+
*/
|
|
3
13
|
version?: string;
|
|
4
14
|
};
|
|
5
15
|
/**
|
|
6
16
|
* Add ffmpeg to the build, and automatically set the FFMPEG_PATH and FFPROBE_PATH environment variables.
|
|
7
|
-
* @param options.version The version of ffmpeg to install. If not provided, the latest version will be installed.
|
|
17
|
+
* @param options.version The version of ffmpeg to install. If not provided, the latest version from apt will be installed.
|
|
18
|
+
* If set to '7' or starts with '7.', a static build of ffmpeg 7.x from johnvansickle.com will be used instead of apt.
|
|
8
19
|
*
|
|
9
20
|
* @returns The build extension.
|
|
10
21
|
*/
|
|
@@ -3,7 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.ffmpeg = ffmpeg;
|
|
4
4
|
/**
|
|
5
5
|
* Add ffmpeg to the build, and automatically set the FFMPEG_PATH and FFPROBE_PATH environment variables.
|
|
6
|
-
* @param options.version The version of ffmpeg to install. If not provided, the latest version will be installed.
|
|
6
|
+
* @param options.version The version of ffmpeg to install. If not provided, the latest version from apt will be installed.
|
|
7
|
+
* If set to '7' or starts with '7.', a static build of ffmpeg 7.x from johnvansickle.com will be used instead of apt.
|
|
7
8
|
*
|
|
8
9
|
* @returns The build extension.
|
|
9
10
|
*/
|
|
@@ -17,10 +18,41 @@ function ffmpeg(options = {}) {
|
|
|
17
18
|
context.logger.debug("Adding ffmpeg", {
|
|
18
19
|
options,
|
|
19
20
|
});
|
|
21
|
+
// Use static build for version 7 or 7.x
|
|
22
|
+
if (options.version === "7" || options.version?.startsWith("7.")) {
|
|
23
|
+
context.addLayer({
|
|
24
|
+
id: "ffmpeg",
|
|
25
|
+
image: {
|
|
26
|
+
instructions: [
|
|
27
|
+
// Install ffmpeg after checksum validation
|
|
28
|
+
"RUN apt-get update && apt-get install -y --no-install-recommends wget xz-utils nscd ca-certificates && apt-get clean && rm -rf /var/lib/apt/lists/* && " +
|
|
29
|
+
"wget https://johnvansickle.com/ffmpeg/builds/ffmpeg-git-amd64-static.tar.xz.md5 && " +
|
|
30
|
+
"wget https://johnvansickle.com/ffmpeg/builds/ffmpeg-git-amd64-static.tar.xz && " +
|
|
31
|
+
"md5sum -c ffmpeg-git-amd64-static.tar.xz.md5 && " +
|
|
32
|
+
"tar xvf ffmpeg-git-amd64-static.tar.xz -C /usr/bin --strip-components=1 --no-anchored 'ffmpeg' 'ffprobe' && " +
|
|
33
|
+
"rm ffmpeg-git-amd64-static.tar.xz*",
|
|
34
|
+
],
|
|
35
|
+
},
|
|
36
|
+
deploy: {
|
|
37
|
+
env: {
|
|
38
|
+
FFMPEG_PATH: "/usr/bin/ffmpeg",
|
|
39
|
+
FFPROBE_PATH: "/usr/bin/ffprobe",
|
|
40
|
+
},
|
|
41
|
+
override: true,
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
else if (options.version) {
|
|
47
|
+
context.logger.warn("Custom ffmpeg version not supported, ignoring", {
|
|
48
|
+
version: options.version,
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
// Default: use apt
|
|
20
52
|
context.addLayer({
|
|
21
53
|
id: "ffmpeg",
|
|
22
54
|
image: {
|
|
23
|
-
pkgs:
|
|
55
|
+
pkgs: ["ffmpeg"],
|
|
24
56
|
},
|
|
25
57
|
deploy: {
|
|
26
58
|
env: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ffmpeg.js","sourceRoot":"","sources":["../../../../src/extensions/core/ffmpeg.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"ffmpeg.js","sourceRoot":"","sources":["../../../../src/extensions/core/ffmpeg.ts"],"names":[],"mappings":";;AAuBA,wBA0DC;AAjED;;;;;;GAMG;AACH,SAAgB,MAAM,CAAC,UAAyB,EAAE;IAChD,OAAO;QACL,IAAI,EAAE,QAAQ;QACd,eAAe,CAAC,OAAO;YACrB,IAAI,OAAO,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC;gBAC7B,OAAO;YACT,CAAC;YAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,eAAe,EAAE;gBACpC,OAAO;aACR,CAAC,CAAC;YAEH,wCAAwC;YACxC,IAAI,OAAO,CAAC,OAAO,KAAK,GAAG,IAAI,OAAO,CAAC,OAAO,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;gBACjE,OAAO,CAAC,QAAQ,CAAC;oBACf,EAAE,EAAE,QAAQ;oBACZ,KAAK,EAAE;wBACL,YAAY,EAAE;4BACZ,2CAA2C;4BAC3C,yJAAyJ;gCACvJ,qFAAqF;gCACrF,iFAAiF;gCACjF,kDAAkD;gCAClD,8GAA8G;gCAC9G,oCAAoC;yBACvC;qBACF;oBACD,MAAM,EAAE;wBACN,GAAG,EAAE;4BACH,WAAW,EAAE,iBAAiB;4BAC9B,YAAY,EAAE,kBAAkB;yBACjC;wBACD,QAAQ,EAAE,IAAI;qBACf;iBACF,CAAC,CAAC;gBACH,OAAO;YACT,CAAC;iBAAM,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;gBAC3B,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,+CAA+C,EAAE;oBACnE,OAAO,EAAE,OAAO,CAAC,OAAO;iBACzB,CAAC,CAAC;YACL,CAAC;YAED,mBAAmB;YACnB,OAAO,CAAC,QAAQ,CAAC;gBACf,EAAE,EAAE,QAAQ;gBACZ,KAAK,EAAE;oBACL,IAAI,EAAE,CAAC,QAAQ,CAAC;iBACjB;gBACD,MAAM,EAAE;oBACN,GAAG,EAAE;wBACH,WAAW,EAAE,iBAAiB;wBAC9B,YAAY,EAAE,kBAAkB;qBACjC;oBACD,QAAQ,EAAE,IAAI;iBACf;aACF,CAAC,CAAC;QACL,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -2,11 +2,13 @@ import { BuildExtension } from "@trigger.dev/core/v3/build";
|
|
|
2
2
|
export type SyncEnvVarsBody = Record<string, string> | Array<{
|
|
3
3
|
name: string;
|
|
4
4
|
value: string;
|
|
5
|
+
isParentEnv?: boolean;
|
|
5
6
|
}>;
|
|
6
7
|
export type SyncEnvVarsResult = SyncEnvVarsBody | Promise<void | undefined | SyncEnvVarsBody> | void | undefined;
|
|
7
8
|
export type SyncEnvVarsParams = {
|
|
8
9
|
projectRef: string;
|
|
9
10
|
environment: string;
|
|
11
|
+
branch?: string;
|
|
10
12
|
env: Record<string, string>;
|
|
11
13
|
};
|
|
12
14
|
export type SyncEnvVarsFunction = (params: SyncEnvVarsParams) => SyncEnvVarsResult;
|
|
@@ -58,23 +58,14 @@ function syncEnvVars(fn, options) {
|
|
|
58
58
|
return;
|
|
59
59
|
}
|
|
60
60
|
const $spinner = context.logger.spinner("Invoking syncEnvVars callback");
|
|
61
|
-
const result = await callSyncEnvVarsFn(fn, manifest.deploy.env ?? {}, manifest.environment, context);
|
|
61
|
+
const result = await callSyncEnvVarsFn(fn, manifest.deploy.env ?? {}, manifest.environment, manifest.branch, context);
|
|
62
62
|
if (!result) {
|
|
63
63
|
$spinner.stop("No env vars detected");
|
|
64
64
|
return;
|
|
65
65
|
}
|
|
66
|
-
const env =
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
}
|
|
70
|
-
// Strip out any TRIGGER_ prefix env vars
|
|
71
|
-
if (UNSYNCABLE_ENV_VARS_PREFIXES.some((prefix) => key.startsWith(prefix))) {
|
|
72
|
-
return acc;
|
|
73
|
-
}
|
|
74
|
-
acc[key] = value;
|
|
75
|
-
return acc;
|
|
76
|
-
}, {});
|
|
77
|
-
const numberOfEnvVars = Object.keys(env).length;
|
|
66
|
+
const env = stripUnsyncableEnvVars(result.env);
|
|
67
|
+
const parentEnv = result.parentEnv ? stripUnsyncableEnvVars(result.parentEnv) : undefined;
|
|
68
|
+
const numberOfEnvVars = Object.keys(env).length + (parentEnv ? Object.keys(parentEnv).length : 0);
|
|
78
69
|
if (numberOfEnvVars === 0) {
|
|
79
70
|
$spinner.stop("No env vars detected");
|
|
80
71
|
return;
|
|
@@ -89,21 +80,38 @@ function syncEnvVars(fn, options) {
|
|
|
89
80
|
id: "sync-env-vars",
|
|
90
81
|
deploy: {
|
|
91
82
|
env,
|
|
83
|
+
parentEnv,
|
|
92
84
|
override: options?.override ?? true,
|
|
93
85
|
},
|
|
94
86
|
});
|
|
95
87
|
},
|
|
96
88
|
};
|
|
97
89
|
}
|
|
98
|
-
|
|
90
|
+
function stripUnsyncableEnvVars(env) {
|
|
91
|
+
return Object.entries(env).reduce((acc, [key, value]) => {
|
|
92
|
+
if (UNSYNCABLE_ENV_VARS.includes(key)) {
|
|
93
|
+
return acc;
|
|
94
|
+
}
|
|
95
|
+
// Strip out any TRIGGER_ prefix env vars
|
|
96
|
+
if (UNSYNCABLE_ENV_VARS_PREFIXES.some((prefix) => key.startsWith(prefix))) {
|
|
97
|
+
return acc;
|
|
98
|
+
}
|
|
99
|
+
acc[key] = value;
|
|
100
|
+
return acc;
|
|
101
|
+
}, {});
|
|
102
|
+
}
|
|
103
|
+
async function callSyncEnvVarsFn(syncEnvVarsFn, env, environment, branch, context) {
|
|
99
104
|
if (syncEnvVarsFn && typeof syncEnvVarsFn === "function") {
|
|
100
|
-
let resolvedEnvVars = {
|
|
105
|
+
let resolvedEnvVars = {
|
|
106
|
+
env: {},
|
|
107
|
+
};
|
|
101
108
|
let result;
|
|
102
109
|
try {
|
|
103
110
|
result = await syncEnvVarsFn({
|
|
104
111
|
projectRef: context.config.project,
|
|
105
112
|
environment,
|
|
106
113
|
env,
|
|
114
|
+
branch,
|
|
107
115
|
});
|
|
108
116
|
}
|
|
109
117
|
catch (error) {
|
|
@@ -120,12 +128,20 @@ async function callSyncEnvVarsFn(syncEnvVarsFn, env, environment, context) {
|
|
|
120
128
|
"value" in item &&
|
|
121
129
|
typeof item.name === "string" &&
|
|
122
130
|
typeof item.value === "string") {
|
|
123
|
-
|
|
131
|
+
if (item.isParentEnv) {
|
|
132
|
+
if (!resolvedEnvVars.parentEnv) {
|
|
133
|
+
resolvedEnvVars.parentEnv = {};
|
|
134
|
+
}
|
|
135
|
+
resolvedEnvVars.parentEnv[item.name] = item.value;
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
resolvedEnvVars.env[item.name] = item.value;
|
|
139
|
+
}
|
|
124
140
|
}
|
|
125
141
|
}
|
|
126
142
|
}
|
|
127
143
|
else if (result) {
|
|
128
|
-
resolvedEnvVars = result;
|
|
144
|
+
resolvedEnvVars.env = result;
|
|
129
145
|
}
|
|
130
146
|
return resolvedEnvVars;
|
|
131
147
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"syncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/syncEnvVars.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"syncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/syncEnvVars.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,13 +4,16 @@ exports.syncVercelEnvVars = syncVercelEnvVars;
|
|
|
4
4
|
const core_js_1 = require("../core.js");
|
|
5
5
|
function syncVercelEnvVars(options) {
|
|
6
6
|
const sync = (0, core_js_1.syncEnvVars)(async (ctx) => {
|
|
7
|
-
const projectId = options?.projectId ?? process.env.VERCEL_PROJECT_ID ??
|
|
8
|
-
ctx.env.VERCEL_PROJECT_ID;
|
|
7
|
+
const projectId = options?.projectId ?? process.env.VERCEL_PROJECT_ID ?? ctx.env.VERCEL_PROJECT_ID;
|
|
9
8
|
const vercelAccessToken = options?.vercelAccessToken ??
|
|
10
9
|
process.env.VERCEL_ACCESS_TOKEN ??
|
|
11
|
-
ctx.env.VERCEL_ACCESS_TOKEN
|
|
12
|
-
|
|
13
|
-
|
|
10
|
+
ctx.env.VERCEL_ACCESS_TOKEN ??
|
|
11
|
+
process.env.VERCEL_TOKEN;
|
|
12
|
+
const vercelTeamId = options?.vercelTeamId ?? process.env.VERCEL_TEAM_ID ?? ctx.env.VERCEL_TEAM_ID;
|
|
13
|
+
const branch = options?.branch ??
|
|
14
|
+
process.env.VERCEL_PREVIEW_BRANCH ??
|
|
15
|
+
ctx.env.VERCEL_PREVIEW_BRANCH ??
|
|
16
|
+
ctx.branch;
|
|
14
17
|
if (!projectId) {
|
|
15
18
|
throw new Error("syncVercelEnvVars: you did not pass in a projectId or set the VERCEL_PROJECT_ID env var.");
|
|
16
19
|
}
|
|
@@ -21,6 +24,7 @@ function syncVercelEnvVars(options) {
|
|
|
21
24
|
prod: "production",
|
|
22
25
|
staging: "preview",
|
|
23
26
|
dev: "development",
|
|
27
|
+
preview: "preview",
|
|
24
28
|
};
|
|
25
29
|
const vercelEnvironment = environmentMap[ctx.environment];
|
|
26
30
|
if (!vercelEnvironment) {
|
|
@@ -29,6 +33,7 @@ function syncVercelEnvVars(options) {
|
|
|
29
33
|
const params = new URLSearchParams({ decrypt: "true" });
|
|
30
34
|
if (vercelTeamId)
|
|
31
35
|
params.set("teamId", vercelTeamId);
|
|
36
|
+
params.set("target", vercelEnvironment);
|
|
32
37
|
const vercelApiUrl = `https://api.vercel.com/v8/projects/${projectId}/env?${params}`;
|
|
33
38
|
try {
|
|
34
39
|
const response = await fetch(vercelApiUrl, {
|
|
@@ -40,13 +45,24 @@ function syncVercelEnvVars(options) {
|
|
|
40
45
|
throw new Error(`HTTP error! status: ${response.status}`);
|
|
41
46
|
}
|
|
42
47
|
const data = await response.json();
|
|
48
|
+
const isBranchable = ctx.environment === "preview";
|
|
43
49
|
const filteredEnvs = data.envs
|
|
44
|
-
.filter((env) =>
|
|
45
|
-
env.
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
+
.filter((env) => {
|
|
51
|
+
if (!env.value)
|
|
52
|
+
return false;
|
|
53
|
+
if (!env.target.includes(vercelEnvironment))
|
|
54
|
+
return false;
|
|
55
|
+
if (isBranchable && env.gitBranch && env.gitBranch !== branch)
|
|
56
|
+
return false;
|
|
57
|
+
return true;
|
|
58
|
+
})
|
|
59
|
+
.map((env) => {
|
|
60
|
+
return {
|
|
61
|
+
name: env.key,
|
|
62
|
+
value: env.value,
|
|
63
|
+
isParentEnv: isBranchable && !env.gitBranch,
|
|
64
|
+
};
|
|
65
|
+
});
|
|
50
66
|
return filteredEnvs;
|
|
51
67
|
}
|
|
52
68
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vercelSyncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/vercelSyncEnvVars.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"vercelSyncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/vercelSyncEnvVars.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { BuildExtension } from "@trigger.dev/core/v3/build";
|
|
2
|
+
type LightpandaOpts = {
|
|
3
|
+
version?: "nightly" | "latest";
|
|
4
|
+
disableTelemetry?: boolean;
|
|
5
|
+
};
|
|
6
|
+
export declare const lightpanda: ({ version, disableTelemetry, }?: LightpandaOpts) => BuildExtension;
|
|
7
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.lightpanda = void 0;
|
|
4
|
+
const lightpanda = ({ version = "latest", disableTelemetry = false, } = {}) => ({
|
|
5
|
+
name: "lightpanda",
|
|
6
|
+
onBuildComplete: async (context) => {
|
|
7
|
+
if (context.target === "dev") {
|
|
8
|
+
return;
|
|
9
|
+
}
|
|
10
|
+
context.logger.debug(`Adding lightpanda`, { version, disableTelemetry });
|
|
11
|
+
const instructions = [
|
|
12
|
+
`COPY --from=lightpanda/browser:${version} /usr/bin/lightpanda /usr/local/bin/lightpanda`,
|
|
13
|
+
`RUN /usr/local/bin/lightpanda version || (echo "lightpanda binary is not functional" && exit 1)`,
|
|
14
|
+
];
|
|
15
|
+
context.addLayer({
|
|
16
|
+
id: "lightpanda",
|
|
17
|
+
image: {
|
|
18
|
+
instructions,
|
|
19
|
+
},
|
|
20
|
+
deploy: {
|
|
21
|
+
env: {
|
|
22
|
+
...(disableTelemetry ? { LIGHTPANDA_DISABLE_TELEMETRY: "true" } : {}),
|
|
23
|
+
},
|
|
24
|
+
override: true,
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
exports.lightpanda = lightpanda;
|
|
30
|
+
//# sourceMappingURL=lightpanda.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lightpanda.js","sourceRoot":"","sources":["../../../src/extensions/lightpanda.ts"],"names":[],"mappings":";;;AAOO,MAAM,UAAU,GAAG,CAAC,EACzB,OAAO,GAAG,QAAQ,EAClB,gBAAgB,GAAG,KAAK,MACN,EAAE,EAAkB,EAAE,CAAC,CAAC;IAC1C,IAAI,EAAE,YAAY;IAClB,eAAe,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;QACjC,IAAI,OAAO,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,EAAE,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC,CAAC;QAEzE,MAAM,YAAY,GAAG;YACnB,kCAAkC,OAAO,gDAAgD;YACzF,iGAAiG;SAC/E,CAAC;QAErB,OAAO,CAAC,QAAQ,CAAC;YACf,EAAE,EAAE,YAAY;YAChB,KAAK,EAAE;gBACL,YAAY;aACb;YACD,MAAM,EAAE;gBACN,GAAG,EAAE;oBACH,GAAG,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,4BAA4B,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;iBACtE;gBACD,QAAQ,EAAE,IAAI;aACf;SACF,CAAC,CAAC;IACL,CAAC;CACF,CAAC,CAAC;AA9BU,QAAA,UAAU,cA8BpB"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import type { BuildContext, BuildExtension } from "@trigger.dev/core/v3/build";
|
|
2
|
+
import type { BuildManifest, BuildTarget } from "@trigger.dev/core/v3";
|
|
3
|
+
type PlaywrightBrowser = "chromium" | "firefox" | "webkit";
|
|
4
|
+
interface PlaywrightExtensionOptions {
|
|
5
|
+
/**
|
|
6
|
+
* Browsers to install. Select only needed browsers to optimize build time and size.
|
|
7
|
+
* @default ["chromium"]
|
|
8
|
+
*/
|
|
9
|
+
browsers?: PlaywrightBrowser[];
|
|
10
|
+
/**
|
|
11
|
+
* Run the browsers in headless mode (Recommended)
|
|
12
|
+
* @default true
|
|
13
|
+
*/
|
|
14
|
+
headless?: boolean;
|
|
15
|
+
/**
|
|
16
|
+
* Playwright version override. If not provided, we will try to detect the version automatically.
|
|
17
|
+
*/
|
|
18
|
+
version?: string;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Installs Playwright browsers and dependencies for your Trigger.dev deployments.
|
|
22
|
+
*
|
|
23
|
+
* @param options - Configuration options for the Playwright extension.
|
|
24
|
+
* @param options.browsers Browsers to install. Accepts an array of strings. Default: `["chromium"]`
|
|
25
|
+
* @param options.headless Whether to run browsers in headless mode. Default: `true`
|
|
26
|
+
* @param options.version Playwright version to use for browser installation. When not set, will automatically detect the version (recommended). Default: `undefined`
|
|
27
|
+
*
|
|
28
|
+
*/
|
|
29
|
+
export declare function playwright(options?: PlaywrightExtensionOptions): PlaywrightExtension;
|
|
30
|
+
/**
|
|
31
|
+
* Background:
|
|
32
|
+
*
|
|
33
|
+
* Running `npx playwright install --with-deps` normally will install the browsers and the dependencies.
|
|
34
|
+
* However, this is not possible in a build context, because we don't have sudo access.
|
|
35
|
+
*
|
|
36
|
+
* So we need to install the dependencies manually and then download and install the browsers.
|
|
37
|
+
* This has a few challenges:
|
|
38
|
+
* 1. We don't want to download all browsers, only the ones we need with it's dependencies
|
|
39
|
+
* The less dependencies we have to install, the faster the build, and the smaller the image.
|
|
40
|
+
* 2. We need to know where to download the browsers from
|
|
41
|
+
* while we can hardcode the download url it might change over time (as it has in the past)
|
|
42
|
+
* so we need to download the browser info first and then parse the output to get the download url.
|
|
43
|
+
*
|
|
44
|
+
* Note: While this looks like we are downloading & installing a lot of stuff, it's actually not that bad
|
|
45
|
+
* since running `npx playwright install --with-deps` will result in the same amount of downloads.
|
|
46
|
+
*/
|
|
47
|
+
declare class PlaywrightExtension implements BuildExtension {
|
|
48
|
+
readonly name = "PlaywrightExtension";
|
|
49
|
+
private moduleExternals;
|
|
50
|
+
private readonly options;
|
|
51
|
+
constructor({ browsers, headless, version, }?: PlaywrightExtensionOptions);
|
|
52
|
+
externalsForTarget(target: BuildTarget): string[];
|
|
53
|
+
onBuildComplete(context: BuildContext, manifest: BuildManifest): void;
|
|
54
|
+
}
|
|
55
|
+
export {};
|