mirror of
https://github.com/actions/deploy-pages.git
synced 2025-12-09 12:26:11 +00:00
See: https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#permissions
44 lines
1.3 KiB
JavaScript
44 lines
1.3 KiB
JavaScript
// This package assumes a site has already been built and the files exist in the current workspace
|
|
// If there's an artifact named `artifact.tar`, it can upload that to actions on its own,
|
|
// without the user having to do the tar process themselves.
|
|
|
|
const core = require('@actions/core')
|
|
// const github = require('@actions/github'); // TODO: Not used until we publish API endpoint to the @action/github package
|
|
|
|
const { Deployment } = require('./deployment')
|
|
const deployment = new Deployment()
|
|
|
|
async function cancelHandler(evtOrExitCodeOrError) {
|
|
await deployment.cancel()
|
|
process.exit(isNaN(+evtOrExitCodeOrError) ? 1 : +evtOrExitCodeOrError)
|
|
}
|
|
|
|
async function main() {
|
|
let idToken = ''
|
|
try {
|
|
idToken = await core.getIDToken()
|
|
} catch (error) {
|
|
console.log(error)
|
|
core.setFailed(`Ensure GITHUB_TOKEN has permission "id-token: write".`)
|
|
return
|
|
}
|
|
try {
|
|
await deployment.create(idToken)
|
|
await deployment.check()
|
|
} catch (error) {
|
|
core.setFailed(error)
|
|
}
|
|
}
|
|
|
|
// Register signal handlers for workflow cancellation
|
|
process.on('SIGINT', cancelHandler)
|
|
process.on('SIGTERM', cancelHandler)
|
|
|
|
// Main
|
|
const emitTelemetry = core.getInput('emit_telemetry')
|
|
if (emitTelemetry === 'true') {
|
|
// For compatibility, treat the use of this deprecated input as a no-op
|
|
} else {
|
|
main()
|
|
}
|