2019-12-03 23:28:59 +08:00
|
|
|
import * as core from '@actions/core'
|
|
|
|
import * as fsHelper from './fs-helper'
|
|
|
|
import * as github from '@actions/github'
|
|
|
|
import * as path from 'path'
|
2020-03-03 00:33:30 +08:00
|
|
|
import {IGitSourceSettings} from './git-source-settings'
|
2019-12-03 23:28:59 +08:00
|
|
|
|
2020-03-03 00:33:30 +08:00
|
|
|
export function getInputs(): IGitSourceSettings {
|
|
|
|
const result = ({} as unknown) as IGitSourceSettings
|
2019-12-03 23:28:59 +08:00
|
|
|
|
|
|
|
// GitHub workspace
|
|
|
|
let githubWorkspacePath = process.env['GITHUB_WORKSPACE']
|
|
|
|
if (!githubWorkspacePath) {
|
|
|
|
throw new Error('GITHUB_WORKSPACE not defined')
|
|
|
|
}
|
|
|
|
githubWorkspacePath = path.resolve(githubWorkspacePath)
|
|
|
|
core.debug(`GITHUB_WORKSPACE = '${githubWorkspacePath}'`)
|
|
|
|
fsHelper.directoryExistsSync(githubWorkspacePath, true)
|
|
|
|
|
2020-05-30 06:57:30 +08:00
|
|
|
// Gist repository?
|
|
|
|
result.isGist = !!core.getInput('gist') || false
|
|
|
|
core.debug(`isGist = '${result.isGist}'`)
|
|
|
|
|
2019-12-03 23:28:59 +08:00
|
|
|
// Qualified repository
|
2020-05-30 06:57:30 +08:00
|
|
|
let qualifiedRepository =
|
2019-12-03 23:28:59 +08:00
|
|
|
core.getInput('repository') ||
|
|
|
|
`${github.context.repo.owner}/${github.context.repo.repo}`
|
2020-05-30 06:57:30 +08:00
|
|
|
if (result.isGist) {
|
|
|
|
qualifiedRepository = core.getInput('gist')
|
|
|
|
}
|
2019-12-03 23:28:59 +08:00
|
|
|
core.debug(`qualified repository = '${qualifiedRepository}'`)
|
|
|
|
const splitRepository = qualifiedRepository.split('/')
|
|
|
|
if (
|
|
|
|
splitRepository.length !== 2 ||
|
|
|
|
!splitRepository[0] ||
|
|
|
|
!splitRepository[1]
|
|
|
|
) {
|
2020-05-30 06:57:30 +08:00
|
|
|
const model = result.isGist ? 'gist' : 'repository'
|
2019-12-03 23:28:59 +08:00
|
|
|
throw new Error(
|
2020-05-30 06:57:30 +08:00
|
|
|
`Invalid ${model} '${qualifiedRepository}'. Expected format {owner}/{repo}.`
|
2019-12-03 23:28:59 +08:00
|
|
|
)
|
|
|
|
}
|
|
|
|
result.repositoryOwner = splitRepository[0]
|
|
|
|
result.repositoryName = splitRepository[1]
|
|
|
|
|
|
|
|
// Repository path
|
|
|
|
result.repositoryPath = core.getInput('path') || '.'
|
|
|
|
result.repositoryPath = path.resolve(
|
|
|
|
githubWorkspacePath,
|
|
|
|
result.repositoryPath
|
|
|
|
)
|
|
|
|
if (
|
|
|
|
!(result.repositoryPath + path.sep).startsWith(
|
|
|
|
githubWorkspacePath + path.sep
|
|
|
|
)
|
|
|
|
) {
|
|
|
|
throw new Error(
|
|
|
|
`Repository path '${result.repositoryPath}' is not under '${githubWorkspacePath}'`
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Workflow repository?
|
|
|
|
const isWorkflowRepository =
|
|
|
|
qualifiedRepository.toUpperCase() ===
|
|
|
|
`${github.context.repo.owner}/${github.context.repo.repo}`.toUpperCase()
|
|
|
|
|
|
|
|
// Source branch, source version
|
|
|
|
result.ref = core.getInput('ref')
|
|
|
|
if (!result.ref) {
|
|
|
|
if (isWorkflowRepository) {
|
|
|
|
result.ref = github.context.ref
|
|
|
|
result.commit = github.context.sha
|
2020-01-22 03:17:04 +08:00
|
|
|
|
|
|
|
// Some events have an unqualifed ref. For example when a PR is merged (pull_request closed event),
|
|
|
|
// the ref is unqualifed like "master" instead of "refs/heads/master".
|
|
|
|
if (result.commit && result.ref && !result.ref.startsWith('refs/')) {
|
|
|
|
result.ref = `refs/heads/${result.ref}`
|
|
|
|
}
|
2019-12-03 23:28:59 +08:00
|
|
|
}
|
2020-06-17 09:45:19 +08:00
|
|
|
|
|
|
|
if (result.isGist && !result.ref && !result.commit) {
|
|
|
|
result.ref = 'refs/heads/master'
|
|
|
|
}
|
2019-12-03 23:28:59 +08:00
|
|
|
}
|
|
|
|
// SHA?
|
|
|
|
else if (result.ref.match(/^[0-9a-fA-F]{40}$/)) {
|
|
|
|
result.commit = result.ref
|
|
|
|
result.ref = ''
|
|
|
|
}
|
|
|
|
core.debug(`ref = '${result.ref}'`)
|
|
|
|
core.debug(`commit = '${result.commit}'`)
|
|
|
|
|
|
|
|
// Clean
|
|
|
|
result.clean = (core.getInput('clean') || 'true').toUpperCase() === 'TRUE'
|
|
|
|
core.debug(`clean = ${result.clean}`)
|
|
|
|
|
|
|
|
// Fetch depth
|
|
|
|
result.fetchDepth = Math.floor(Number(core.getInput('fetch-depth') || '1'))
|
|
|
|
if (isNaN(result.fetchDepth) || result.fetchDepth < 0) {
|
|
|
|
result.fetchDepth = 0
|
|
|
|
}
|
|
|
|
core.debug(`fetch depth = ${result.fetchDepth}`)
|
|
|
|
|
|
|
|
// LFS
|
|
|
|
result.lfs = (core.getInput('lfs') || 'false').toUpperCase() === 'TRUE'
|
|
|
|
core.debug(`lfs = ${result.lfs}`)
|
|
|
|
|
2020-03-06 03:21:59 +08:00
|
|
|
// Submodules
|
|
|
|
result.submodules = false
|
|
|
|
result.nestedSubmodules = false
|
|
|
|
const submodulesString = (core.getInput('submodules') || '').toUpperCase()
|
|
|
|
if (submodulesString == 'RECURSIVE') {
|
|
|
|
result.submodules = true
|
|
|
|
result.nestedSubmodules = true
|
|
|
|
} else if (submodulesString == 'TRUE') {
|
|
|
|
result.submodules = true
|
|
|
|
}
|
|
|
|
core.debug(`submodules = ${result.submodules}`)
|
|
|
|
core.debug(`recursive submodules = ${result.nestedSubmodules}`)
|
|
|
|
|
2019-12-13 02:49:26 +08:00
|
|
|
// Auth token
|
2020-06-17 01:41:01 +08:00
|
|
|
result.authToken = core.getInput('token', {required: true})
|
2019-12-13 02:49:26 +08:00
|
|
|
|
2020-03-12 03:55:17 +08:00
|
|
|
// SSH
|
|
|
|
result.sshKey = core.getInput('ssh-key')
|
|
|
|
result.sshKnownHosts = core.getInput('ssh-known-hosts')
|
|
|
|
result.sshStrict =
|
|
|
|
(core.getInput('ssh-strict') || 'true').toUpperCase() === 'TRUE'
|
|
|
|
|
2019-12-13 02:49:26 +08:00
|
|
|
// Persist credentials
|
|
|
|
result.persistCredentials =
|
|
|
|
(core.getInput('persist-credentials') || 'false').toUpperCase() === 'TRUE'
|
2019-12-03 23:28:59 +08:00
|
|
|
|
|
|
|
return result
|
|
|
|
}
|