summaryrefslogtreecommitdiff
path: root/.github/scripts/utils.mjs
diff options
context:
space:
mode:
authorGravatar Emanuele Stoppa <my.burning@gmail.com> 2024-11-18 13:34:43 +0000
committerGravatar GitHub <noreply@github.com> 2024-11-18 13:34:43 +0000
commit3bde4aa751c8bdf4f23edc86455b22061480583a (patch)
tree9d52d33854150112acbff936d3743c61fd07e0d4 /.github/scripts/utils.mjs
parentcc03d907c1fe6af4758afac34b318403bd75867a (diff)
downloadastro-3bde4aa751c8bdf4f23edc86455b22061480583a.tar.gz
astro-3bde4aa751c8bdf4f23edc86455b22061480583a.tar.zst
astro-3bde4aa751c8bdf4f23edc86455b22061480583a.zip
chore: use Biome VCS ignore file (#12465)
Diffstat (limited to '')
-rw-r--r--.github/scripts/utils.mjs86
1 files changed, 40 insertions, 46 deletions
diff --git a/.github/scripts/utils.mjs b/.github/scripts/utils.mjs
index da5befc2c..9aaa383d8 100644
--- a/.github/scripts/utils.mjs
+++ b/.github/scripts/utils.mjs
@@ -1,59 +1,53 @@
-import * as fs from 'node:fs'
-import * as os from 'node:os'
-import * as crypto from 'node:crypto'
+import * as fs from 'node:fs';
+import * as os from 'node:os';
+import * as crypto from 'node:crypto';
/** Based on https://github.com/actions/toolkit/blob/4e3b068ce116d28cb840033c02f912100b4592b0/packages/core/src/file-command.ts */
export function setOutput(key, value) {
- const filePath = process.env['GITHUB_OUTPUT'] || ''
- if (filePath) {
- return issueFileCommand('OUTPUT', prepareKeyValueMessage(key, value))
- }
- process.stdout.write(os.EOL)
+ const filePath = process.env['GITHUB_OUTPUT'] || '';
+ if (filePath) {
+ return issueFileCommand('OUTPUT', prepareKeyValueMessage(key, value));
+ }
+ process.stdout.write(os.EOL);
}
function issueFileCommand(command, message) {
- const filePath = process.env[`GITHUB_${command}`]
- if (!filePath) {
- throw new Error(
- `Unable to find environment variable for file command ${command}`
- )
- }
- if (!fs.existsSync(filePath)) {
- throw new Error(`Missing file at path: ${filePath}`)
- }
-
- fs.appendFileSync(filePath, `${toCommandValue(message)}${os.EOL}`, {
- encoding: 'utf8'
- })
+ const filePath = process.env[`GITHUB_${command}`];
+ if (!filePath) {
+ throw new Error(`Unable to find environment variable for file command ${command}`);
+ }
+ if (!fs.existsSync(filePath)) {
+ throw new Error(`Missing file at path: ${filePath}`);
+ }
+
+ fs.appendFileSync(filePath, `${toCommandValue(message)}${os.EOL}`, {
+ encoding: 'utf8',
+ });
}
function prepareKeyValueMessage(key, value) {
- const delimiter = `gh-delimiter-${crypto.randomUUID()}`
- const convertedValue = toCommandValue(value)
-
- // These should realistically never happen, but just in case someone finds a
- // way to exploit uuid generation let's not allow keys or values that contain
- // the delimiter.
- if (key.includes(delimiter)) {
- throw new Error(
- `Unexpected input: name should not contain the delimiter "${delimiter}"`
- )
- }
-
- if (convertedValue.includes(delimiter)) {
- throw new Error(
- `Unexpected input: value should not contain the delimiter "${delimiter}"`
- )
- }
-
- return `${key}<<${delimiter}${os.EOL}${convertedValue}${os.EOL}${delimiter}`
+ const delimiter = `gh-delimiter-${crypto.randomUUID()}`;
+ const convertedValue = toCommandValue(value);
+
+ // These should realistically never happen, but just in case someone finds a
+ // way to exploit uuid generation let's not allow keys or values that contain
+ // the delimiter.
+ if (key.includes(delimiter)) {
+ throw new Error(`Unexpected input: name should not contain the delimiter "${delimiter}"`);
+ }
+
+ if (convertedValue.includes(delimiter)) {
+ throw new Error(`Unexpected input: value should not contain the delimiter "${delimiter}"`);
+ }
+
+ return `${key}<<${delimiter}${os.EOL}${convertedValue}${os.EOL}${delimiter}`;
}
function toCommandValue(input) {
- if (input === null || input === undefined) {
- return ''
- } else if (typeof input === 'string' || input instanceof String) {
- return input
- }
- return JSON.stringify(input)
+ if (input === null || input === undefined) {
+ return '';
+ } else if (typeof input === 'string' || input instanceof String) {
+ return input;
+ }
+ return JSON.stringify(input);
}