diff --git a/.github/actions/setup/action.yml b/.github/actions/setup/action.yml new file mode 100644 index 0000000..ced847c --- /dev/null +++ b/.github/actions/setup/action.yml @@ -0,0 +1,15 @@ +name: Setup +description: 'Installs node, driver dependencies, and builds source' + +runs: + using: composite + steps: + - uses: actions/setup-node@v4 + with: + node-version: 'lts/*' + cache: 'npm' + registry-url: 'https://registry.npmjs.org' + - run: npm install -g npm@latest + shell: bash + - run: npm clean-install + shell: bash diff --git a/.github/scripts/highlights.mjs b/.github/scripts/highlights.mjs new file mode 100644 index 0000000..20d5542 --- /dev/null +++ b/.github/scripts/highlights.mjs @@ -0,0 +1,77 @@ +// @ts-check +import * as process from 'node:process'; +import { output } from './util.mjs'; + +const { + GITHUB_TOKEN = '', + PR_LIST = '', + REPOSITORY = '' +} = process.env; +if (GITHUB_TOKEN === '') throw new Error('GITHUB_TOKEN cannot be empty'); +if (REPOSITORY === '') throw new Error('REPOSITORY cannot be empty') + +const API_REQ_INFO = { + headers: { + Accept: 'application/vnd.github.v3+json', + 'X-GitHub-Api-Version': '2022-11-28', + Authorization: `Bearer ${GITHUB_TOKEN}` + } +} + +const prs = PR_LIST.split(',').map(pr => { + const prNum = Number(pr); + if (Number.isNaN(prNum)) + throw Error(`expected PR number list: ${PR_LIST}, offending entry: ${pr}`); + return prNum; +}); + +/** @param {number} pull_number */ +async function getPullRequestContent(pull_number) { + const startIndicator = 'RELEASE_HIGHLIGHT_START -->'; + const endIndicator = '