UNPKG

projen

Version:

CDK for software projects

152 lines • 24.9 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.WorkflowSteps = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const object_1 = require("../util/object"); /** * A collection of very commonly used, individual, GitHub Workflow Job steps. */ class WorkflowSteps { /** * Checks out a repository. * * @param options Options to configure the `checkout` JobStep * @returns A JobStep that checks out a repository */ static checkout(options = {}) { const checkoutWith = (0, object_1.removeNullOrUndefinedProperties)({ "fetch-depth": options?.with?.fetchDepth, token: options?.with?.token, ref: options?.with?.ref, repository: options?.with?.repository, path: options?.with?.path, ...(options?.with?.lfs ? { lfs: true } : {}), }); return { ...this.buildJobStepConfig({ ...options, name: options.name ?? "Checkout", }), uses: "actions/checkout@v4", with: Object.keys(checkoutWith).length > 0 ? checkoutWith : undefined, }; } /** * Configures the git identity (user name and email). * * @param options Options to configure the git identity JobStep * @returns Job step that configures the provided git identity */ static setupGitIdentity(options) { return { ...this.buildJobStepConfig({ ...options, name: options.name ?? "Set git identity", }), run: [ `git config user.name "${options.gitIdentity.name}"`, `git config user.email "${options.gitIdentity.email}"`, ].join("\n"), }; } /** * Checks if a tag exists. * * Requires a checkout step to have been run before this step with "fetch-depth" set to "0". * * Outputs: * - `exists`: A string value of 'true' or 'false' indicating if the tag exists. * * @param tag The tag to check. You may use valid bash code instead of a literal string in this field. * @param options Options to configure the `tag-exists` JobStep * @returns Job step that checks if the provided tag exists */ static tagExists(tag, options) { const checkTag = (remoteTag) => `git ls-remote -q --exit-code --tags origin ${remoteTag}`; const varIsSet = (variable) => `[ ! -z "$${variable}" ]`; const setOutput = (value) => `(echo "exists=${value ? "true" : "false"}" >> $GITHUB_OUTPUT)`; return { ...this.buildJobStepConfig({ ...options, name: options.name ?? "Check if tag exists", id: options.id ?? "check-tag", }), run: [ `TAG=${tag}`, `(${varIsSet("TAG")} && ${checkTag("$TAG")} && ${setOutput(true)}) || ${setOutput(false)}`, "cat $GITHUB_OUTPUT", ].join("\n"), }; } /** * Uploads an artifact. * * @param options Options to configure the `upload-artifact` JobStep * @returns A JobStep that uploads an artifact */ static uploadArtifact(options) { const uploadArtifactWith = (0, object_1.removeNullOrUndefinedProperties)({ name: options?.with?.name, path: options?.with?.path, overwrite: options?.with?.overwrite ?? true, "if-no-files-found": options?.with?.ifNoFilesFound, "retention-days": options?.with?.retentionDays, "compression-level": options?.with?.compressionLevel, "include-hidden-files": options?.with?.includeHiddenFiles, }); return { ...this.buildJobStepConfig({ ...options, name: options.name ?? "Upload artifact", }), uses: "actions/upload-artifact@v4.4.0", with: uploadArtifactWith, }; } /** * Downloads an artifact. * * @param options Options to configure the `download-artifact` JobStep * @returns A JobStep that downloads an artifact */ static downloadArtifact(options) { const downloadArtifactWith = options?.with ? (0, object_1.removeNullOrUndefinedProperties)({ name: options?.with?.name, path: options?.with?.path, pattern: options?.with?.pattern, repository: options?.with?.repository, "merge-multiple": options?.with?.mergeMultiple, "github-token": options?.with?.token, "run-id": options?.with?.runId, }) : undefined; return { ...this.buildJobStepConfig({ ...options, name: options?.name ?? "Download artifact", }), uses: "actions/download-artifact@v4", with: downloadArtifactWith, }; } /** * Simple adapter to ensure we only include the necessary fields for a JobStepConfiguration. */ static buildJobStepConfig(options) { return { continueOnError: options?.continueOnError, env: options?.env, id: options?.id, if: options?.if, name: options?.name, timeoutMinutes: options?.timeoutMinutes, workingDirectory: options?.workingDirectory, }; } } exports.WorkflowSteps = WorkflowSteps; _a = JSII_RTTI_SYMBOL_1; WorkflowSteps[_a] = { fqn: "projen.github.WorkflowSteps", version: "0.93.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-steps.js","sourceRoot":"","sources":["../../src/github/workflow-steps.ts"],"names":[],"mappings":"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","sourcesContent":["import { GitIdentity } from \"./task-workflow\";\nimport { JobStepConfiguration, JobStep } from \"./workflows-model\";\nimport { removeNullOrUndefinedProperties } from \"../util/object\";\n\n/**\n * A collection of very commonly used, individual, GitHub Workflow Job steps.\n */\nexport class WorkflowSteps {\n  /**\n   * Checks out a repository.\n   *\n   * @param options Options to configure the `checkout` JobStep\n   * @returns A JobStep that checks out a repository\n   */\n  public static checkout(options: CheckoutOptions = {}): JobStep {\n    const checkoutWith = removeNullOrUndefinedProperties({\n      \"fetch-depth\": options?.with?.fetchDepth,\n      token: options?.with?.token,\n      ref: options?.with?.ref,\n      repository: options?.with?.repository,\n      path: options?.with?.path,\n      ...(options?.with?.lfs ? { lfs: true } : {}),\n    });\n\n    return {\n      ...this.buildJobStepConfig({\n        ...options,\n        name: options.name ?? \"Checkout\",\n      }),\n      uses: \"actions/checkout@v4\",\n      with: Object.keys(checkoutWith).length > 0 ? checkoutWith : undefined,\n    };\n  }\n\n  /**\n   * Configures the git identity (user name and email).\n   *\n   * @param options Options to configure the git identity JobStep\n   * @returns Job step that configures the provided git identity\n   */\n  public static setupGitIdentity(options: SetupGitIdentityOptions): JobStep {\n    return {\n      ...this.buildJobStepConfig({\n        ...options,\n        name: options.name ?? \"Set git identity\",\n      }),\n      run: [\n        `git config user.name \"${options.gitIdentity.name}\"`,\n        `git config user.email \"${options.gitIdentity.email}\"`,\n      ].join(\"\\n\"),\n    };\n  }\n\n  /**\n   * Checks if a tag exists.\n   *\n   * Requires a checkout step to have been run before this step with \"fetch-depth\" set to \"0\".\n   *\n   * Outputs:\n   * - `exists`: A string value of 'true' or 'false' indicating if the tag exists.\n   *\n   * @param tag The tag to check. You may use valid bash code instead of a literal string in this field.\n   * @param options Options to configure the `tag-exists` JobStep\n   * @returns Job step that checks if the provided tag exists\n   */\n  public static tagExists(tag: string, options: JobStepConfiguration): JobStep {\n    const checkTag = (remoteTag: string) =>\n      `git ls-remote -q --exit-code --tags origin ${remoteTag}`;\n    const varIsSet = (variable: string) => `[ ! -z \"$${variable}\" ]`;\n    const setOutput = (value: boolean) =>\n      `(echo \"exists=${value ? \"true\" : \"false\"}\" >> $GITHUB_OUTPUT)`;\n\n    return {\n      ...this.buildJobStepConfig({\n        ...options,\n        name: options.name ?? \"Check if tag exists\",\n        id: options.id ?? \"check-tag\",\n      }),\n      run: [\n        `TAG=${tag}`,\n        `(${varIsSet(\"TAG\")} && ${checkTag(\"$TAG\")} && ${setOutput(\n          true\n        )}) || ${setOutput(false)}`,\n        \"cat $GITHUB_OUTPUT\",\n      ].join(\"\\n\"),\n    };\n  }\n\n  /**\n   * Uploads an artifact.\n   *\n   * @param options Options to configure the `upload-artifact` JobStep\n   * @returns A JobStep that uploads an artifact\n   */\n  public static uploadArtifact(options: UploadArtifactOptions): JobStep {\n    const uploadArtifactWith: UploadArtifactWith =\n      removeNullOrUndefinedProperties({\n        name: options?.with?.name,\n        path: options?.with?.path,\n        overwrite: options?.with?.overwrite ?? true,\n        \"if-no-files-found\": options?.with?.ifNoFilesFound,\n        \"retention-days\": options?.with?.retentionDays,\n        \"compression-level\": options?.with?.compressionLevel,\n        \"include-hidden-files\": options?.with?.includeHiddenFiles,\n      });\n\n    return {\n      ...this.buildJobStepConfig({\n        ...options,\n        name: options.name ?? \"Upload artifact\",\n      }),\n      uses: \"actions/upload-artifact@v4.4.0\",\n      with: uploadArtifactWith,\n    };\n  }\n\n  /**\n   * Downloads an artifact.\n   *\n   * @param options Options to configure the `download-artifact` JobStep\n   * @returns A JobStep that downloads an artifact\n   */\n  public static downloadArtifact(options?: DownloadArtifactOptions): JobStep {\n    const downloadArtifactWith: DownloadArtifactWith | undefined = options?.with\n      ? removeNullOrUndefinedProperties({\n          name: options?.with?.name,\n          path: options?.with?.path,\n          pattern: options?.with?.pattern,\n          repository: options?.with?.repository,\n          \"merge-multiple\": options?.with?.mergeMultiple,\n          \"github-token\": options?.with?.token,\n          \"run-id\": options?.with?.runId,\n        })\n      : undefined;\n\n    return {\n      ...this.buildJobStepConfig({\n        ...options,\n        name: options?.name ?? \"Download artifact\",\n      }),\n      uses: \"actions/download-artifact@v4\",\n      with: downloadArtifactWith,\n    };\n  }\n\n  /**\n   * Simple adapter to ensure we only include the necessary fields for a JobStepConfiguration.\n   */\n  private static buildJobStepConfig(\n    options: JobStepConfiguration\n  ): JobStepConfiguration {\n    return {\n      continueOnError: options?.continueOnError,\n      env: options?.env,\n      id: options?.id,\n      if: options?.if,\n      name: options?.name,\n      timeoutMinutes: options?.timeoutMinutes,\n      workingDirectory: options?.workingDirectory,\n    };\n  }\n}\nexport interface CheckoutOptions extends JobStepConfiguration {\n  /**\n   * Options for `checkout`.\n   */\n  readonly with?: CheckoutWith;\n}\n\n/**\n * Options for `checkout`.\n */\nexport interface CheckoutWith {\n  /**\n   * Number of commits to fetch. 0 indicates all history for all branches and tags.\n   *\n   * @default 1\n   */\n  readonly fetchDepth?: number;\n  /**\n   * Whether LFS is enabled for the GitHub repository\n   *\n   * @default false\n   */\n  readonly lfs?: boolean;\n\n  /**\n   * Branch or tag name.\n   * @default - the default branch is implicitly used\n   */\n  readonly ref?: string;\n\n  /**\n   * The repository (owner/repo) to use.\n   * @default - the default repository is implicitly used\n   */\n  readonly repository?: string;\n\n  /**\n   * A GitHub token to use when checking out the repository.\n   *\n   * If the intent is to push changes back to the branch, then you must use a\n   * PAT with `repo` (and possibly `workflows`) permissions.\n   * @default - the default GITHUB_TOKEN is implicitly used\n   */\n  readonly token?: string;\n\n  /**\n   * Relative path under $GITHUB_WORKSPACE to place the repository\n   * @default - $GITHUB_WORKSPACE\n   */\n  readonly path?: string;\n}\n\nexport interface SetupGitIdentityOptions extends JobStepConfiguration {\n  /**\n   * The identity to use.\n   */\n  readonly gitIdentity: GitIdentity;\n}\n\nexport interface UploadArtifactWith {\n  /**\n   * Name of the artifact to upload.\n   *\n   * @default \"artifact\"\n   */\n  readonly name?: string;\n\n  /**\n   * A file, directory or wildcard pattern that describes what to upload\n   */\n  readonly path: string;\n\n  /**\n   * The desired behavior if no files are found using the provided path.\n   * Available Options:\n   *   warn: Output a warning but do not fail the action\n   *   error: Fail the action with an error message\n   *   ignore: Do not output any warnings or errors, the action does not fail\n   *\n   * @default \"warn\"\n   */\n  readonly ifNoFilesFound?: \"error\" | \"warn\" | \"ignore\";\n\n  /**\n   * Duration after which artifact will expire in days. 0 means using default repository retention.\n   *\n   * Minimum 1 day.\n   * Maximum 90 days unless changed from the repository settings page.\n   *\n   * @default - The default repository retention\n   */\n  readonly retentionDays?: number;\n\n  /**\n   * The level of compression for Zlib to be applied to the artifact archive.\n   *\n   * The value can range from 0 to 9.\n   * For large files that are not easily compressed, a value of 0 is recommended for significantly faster uploads.\n   *\n   * @default 6\n   */\n  readonly compressionLevel?: number;\n\n  /**\n   * Whether action should overwrite an existing artifact with the same name (should one exist)\n   *\n   * Introduced in v4 and represents a breaking change from the behavior of the v3 action.\n   * To maintain backwards compatibility with existing, this should be set the `true` (the default).\n   *\n   * @default true\n   */\n  readonly overwrite?: boolean;\n\n  /**\n   * Whether to include hidden files in the provided path in the artifact\n   *\n   * The file contents of any hidden files in the path should be validated before enabled this to avoid uploading sensitive information.\n   *\n   * @default false\n   */\n  readonly includeHiddenFiles?: boolean;\n}\n\nexport interface UploadArtifactOptions extends JobStepConfiguration {\n  /**\n   * Options for `upload-artifact`.\n   */\n  readonly with: UploadArtifactWith;\n}\n\nexport interface DownloadArtifactWith {\n  /**\n   * Name of the artifact to download\n   *\n   * @default - If unspecified, all artifacts for the run are downloaded\n   */\n  readonly name?: string;\n\n  /**\n   * A file, directory or wildcard pattern that describes what to download. Supports basic tilde expansion.\n   *\n   * @default - $GITHUB_WORKSPACE\n   */\n  readonly path?: string;\n\n  /**\n   * A glob pattern to the artifacts that should be downloaded\n   * This is ignored if name is specified\n   */\n  readonly pattern?: string;\n\n  /**\n   * When multiple artifacts are matched, this changes the behavior of the destination directories\n   * If true, the downloaded artifacts will be in the same directory specified by path\n   * If false, the downloaded artifacts will be extracted into individual named directories within the specified path\n   *\n   * @default false\n   */\n  readonly mergeMultiple?: boolean;\n\n  /**\n   * The GitHub token used to authenticate with the GitHub API to download artifacts from a different repository or from a different workflow run\n   *\n   * @default - If unspecified, the action will download artifacts from the current repo and the current workflow run\n   */\n  readonly token?: string;\n\n  /**\n   * The repository owner and the repository name joined together by \"/\"\n   * If github-token is specified, this is the repository that artifacts will be downloaded from\n   *\n   * @default - ${{ github.repository }}\n   */\n  readonly repository?: string;\n\n  /**\n   * The id of the workflow run where the desired download artifact was uploaded from\n   * If github-token is specified, this is the run that artifacts will be downloaded from\n   *\n   * @default - ${{ github.run_id }}\n   */\n  readonly runId?: string;\n}\n\nexport interface DownloadArtifactOptions extends JobStepConfiguration {\n  /**\n   * Options for `download-artifact`.\n   */\n  readonly with: DownloadArtifactWith;\n}\n"]}