UNPKG

jsii-release

Version:

Release jsii modules to multiple package managers

221 lines 18.9 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.identify = exports.email = exports.username = exports.checkout = exports.push = exports.tag = exports.init = exports.commit = exports.add = exports.diffIndex = exports.detectSSH = exports.getToken = exports.detectGHE = exports.clone = void 0; const shell = __importStar(require("./shell")); /** * Clones a repository from GitHub. Requires a `GITHUB_TOKEN` env variable. * * @param repositoryUrl the repository to clone. * @param targetDir the clone directory. */ function clone(repositoryUrl, targetDir) { const gitHubUseSsh = detectSSH(); if (gitHubUseSsh) { const sshRepositoryUrl = repositoryUrl.replace('/', ':'); shell.run(`git clone git@${sshRepositoryUrl}.git ${targetDir}`); } else { const gitHubToken = getToken(detectGHE()); if (!gitHubToken) { throw new Error('GITHUB_TOKEN env variable is required when GITHUB_USE_SSH env variable is not used'); } shell.run(`git clone https://${gitHubToken}@${repositoryUrl}.git ${targetDir}`); } } exports.clone = clone; /** * Checks if the current environment is an GHE environment. * * This check is using GITHUB_API_URL set in GitHub Actions workflow, as well as common gh cli env variables. * https://docs.github.com/en/actions/learn-github-actions/variables#default-environment-variables * https://cli.github.com/manual/gh_help_environment * * @return - `true` if GH_HOST or GITHUB_API_URL env var are defined and not equal to the public github endpoint, otherwise `false` */ function detectGHE() { const githubApiUrl = process.env.GITHUB_API_URL; const ghHost = process.env.GH_HOST; return (Boolean(ghHost) && ghHost.trim().toLowerCase() != 'github.com') || (Boolean(githubApiUrl) && githubApiUrl.trim().toLowerCase() != 'https://api.github.com'); } exports.detectGHE = detectGHE; /** * Returns an appropriate github token from the environment. * * @return GH_ENTERPRISE_TOKEN or GITHUB_ENTERPRISE_TOKEN or GITHUB_TOKEN if in an GHE environment, otherwise GITHUB_TOKEN */ function getToken(isGHE) { var _a, _b; if (isGHE) { const githubEnterpiseToken = (_b = (_a = process.env.GH_ENTERPRISE_TOKEN) !== null && _a !== void 0 ? _a : process.env.GITHUB_ENTERPRISE_TOKEN) !== null && _b !== void 0 ? _b : process.env.GITHUB_TOKEN; return githubEnterpiseToken; } return process.env.GITHUB_TOKEN; } exports.getToken = getToken; /** * Checks if SSH should be used to clone repo. * This checks the presence and values of the GIT_USE_SSH env variable and the deprecated GITHUB_USE_SSH for legacy reason. Returns true if either of these env vars are defined and not falsy. */ function detectSSH() { var _a; return Boolean((_a = process.env.GIT_USE_SSH) !== null && _a !== void 0 ? _a : process.env.GITHUB_USE_SSH); } exports.detectSSH = detectSSH; /** * Query the git index for changes. * * @return True if changes exist, False otherwise. */ function diffIndex() { try { shell.run('git diff-index --exit-code HEAD --'); return false; } catch (err) { return true; } } exports.diffIndex = diffIndex; /** * Add files to the index. * * @param p the path. */ function add(p) { shell.run(`git add ${p}`); } exports.add = add; /** * Commit. * * @param message the commit message. */ function commit(message) { shell.run(`git commit -m "${message}"`); } exports.commit = commit; /** * Initialize a repository. */ function init() { shell.run('git init'); } exports.init = init; /** * Cerate a tag. * * @param name tag name. * @returns true if the tag was created, false if it already exists. */ function tag(name) { try { shell.run(`git tag -a ${name} -m ${name}`, { capture: true }); return true; } catch (e) { if (e instanceof Error && e.message.includes('already exists')) { return false; } throw e; } } exports.tag = tag; /** * Push a ref to origin. * * @param ref the ref */ function push(ref) { shell.run(`git push origin ${ref}`); } exports.push = push; /** * Checkout to a new branch. Creates a new one if `options.createIfMissing` is True and the branch doesn't exist. * * @param branch the branch. * @param options options. */ function checkout(branch, options) { if (options.createIfMissing) { try { shell.run(`git show-branch origin/${branch}`, { capture: true }); } catch (e) { if (e instanceof Error && e.message.includes('fatal: bad sha1 reference')) { console.log('Remote branch not found, creating new branch.'); shell.run(`git checkout -B ${branch}`); return; } } } shell.run(`git checkout ${branch}`); } exports.checkout = checkout; /** * Fetch the configured git user name for the current directory. * Returns undefined if not configured. */ function username() { try { return shell.run('git config user.name', { capture: true }); } catch (err) { if (err instanceof Error) { console.warn(err.message); } return undefined; } } exports.username = username; /** * Fetch the configured git user email for the current directory. * Returns undefined if not configured. */ function email() { try { return shell.run('git config user.email', { capture: true }); } catch (err) { if (err instanceof Error) { console.warn(err.message); } return undefined; } } exports.email = email; /** * Identify the committer with a username and email. * * @param user the username. * @param email the email address. */ function identify(user, address) { shell.run(`git config user.name "${user}"`); shell.run(`git config user.email "${address}"`); } exports.identify = identify; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"git.js","sourceRoot":"","sources":["../../src/help/git.ts"],"names":[],"mappings":"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","sourcesContent":["import * as shell from './shell';\n\n/**\n * Clones a repository from GitHub. Requires a `GITHUB_TOKEN` env variable.\n *\n * @param repositoryUrl the repository to clone.\n * @param targetDir the clone directory.\n */\nexport function clone(repositoryUrl: string, targetDir: string) {\n  const gitHubUseSsh = detectSSH();\n  if (gitHubUseSsh) {\n    const sshRepositoryUrl = repositoryUrl.replace('/', ':');\n    shell.run(`git clone git@${sshRepositoryUrl}.git ${targetDir}`);\n  } else {\n    const gitHubToken = getToken(detectGHE());\n    if (!gitHubToken) {\n      throw new Error('GITHUB_TOKEN env variable is required when GITHUB_USE_SSH env variable is not used');\n    }\n    shell.run(`git clone https://${gitHubToken}@${repositoryUrl}.git ${targetDir}`);\n\n  }\n}\n\n/**\n * Checks if the current environment is an GHE environment.\n *\n * This check is using GITHUB_API_URL set in GitHub Actions workflow, as well as common gh cli env variables.\n * https://docs.github.com/en/actions/learn-github-actions/variables#default-environment-variables\n * https://cli.github.com/manual/gh_help_environment\n *\n * @return - `true` if GH_HOST or GITHUB_API_URL env var are defined and not equal to the public github endpoint, otherwise `false`\n */\nexport function detectGHE(): boolean {\n  const githubApiUrl = process.env.GITHUB_API_URL;\n  const ghHost = process.env.GH_HOST;\n\n  return (Boolean(ghHost) && ghHost!.trim().toLowerCase() != 'github.com')\n    || (Boolean(githubApiUrl) && githubApiUrl!.trim().toLowerCase() != 'https://api.github.com');\n}\n\n/**\n * Returns an appropriate github token from the environment.\n *\n * @return GH_ENTERPRISE_TOKEN or GITHUB_ENTERPRISE_TOKEN or GITHUB_TOKEN if in an GHE environment, otherwise GITHUB_TOKEN\n */\n\nexport function getToken(isGHE: boolean): (string | undefined) {\n  if (isGHE) {\n    const githubEnterpiseToken = process.env.GH_ENTERPRISE_TOKEN ?? process.env.GITHUB_ENTERPRISE_TOKEN ?? process.env.GITHUB_TOKEN;\n    return githubEnterpiseToken;\n  }\n  return process.env.GITHUB_TOKEN;\n}\n\n/**\n * Checks if SSH should be used to clone repo.\n * This checks the presence and values of the GIT_USE_SSH env variable and the deprecated GITHUB_USE_SSH for legacy reason. Returns true if either of these env vars are defined and not falsy.\n */\n\nexport function detectSSH(): boolean {\n  return Boolean(process.env.GIT_USE_SSH ?? process.env.GITHUB_USE_SSH);\n}\n\n/**\n * Query the git index for changes.\n *\n * @return True if changes exist, False otherwise.\n */\nexport function diffIndex(): boolean {\n  try {\n    shell.run('git diff-index --exit-code HEAD --');\n    return false;\n  } catch (err) {\n    return true;\n  }\n}\n\n/**\n * Add files to the index.\n *\n * @param p the path.\n */\nexport function add(p: string) {\n  shell.run(`git add ${p}`);\n}\n\n/**\n * Commit.\n *\n * @param message the commit message.\n */\nexport function commit(message: string) {\n  shell.run(`git commit -m \"${message}\"`);\n}\n\n/**\n * Initialize a repository.\n */\nexport function init() {\n  shell.run('git init');\n}\n\n/**\n * Cerate a tag.\n *\n * @param name tag name.\n * @returns true if the tag was created, false if it already exists.\n */\nexport function tag(name: string): boolean {\n  try {\n    shell.run(`git tag -a ${name} -m ${name}`, { capture: true });\n    return true;\n  } catch (e) {\n    if (e instanceof Error && e.message.includes('already exists')) {\n      return false;\n    }\n    throw e;\n  }\n}\n\n/**\n * Push a ref to origin.\n *\n * @param ref the ref\n */\nexport function push(ref: string) {\n  shell.run(`git push origin ${ref}`);\n}\n\n/**\n * Checkout to a new branch. Creates a new one if `options.createIfMissing` is True and the branch doesn't exist.\n *\n * @param branch the branch.\n * @param options options.\n */\nexport function checkout(branch: string, options: { createIfMissing?: boolean } ) {\n  if (options.createIfMissing) {\n    try {\n      shell.run(`git show-branch origin/${branch}`, { capture: true });\n    } catch (e) {\n      if (e instanceof Error && e.message.includes('fatal: bad sha1 reference')) {\n        console.log('Remote branch not found, creating new branch.');\n        shell.run(`git checkout -B ${branch}`);\n        return;\n      }\n    }\n  }\n  shell.run(`git checkout ${branch}`);\n}\n\n/**\n * Fetch the configured git user name for the current directory.\n * Returns undefined if not configured.\n */\nexport function username() {\n  try {\n    return shell.run('git config user.name', { capture: true });\n  } catch (err) {\n    if (err instanceof Error) {\n      console.warn(err.message);\n    }\n    return undefined;\n  }\n}\n\n/**\n * Fetch the configured git user email for the current directory.\n * Returns undefined if not configured.\n */\nexport function email() {\n  try {\n    return shell.run('git config user.email', { capture: true });\n  } catch (err) {\n    if (err instanceof Error) {\n      console.warn(err.message);\n    }\n    return undefined;\n  }\n}\n\n/**\n * Identify the committer with a username and email.\n *\n * @param user the username.\n * @param email the email address.\n */\nexport function identify(user: string, address: string) {\n  shell.run(`git config user.name \"${user}\"`);\n  shell.run(`git config user.email \"${address}\"`);\n}\n"]}