Files
npm-audit-action/src/main.ts

41 lines
1.1 KiB
TypeScript
Raw Normal View History

2019-12-08 19:17:13 +09:00
import * as core from '@actions/core'
import * as github from '@actions/github'
import stripAnsi from 'strip-ansi'
import Octokit, {IssuesCreateResponse} from '@octokit/rest'
import {Audit} from './audit'
import * as issue from './issue'
import {IssueOption} from './interface'
2019-12-08 19:17:13 +09:00
async function run(): Promise<void> {
try {
const audit = new Audit()
audit.run()
2019-12-08 19:17:13 +09:00
core.info(audit.stdout)
2019-12-08 22:10:35 +09:00
if (!audit.foundVulnerability()) {
2019-12-08 22:10:35 +09:00
// vulnerabilities are not found
return
}
core.debug('open an issue')
const token: string = core.getInput('token', {required: true})
const client: Octokit = new github.GitHub(token)
// remove control characters and create a code block
const issueBody = `\`\`\`\n${stripAnsi(audit.stdout)}\n\`\`\``
2019-12-09 21:31:55 +09:00
const option: IssueOption = issue.getIssueOption(issueBody)
const {
2019-12-09 21:31:55 +09:00
data: createdIssue
}: Octokit.Response<IssuesCreateResponse> = await client.issues.create({
...github.context.repo,
2019-12-09 21:31:55 +09:00
...option
})
2019-12-09 21:31:55 +09:00
core.debug(`#${createdIssue.number}`)
2019-12-08 19:17:13 +09:00
} catch (error) {
core.setFailed(error.message)
}
}
run()