projen
Version:
CDK for software projects
153 lines • 24.9 kB
JavaScript
;
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",
shell: "bash",
}),
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.95.2" };
//# 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        shell: \"bash\",\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"]}