projen 0.78.9 → 0.78.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (146) hide show
  1. package/.jsii +1126 -555
  2. package/lib/awscdk/auto-discover.js +5 -5
  3. package/lib/awscdk/awscdk-app-java.js +1 -1
  4. package/lib/awscdk/awscdk-app-py.js +1 -1
  5. package/lib/awscdk/awscdk-app-ts.js +1 -1
  6. package/lib/awscdk/awscdk-construct.js +2 -2
  7. package/lib/awscdk/awscdk-deps-java.js +1 -1
  8. package/lib/awscdk/awscdk-deps-js.js +1 -1
  9. package/lib/awscdk/awscdk-deps-py.js +1 -1
  10. package/lib/awscdk/awscdk-deps.js +1 -1
  11. package/lib/awscdk/cdk-config.js +1 -1
  12. package/lib/awscdk/cdk-tasks.js +1 -1
  13. package/lib/awscdk/integration-test.js +1 -1
  14. package/lib/awscdk/lambda-extension.js +1 -1
  15. package/lib/awscdk/lambda-function.js +2 -2
  16. package/lib/build/build-workflow.js +4 -6
  17. package/lib/cdk/auto-discover-base.js +2 -2
  18. package/lib/cdk/construct-lib.js +1 -1
  19. package/lib/cdk/integration-test-base.js +1 -1
  20. package/lib/cdk/jsii-docgen.js +1 -1
  21. package/lib/cdk/jsii-project.js +1 -1
  22. package/lib/cdk8s/auto-discover.js +2 -2
  23. package/lib/cdk8s/cdk8s-app-py.js +1 -1
  24. package/lib/cdk8s/cdk8s-app-ts.js +1 -1
  25. package/lib/cdk8s/cdk8s-construct.js +1 -1
  26. package/lib/cdk8s/cdk8s-deps-py.js +1 -1
  27. package/lib/cdk8s/cdk8s-deps.js +1 -1
  28. package/lib/cdk8s/integration-test.js +1 -1
  29. package/lib/cdktf/cdktf-construct.js +1 -1
  30. package/lib/circleci/circleci.js +1 -1
  31. package/lib/component.js +1 -1
  32. package/lib/dependencies.js +1 -1
  33. package/lib/dev-env.js +1 -1
  34. package/lib/docker-compose/docker-compose-service.js +1 -1
  35. package/lib/docker-compose/docker-compose.js +1 -1
  36. package/lib/file.js +1 -1
  37. package/lib/gitattributes.js +1 -1
  38. package/lib/github/actions-provider.js +1 -1
  39. package/lib/github/auto-approve.js +1 -1
  40. package/lib/github/auto-merge.js +1 -1
  41. package/lib/github/dependabot.js +1 -1
  42. package/lib/github/github-credentials.js +1 -1
  43. package/lib/github/github-project.js +1 -1
  44. package/lib/github/github.js +1 -1
  45. package/lib/github/index.d.ts +1 -0
  46. package/lib/github/index.js +2 -1
  47. package/lib/github/mergify.js +1 -1
  48. package/lib/github/pr-template.js +1 -1
  49. package/lib/github/pull-request-lint.js +1 -1
  50. package/lib/github/stale.js +1 -1
  51. package/lib/github/task-workflow-job.d.ts +132 -0
  52. package/lib/github/task-workflow-job.js +98 -0
  53. package/lib/github/task-workflow.d.ts +6 -85
  54. package/lib/github/task-workflow.js +7 -51
  55. package/lib/github/workflow-actions.js +4 -5
  56. package/lib/github/workflow-jobs.js +1 -1
  57. package/lib/github/workflow-steps.d.ts +51 -18
  58. package/lib/github/workflow-steps.js +26 -5
  59. package/lib/github/workflows-model.d.ts +35 -14
  60. package/lib/github/workflows-model.js +1 -1
  61. package/lib/github/workflows.js +1 -1
  62. package/lib/gitlab/configuration.js +1 -1
  63. package/lib/gitlab/gitlab-configuration.js +1 -1
  64. package/lib/gitlab/nested-configuration.js +1 -1
  65. package/lib/gitpod.js +1 -1
  66. package/lib/ignore-file.js +1 -1
  67. package/lib/ini.js +1 -1
  68. package/lib/java/java-project.js +1 -1
  69. package/lib/java/junit.js +1 -1
  70. package/lib/java/maven-compile.js +1 -1
  71. package/lib/java/maven-packaging.js +1 -1
  72. package/lib/java/maven-sample.js +1 -1
  73. package/lib/java/pom.js +1 -1
  74. package/lib/java/projenrc.js +1 -1
  75. package/lib/javascript/bundler.js +1 -1
  76. package/lib/javascript/eslint.js +1 -1
  77. package/lib/javascript/jest.js +4 -4
  78. package/lib/javascript/license-checker.js +1 -1
  79. package/lib/javascript/node-package.js +1 -1
  80. package/lib/javascript/node-project.d.ts +12 -2
  81. package/lib/javascript/node-project.js +17 -4
  82. package/lib/javascript/npm-config.js +1 -1
  83. package/lib/javascript/prettier.js +1 -1
  84. package/lib/javascript/projenrc.js +1 -1
  85. package/lib/javascript/typescript-config.js +2 -2
  86. package/lib/javascript/upgrade-dependencies.js +2 -2
  87. package/lib/javascript/yarnrc.js +1 -1
  88. package/lib/json-patch.js +1 -1
  89. package/lib/json.js +1 -1
  90. package/lib/license.js +1 -1
  91. package/lib/logger.js +1 -1
  92. package/lib/makefile.js +1 -1
  93. package/lib/object-file.js +1 -1
  94. package/lib/project-build.js +1 -1
  95. package/lib/project-tree.js +1 -1
  96. package/lib/project.js +8 -4
  97. package/lib/projects.js +1 -1
  98. package/lib/projenrc-json.js +2 -2
  99. package/lib/projenrc.js +1 -1
  100. package/lib/python/pip.js +1 -1
  101. package/lib/python/poetry.js +2 -2
  102. package/lib/python/projenrc.js +1 -1
  103. package/lib/python/pytest-sample.js +1 -1
  104. package/lib/python/pytest.js +1 -1
  105. package/lib/python/python-project.js +1 -1
  106. package/lib/python/python-sample.js +1 -1
  107. package/lib/python/requirements-file.js +1 -1
  108. package/lib/python/setuppy.js +1 -1
  109. package/lib/python/setuptools.js +1 -1
  110. package/lib/python/venv.js +1 -1
  111. package/lib/readme.js +1 -1
  112. package/lib/release/publisher.js +1 -1
  113. package/lib/release/release-trigger.js +1 -1
  114. package/lib/release/release.d.ts +9 -4
  115. package/lib/release/release.js +55 -26
  116. package/lib/renovatebot.js +1 -1
  117. package/lib/runner-options.d.ts +1 -1
  118. package/lib/runner-options.js +1 -1
  119. package/lib/sample-file.js +2 -2
  120. package/lib/semver.js +1 -1
  121. package/lib/source-code.js +1 -1
  122. package/lib/task-runtime.js +1 -1
  123. package/lib/task.js +1 -1
  124. package/lib/tasks.js +1 -1
  125. package/lib/testing.js +1 -1
  126. package/lib/textfile.js +1 -1
  127. package/lib/toml.js +1 -1
  128. package/lib/typescript/projenrc-ts.js +1 -1
  129. package/lib/typescript/projenrc.js +3 -2
  130. package/lib/typescript/typescript-typedoc.js +1 -1
  131. package/lib/typescript/typescript.js +6 -6
  132. package/lib/util/path.d.ts +8 -0
  133. package/lib/util/path.js +21 -0
  134. package/lib/version.js +2 -2
  135. package/lib/vscode/devcontainer.js +1 -1
  136. package/lib/vscode/extensions.js +1 -1
  137. package/lib/vscode/launch-config.js +1 -1
  138. package/lib/vscode/settings.js +1 -1
  139. package/lib/vscode/vscode.js +1 -1
  140. package/lib/web/next.js +3 -3
  141. package/lib/web/postcss.js +1 -1
  142. package/lib/web/react.js +4 -4
  143. package/lib/web/tailwind.js +1 -1
  144. package/lib/xmlfile.js +1 -1
  145. package/lib/yaml.js +1 -1
  146. package/package.json +1 -1
@@ -0,0 +1,132 @@
1
+ import { IConstruct } from "constructs";
2
+ import { GitIdentity } from "./task-workflow";
3
+ import { CheckoutWith } from "./workflow-steps";
4
+ import { ContainerOptions, Job, JobDefaults, JobPermissions, JobStep, JobStepOutput, JobStrategy, Tools } from "./workflows-model";
5
+ import { Component } from "../component";
6
+ import { GroupRunnerOptions } from "../runner-options";
7
+ import { Task } from "../task";
8
+ /**
9
+ * Options to create the Job associated with a TaskWorkflow.
10
+ */
11
+ export interface TaskWorkflowJobOptions {
12
+ /**
13
+ * @default - default image
14
+ */
15
+ readonly container?: ContainerOptions;
16
+ /**
17
+ * Adds an 'if' condition to the workflow.
18
+ */
19
+ readonly condition?: string;
20
+ /**
21
+ * A directory name which contains artifacts to be uploaded (e.g. `dist`).
22
+ * If this is set, the contents of this directory will be uploaded as an
23
+ * artifact at the end of the workflow run, even if other steps fail.
24
+ *
25
+ * @default - not set
26
+ */
27
+ readonly artifactsDirectory?: string;
28
+ /**
29
+ * Initial steps to run before the source code checkout.
30
+ *
31
+ * @default - not set
32
+ */
33
+ readonly preCheckoutSteps?: JobStep[];
34
+ /**
35
+ * Override for the `with` property of the source code checkout step.
36
+ *
37
+ * @default - not set
38
+ */
39
+ readonly checkoutWith?: CheckoutWith;
40
+ /**
41
+ * Steps to run before the main build step.
42
+ *
43
+ * @default - not set
44
+ */
45
+ readonly preBuildSteps?: JobStep[];
46
+ /**
47
+ * Actions to run after the main build step.
48
+ *
49
+ * @default - not set
50
+ */
51
+ readonly postBuildSteps?: JobStep[];
52
+ /**
53
+ * Workflow environment variables.
54
+ * @default {}
55
+ */
56
+ readonly env?: Record<string, string>;
57
+ /**
58
+ * Permissions for the build job.
59
+ */
60
+ readonly permissions: JobPermissions;
61
+ /**
62
+ * Mapping of job output names to values/expressions.
63
+ *
64
+ * @default {}
65
+ */
66
+ readonly outputs?: {
67
+ [name: string]: JobStepOutput;
68
+ };
69
+ /**
70
+ * The git identity to use in this workflow.
71
+ */
72
+ readonly gitIdentity?: GitIdentity;
73
+ /**
74
+ * Github Runner selection labels
75
+ * @default ["ubuntu-latest"]
76
+ * @description Defines a target Runner by labels
77
+ * @throws {Error} if both `runsOn` and `runsOnGroup` are specified
78
+ */
79
+ readonly runsOn?: string[];
80
+ /**
81
+ * Github Runner Group selection options
82
+ * @description Defines a target Runner Group by name and/or labels
83
+ * @throws {Error} if both `runsOn` and `runsOnGroup` are specified
84
+ */
85
+ readonly runsOnGroup?: GroupRunnerOptions;
86
+ /**
87
+ * Whether to download files from Git LFS for this workflow
88
+ *
89
+ * @default - Use the setting on the corresponding GitHub project
90
+ */
91
+ readonly downloadLfs?: boolean;
92
+ /**
93
+ * Default settings for all steps in the TaskWorkflow Job.
94
+ */
95
+ readonly jobDefaults?: JobDefaults;
96
+ }
97
+ /**
98
+ * The primary or initial job of a TaskWorkflow.
99
+ *
100
+ * @implements {Job}
101
+ */
102
+ export declare class TaskWorkflowJob extends Component {
103
+ readonly runsOn?: string[] | undefined;
104
+ readonly runsOnGroup?: GroupRunnerOptions | undefined;
105
+ readonly steps: JobStep[];
106
+ readonly environment?: unknown;
107
+ readonly outputs?: Record<string, JobStepOutput> | undefined;
108
+ readonly env?: Record<string, string> | undefined;
109
+ readonly defaults?: JobDefaults | undefined;
110
+ readonly timeoutMinutes?: number | undefined;
111
+ readonly continueOnError?: boolean | undefined;
112
+ readonly container?: ContainerOptions | undefined;
113
+ readonly services?: Record<string, ContainerOptions> | undefined;
114
+ readonly tools?: Tools | undefined;
115
+ readonly name?: string | undefined;
116
+ readonly needs?: string[] | undefined;
117
+ readonly permissions: JobPermissions;
118
+ readonly concurrency?: unknown;
119
+ readonly if?: string | undefined;
120
+ readonly strategy?: JobStrategy | undefined;
121
+ /**
122
+ * @param scope should be part of the project the Task belongs to.
123
+ * @param task the main task that is run as part of this job.
124
+ * @param options options to configure the TaskWorkflowJob.
125
+ */
126
+ constructor(scope: IConstruct, task: Task, options: TaskWorkflowJobOptions);
127
+ /**
128
+ * @jsii ignore
129
+ * @internal
130
+ */
131
+ toJSON(): Job;
132
+ }
@@ -0,0 +1,98 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.TaskWorkflowJob = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const constants_1 = require("./constants");
7
+ const workflow_steps_1 = require("./workflow-steps");
8
+ const component_1 = require("../component");
9
+ const runner_options_1 = require("../runner-options");
10
+ /**
11
+ * The primary or initial job of a TaskWorkflow.
12
+ *
13
+ * @implements {Job}
14
+ */
15
+ class TaskWorkflowJob extends component_1.Component {
16
+ /**
17
+ * @param scope should be part of the project the Task belongs to.
18
+ * @param task the main task that is run as part of this job.
19
+ * @param options options to configure the TaskWorkflowJob.
20
+ */
21
+ constructor(scope, task, options) {
22
+ super(scope, `${new.target.name}#${task.name}`);
23
+ const preCheckoutSteps = options.preCheckoutSteps ?? [];
24
+ const checkoutWith = {};
25
+ if (options.downloadLfs) {
26
+ checkoutWith.lfs = true;
27
+ }
28
+ // 'checkoutWith' can override 'lfs'
29
+ Object.assign(checkoutWith, options.checkoutWith ?? {});
30
+ const preBuildSteps = options.preBuildSteps ?? [];
31
+ const postBuildSteps = options.postBuildSteps ?? [];
32
+ const gitIdentity = options.gitIdentity ?? constants_1.DEFAULT_GITHUB_ACTIONS_USER;
33
+ if (options.artifactsDirectory) {
34
+ postBuildSteps.push(workflow_steps_1.WorkflowSteps.uploadArtifact({
35
+ // Setting to always will ensure that this step will run even if
36
+ // the previous ones have failed (e.g. coverage report, internal logs, etc)
37
+ if: "always()",
38
+ with: {
39
+ name: options.artifactsDirectory,
40
+ path: options.artifactsDirectory,
41
+ },
42
+ }));
43
+ }
44
+ const runsOnInputs = (0, runner_options_1.filteredRunsOnOptions)(options.runsOn, options.runsOnGroup);
45
+ this.runsOn = runsOnInputs?.runsOn;
46
+ this.runsOnGroup = runsOnInputs?.runsOnGroup;
47
+ this.container = options.container;
48
+ this.env = options.env;
49
+ this.permissions = options.permissions;
50
+ this.defaults = options?.jobDefaults;
51
+ this.if = options.condition;
52
+ this.outputs = options.outputs;
53
+ this.steps = [
54
+ ...preCheckoutSteps,
55
+ // check out sources.
56
+ workflow_steps_1.WorkflowSteps.checkout({ with: checkoutWith }),
57
+ // sets git identity so we can push later
58
+ workflow_steps_1.WorkflowSteps.setupGitIdentity({ gitIdentity }),
59
+ ...preBuildSteps,
60
+ // run the main build task
61
+ {
62
+ name: task.name,
63
+ run: this.project.runTaskCommand(task),
64
+ },
65
+ ...postBuildSteps,
66
+ ];
67
+ }
68
+ /**
69
+ * @jsii ignore
70
+ * @internal
71
+ */
72
+ toJSON() {
73
+ return {
74
+ runsOn: this.runsOn,
75
+ runsOnGroup: this.runsOnGroup,
76
+ steps: this.steps,
77
+ environment: this.environment,
78
+ outputs: this.outputs,
79
+ env: this.env,
80
+ defaults: this.defaults,
81
+ timeoutMinutes: this.timeoutMinutes,
82
+ continueOnError: this.continueOnError,
83
+ container: this.container,
84
+ services: this.services,
85
+ tools: this.tools,
86
+ name: this.name,
87
+ needs: this.needs,
88
+ permissions: this.permissions,
89
+ concurrency: this.concurrency,
90
+ if: this.if,
91
+ strategy: this.strategy,
92
+ };
93
+ }
94
+ }
95
+ exports.TaskWorkflowJob = TaskWorkflowJob;
96
+ _a = JSII_RTTI_SYMBOL_1;
97
+ TaskWorkflowJob[_a] = { fqn: "projen.github.TaskWorkflowJob", version: "0.78.11" };
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-workflow-job.js","sourceRoot":"","sources":["../../src/github/task-workflow-job.ts"],"names":[],"mappings":"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","sourcesContent":["import { IConstruct } from \"constructs\";\nimport { DEFAULT_GITHUB_ACTIONS_USER } from \"./constants\";\nimport { GitIdentity } from \"./task-workflow\";\nimport { CheckoutWith, WorkflowSteps } from \"./workflow-steps\";\nimport {\n  ContainerOptions,\n  Job,\n  JobDefaults,\n  JobPermissions,\n  JobStep,\n  JobStepOutput,\n  JobStrategy,\n  Tools,\n} from \"./workflows-model\";\nimport { Component } from \"../component\";\nimport { GroupRunnerOptions, filteredRunsOnOptions } from \"../runner-options\";\nimport { Task } from \"../task\";\n\n/**\n * Options to create the Job associated with a TaskWorkflow.\n */\nexport interface TaskWorkflowJobOptions {\n  /**\n   * @default - default image\n   */\n  readonly container?: ContainerOptions;\n\n  /**\n   * Adds an 'if' condition to the workflow.\n   */\n  readonly condition?: string;\n\n  /**\n   * A directory name which contains artifacts to be uploaded (e.g. `dist`).\n   * If this is set, the contents of this directory will be uploaded as an\n   * artifact at the end of the workflow run, even if other steps fail.\n   *\n   * @default - not set\n   */\n  readonly artifactsDirectory?: string;\n\n  /**\n   * Initial steps to run before the source code checkout.\n   *\n   * @default - not set\n   */\n  readonly preCheckoutSteps?: JobStep[];\n\n  /**\n   * Override for the `with` property of the source code checkout step.\n   *\n   * @default - not set\n   */\n  readonly checkoutWith?: CheckoutWith;\n\n  /**\n   * Steps to run before the main build step.\n   *\n   * @default - not set\n   */\n  readonly preBuildSteps?: JobStep[];\n\n  /**\n   * Actions to run after the main build step.\n   *\n   * @default - not set\n   */\n  readonly postBuildSteps?: JobStep[];\n\n  /**\n   * Workflow environment variables.\n   * @default {}\n   */\n  readonly env?: Record<string, string>;\n\n  /**\n   * Permissions for the build job.\n   */\n  readonly permissions: JobPermissions;\n\n  /**\n   * Mapping of job output names to values/expressions.\n   *\n   * @default {}\n   */\n  readonly outputs?: { [name: string]: JobStepOutput };\n\n  /**\n   * The git identity to use in this workflow.\n   */\n  readonly gitIdentity?: GitIdentity;\n\n  /**\n   * Github Runner selection labels\n   * @default [\"ubuntu-latest\"]\n   * @description Defines a target Runner by labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly runsOn?: string[];\n\n  /**\n   * Github Runner Group selection options\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly runsOnGroup?: GroupRunnerOptions;\n\n  /**\n   * Whether to download files from Git LFS for this workflow\n   *\n   * @default - Use the setting on the corresponding GitHub project\n   */\n  readonly downloadLfs?: boolean;\n\n  /**\n   * Default settings for all steps in the TaskWorkflow Job.\n   */\n  readonly jobDefaults?: JobDefaults;\n}\n\n/**\n * The primary or initial job of a TaskWorkflow.\n *\n * @implements {Job}\n */\nexport class TaskWorkflowJob extends Component {\n  public readonly runsOn?: string[] | undefined;\n  public readonly runsOnGroup?: GroupRunnerOptions | undefined;\n  public readonly steps: JobStep[];\n  public readonly environment?: unknown;\n  public readonly outputs?: Record<string, JobStepOutput> | undefined;\n  public readonly env?: Record<string, string> | undefined;\n  public readonly defaults?: JobDefaults | undefined;\n  public readonly timeoutMinutes?: number | undefined;\n  public readonly continueOnError?: boolean | undefined;\n  public readonly container?: ContainerOptions | undefined;\n  public readonly services?: Record<string, ContainerOptions> | undefined;\n  public readonly tools?: Tools | undefined;\n  public readonly name?: string | undefined;\n  public readonly needs?: string[] | undefined;\n  public readonly permissions: JobPermissions;\n  public readonly concurrency?: unknown;\n  public readonly if?: string | undefined;\n  public readonly strategy?: JobStrategy | undefined;\n\n  /**\n   * @param scope should be part of the project the Task belongs to.\n   * @param task the main task that is run as part of this job.\n   * @param options options to configure the TaskWorkflowJob.\n   */\n  constructor(scope: IConstruct, task: Task, options: TaskWorkflowJobOptions) {\n    super(scope, `${new.target.name}#${task.name}`);\n    const preCheckoutSteps = options.preCheckoutSteps ?? [];\n\n    const checkoutWith: { lfs?: boolean } = {};\n    if (options.downloadLfs) {\n      checkoutWith.lfs = true;\n    }\n    // 'checkoutWith' can override 'lfs'\n    Object.assign(checkoutWith, options.checkoutWith ?? {});\n\n    const preBuildSteps = options.preBuildSteps ?? [];\n    const postBuildSteps = options.postBuildSteps ?? [];\n    const gitIdentity = options.gitIdentity ?? DEFAULT_GITHUB_ACTIONS_USER;\n\n    if (options.artifactsDirectory) {\n      postBuildSteps.push(\n        WorkflowSteps.uploadArtifact({\n          // Setting to always will ensure that this step will run even if\n          // the previous ones have failed (e.g. coverage report, internal logs, etc)\n          if: \"always()\",\n          with: {\n            name: options.artifactsDirectory,\n            path: options.artifactsDirectory,\n          },\n        })\n      );\n    }\n\n    const runsOnInputs = filteredRunsOnOptions(\n      options.runsOn,\n      options.runsOnGroup\n    );\n    this.runsOn = (runsOnInputs as { runsOn: string[] })?.runsOn;\n    this.runsOnGroup = (\n      runsOnInputs as { runsOnGroup: GroupRunnerOptions }\n    )?.runsOnGroup;\n    this.container = options.container;\n    this.env = options.env;\n    this.permissions = options.permissions;\n    this.defaults = options?.jobDefaults;\n    this.if = options.condition;\n    this.outputs = options.outputs;\n    this.steps = [\n      ...preCheckoutSteps,\n\n      // check out sources.\n      WorkflowSteps.checkout({ with: checkoutWith }),\n\n      // sets git identity so we can push later\n      WorkflowSteps.setupGitIdentity({ gitIdentity }),\n\n      ...preBuildSteps,\n\n      // run the main build task\n      {\n        name: task.name,\n        run: this.project.runTaskCommand(task),\n      },\n\n      ...postBuildSteps,\n    ];\n  }\n\n  /**\n   * @jsii ignore\n   * @internal\n   */\n  public toJSON(): Job {\n    return {\n      runsOn: this.runsOn,\n      runsOnGroup: this.runsOnGroup,\n      steps: this.steps,\n      environment: this.environment,\n      outputs: this.outputs,\n      env: this.env,\n      defaults: this.defaults,\n      timeoutMinutes: this.timeoutMinutes,\n      continueOnError: this.continueOnError,\n      container: this.container,\n      services: this.services,\n      tools: this.tools,\n      name: this.name,\n      needs: this.needs,\n      permissions: this.permissions,\n      concurrency: this.concurrency,\n      if: this.if,\n      strategy: this.strategy,\n    };\n  }\n}\n"]}
@@ -1,10 +1,12 @@
1
1
  import { GitHub } from "./github";
2
- import { CheckoutWith } from "./workflow-steps";
2
+ import { TaskWorkflowJobOptions } from "./task-workflow-job";
3
3
  import { GithubWorkflow } from "./workflows";
4
- import { ContainerOptions, JobPermissions, JobStep, JobStepOutput, Triggers } from "./workflows-model";
5
- import { GroupRunnerOptions } from "../runner-options";
4
+ import { Triggers } from "./workflows-model";
6
5
  import { Task } from "../task";
7
- export interface TaskWorkflowOptions {
6
+ /**
7
+ * Options to create a TaskWorkflow.
8
+ */
9
+ export interface TaskWorkflowOptions extends TaskWorkflowJobOptions {
8
10
  /**
9
11
  * The workflow name.
10
12
  */
@@ -14,102 +16,21 @@ export interface TaskWorkflowOptions {
14
16
  * @default "build"
15
17
  */
16
18
  readonly jobId?: string;
17
- /**
18
- * @default - default image
19
- */
20
- readonly container?: ContainerOptions;
21
- /**
22
- * Adds an 'if' condition to the workflow.
23
- */
24
- readonly condition?: string;
25
- /**
26
- * A directory name which contains artifacts to be uploaded (e.g. `dist`).
27
- * If this is set, the contents of this directory will be uploaded as an
28
- * artifact at the end of the workflow run, even if other steps fail.
29
- *
30
- * @default - not set
31
- */
32
- readonly artifactsDirectory?: string;
33
19
  /**
34
20
  * The triggers for the workflow.
35
21
  *
36
22
  * @default - by default workflows can only be triggered by manually.
37
23
  */
38
24
  readonly triggers?: Triggers;
39
- /**
40
- * Initial steps to run before the source code checkout.
41
- *
42
- * @default - not set
43
- */
44
- readonly preCheckoutSteps?: JobStep[];
45
- /**
46
- * Override for the `with` property of the source code checkout step.
47
- *
48
- * @default - not set
49
- */
50
- readonly checkoutWith?: CheckoutWith;
51
- /**
52
- * Steps to run before the main build step.
53
- *
54
- * @default - not set
55
- */
56
- readonly preBuildSteps?: JobStep[];
57
25
  /**
58
26
  * The main task to be executed.
59
27
  */
60
28
  readonly task: Task;
61
- /**
62
- * Actions to run after the main build step.
63
- *
64
- * @default - not set
65
- */
66
- readonly postBuildSteps?: JobStep[];
67
- /**
68
- * Workflow environment variables.
69
- * @default {}
70
- */
71
- readonly env?: Record<string, string>;
72
- /**
73
- * Permissions for the build job.
74
- */
75
- readonly permissions: JobPermissions;
76
- /**
77
- * Mapping of job output names to values/expressions.
78
- *
79
- * @default {}
80
- */
81
- readonly outputs?: {
82
- [name: string]: JobStepOutput;
83
- };
84
- /**
85
- * The git identity to use in this workflow.
86
- */
87
- readonly gitIdentity?: GitIdentity;
88
- /**
89
- * Github Runner selection labels
90
- * @default ["ubuntu-latest"]
91
- * @description Defines a target Runner by labels
92
- * @throws {Error} if both `runsOn` and `runsOnGroup` are specified
93
- */
94
- readonly runsOn?: string[];
95
- /**
96
- * Github Runner Group selection options
97
- * @description Defines a target Runner Group by name and/or labels
98
- * @throws {Error} if both `runsOn` and `runsOnGroup` are specified
99
- */
100
- readonly runsOnGroup?: GroupRunnerOptions;
101
- /**
102
- * Whether to download files from Git LFS for this workflow
103
- *
104
- * @default - Use the setting on the corresponding GitHub project
105
- */
106
- readonly downloadLfs?: boolean;
107
29
  }
108
30
  /**
109
31
  * A GitHub workflow for common build tasks within a project.
110
32
  */
111
33
  export declare class TaskWorkflow extends GithubWorkflow {
112
- private readonly github;
113
34
  readonly jobId: string;
114
35
  readonly artifactsDirectory?: string;
115
36
  constructor(github: GitHub, options: TaskWorkflowOptions);
@@ -3,10 +3,8 @@ var _a;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.TaskWorkflow = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
- const constants_1 = require("./constants");
7
- const workflow_steps_1 = require("./workflow-steps");
6
+ const task_workflow_job_1 = require("./task-workflow-job");
8
7
  const workflows_1 = require("./workflows");
9
- const runner_options_1 = require("../runner-options");
10
8
  const DEFAULT_JOB_ID = "build";
11
9
  /**
12
10
  * A GitHub workflow for common build tasks within a project.
@@ -15,7 +13,6 @@ class TaskWorkflow extends workflows_1.GithubWorkflow {
15
13
  constructor(github, options) {
16
14
  super(github, options.name);
17
15
  this.jobId = options.jobId ?? DEFAULT_JOB_ID;
18
- this.github = github;
19
16
  this.artifactsDirectory = options.artifactsDirectory;
20
17
  if (options.triggers) {
21
18
  if (options.triggers.issueComment) {
@@ -27,55 +24,14 @@ class TaskWorkflow extends workflows_1.GithubWorkflow {
27
24
  this.on({
28
25
  workflowDispatch: {}, // allow manual triggering
29
26
  });
30
- const preCheckoutSteps = options.preCheckoutSteps ?? [];
31
- const checkoutWith = {};
32
- if (options.downloadLfs ?? github.downloadLfs) {
33
- checkoutWith.lfs = true;
34
- }
35
- // 'checkoutWith' can override 'lfs'
36
- Object.assign(checkoutWith, options.checkoutWith ?? {});
37
- const preBuildSteps = options.preBuildSteps ?? [];
38
- const postBuildSteps = options.postBuildSteps ?? [];
39
- const gitIdentity = options.gitIdentity ?? constants_1.DEFAULT_GITHUB_ACTIONS_USER;
40
- if (this.artifactsDirectory) {
41
- postBuildSteps.push({
42
- name: "Upload artifact",
43
- uses: "actions/upload-artifact@v3",
44
- // Setting to always will ensure that this step will run even if
45
- // the previous ones have failed (e.g. coverage report, internal logs, etc)
46
- if: "always()",
47
- with: {
48
- name: this.artifactsDirectory,
49
- path: this.artifactsDirectory,
50
- },
51
- });
52
- }
53
- const job = {
54
- ...(0, runner_options_1.filteredRunsOnOptions)(options.runsOn, options.runsOnGroup),
55
- container: options.container,
56
- env: options.env,
57
- permissions: options.permissions,
58
- if: options.condition,
59
- outputs: options.outputs,
60
- steps: [
61
- ...preCheckoutSteps,
62
- // check out sources.
63
- workflow_steps_1.WorkflowSteps.checkout({ with: checkoutWith }),
64
- // sets git identity so we can push later
65
- workflow_steps_1.WorkflowSteps.setupGitIdentity({ gitIdentity }),
66
- ...preBuildSteps,
67
- // run the main build task
68
- {
69
- name: options.task.name,
70
- run: this.github.project.runTaskCommand(options.task),
71
- },
72
- ...postBuildSteps,
73
- ],
74
- };
27
+ const job = new task_workflow_job_1.TaskWorkflowJob(this, options.task, {
28
+ ...options,
29
+ downloadLfs: options.downloadLfs ?? github.downloadLfs,
30
+ });
75
31
  this.addJobs({ [this.jobId]: job });
76
32
  }
77
33
  }
78
34
  exports.TaskWorkflow = TaskWorkflow;
79
35
  _a = JSII_RTTI_SYMBOL_1;
80
- TaskWorkflow[_a] = { fqn: "projen.github.TaskWorkflow", version: "0.78.9" };
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-workflow.js","sourceRoot":"","sources":["../../src/github/task-workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import { DEFAULT_GITHUB_ACTIONS_USER } from \"./constants\";\nimport { GitHub } from \"./github\";\nimport { CheckoutWith, WorkflowSteps } from \"./workflow-steps\";\nimport { GithubWorkflow } from \"./workflows\";\nimport {\n  ContainerOptions,\n  Job,\n  JobPermissions,\n  JobStep,\n  JobStepOutput,\n  Triggers,\n} from \"./workflows-model\";\nimport { GroupRunnerOptions, filteredRunsOnOptions } from \"../runner-options\";\nimport { Task } from \"../task\";\n\nconst DEFAULT_JOB_ID = \"build\";\n\nexport interface TaskWorkflowOptions {\n  /**\n   * The workflow name.\n   */\n  readonly name: string;\n\n  /**\n   * The primary job id.\n   * @default \"build\"\n   */\n  readonly jobId?: string;\n\n  /**\n   * @default - default image\n   */\n  readonly container?: ContainerOptions;\n\n  /**\n   * Adds an 'if' condition to the workflow.\n   */\n  readonly condition?: string;\n\n  /**\n   * A directory name which contains artifacts to be uploaded (e.g. `dist`).\n   * If this is set, the contents of this directory will be uploaded as an\n   * artifact at the end of the workflow run, even if other steps fail.\n   *\n   * @default - not set\n   */\n  readonly artifactsDirectory?: string;\n\n  /**\n   * The triggers for the workflow.\n   *\n   * @default - by default workflows can only be triggered by manually.\n   */\n  readonly triggers?: Triggers;\n\n  /**\n   * Initial steps to run before the source code checkout.\n   *\n   * @default - not set\n   */\n  readonly preCheckoutSteps?: JobStep[];\n\n  /**\n   * Override for the `with` property of the source code checkout step.\n   *\n   * @default - not set\n   */\n  readonly checkoutWith?: CheckoutWith;\n\n  /**\n   * Steps to run before the main build step.\n   *\n   * @default - not set\n   */\n  readonly preBuildSteps?: JobStep[];\n\n  /**\n   * The main task to be executed.\n   */\n  readonly task: Task;\n\n  /**\n   * Actions to run after the main build step.\n   *\n   * @default - not set\n   */\n  readonly postBuildSteps?: JobStep[];\n\n  /**\n   * Workflow environment variables.\n   * @default {}\n   */\n  readonly env?: Record<string, string>;\n\n  /**\n   * Permissions for the build job.\n   */\n  readonly permissions: JobPermissions;\n\n  /**\n   * Mapping of job output names to values/expressions.\n   *\n   * @default {}\n   */\n  readonly outputs?: { [name: string]: JobStepOutput };\n\n  /**\n   * The git identity to use in this workflow.\n   */\n  readonly gitIdentity?: GitIdentity;\n\n  /**\n   * Github Runner selection labels\n   * @default [\"ubuntu-latest\"]\n   * @description Defines a target Runner by labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly runsOn?: string[];\n\n  /**\n   * Github Runner Group selection options\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly runsOnGroup?: GroupRunnerOptions;\n\n  /**\n   * Whether to download files from Git LFS for this workflow\n   *\n   * @default - Use the setting on the corresponding GitHub project\n   */\n  readonly downloadLfs?: boolean;\n}\n\n/**\n * A GitHub workflow for common build tasks within a project.\n */\nexport class TaskWorkflow extends GithubWorkflow {\n  private readonly github: GitHub;\n  public readonly jobId: string;\n  public readonly artifactsDirectory?: string;\n\n  constructor(github: GitHub, options: TaskWorkflowOptions) {\n    super(github, options.name);\n    this.jobId = options.jobId ?? DEFAULT_JOB_ID;\n    this.github = github;\n    this.artifactsDirectory = options.artifactsDirectory;\n\n    if (options.triggers) {\n      if (options.triggers.issueComment) {\n        // https://docs.github.com/en/actions/learn-github-actions/security-hardening-for-github-actions#potential-impact-of-a-compromised-runner\n        throw new Error(\n          'Trigger \"issueComment\" should not be used due to a security concern'\n        );\n      }\n\n      this.on(options.triggers);\n    }\n\n    this.on({\n      workflowDispatch: {}, // allow manual triggering\n    });\n\n    const preCheckoutSteps = options.preCheckoutSteps ?? [];\n\n    const checkoutWith: { lfs?: boolean } = {};\n    if (options.downloadLfs ?? github.downloadLfs) {\n      checkoutWith.lfs = true;\n    }\n    // 'checkoutWith' can override 'lfs'\n    Object.assign(checkoutWith, options.checkoutWith ?? {});\n\n    const preBuildSteps = options.preBuildSteps ?? [];\n    const postBuildSteps = options.postBuildSteps ?? [];\n    const gitIdentity = options.gitIdentity ?? DEFAULT_GITHUB_ACTIONS_USER;\n\n    if (this.artifactsDirectory) {\n      postBuildSteps.push({\n        name: \"Upload artifact\",\n        uses: \"actions/upload-artifact@v3\",\n        // Setting to always will ensure that this step will run even if\n        // the previous ones have failed (e.g. coverage report, internal logs, etc)\n        if: \"always()\",\n        with: {\n          name: this.artifactsDirectory,\n          path: this.artifactsDirectory,\n        },\n      });\n    }\n\n    const job: Job = {\n      ...filteredRunsOnOptions(options.runsOn, options.runsOnGroup),\n      container: options.container,\n      env: options.env,\n      permissions: options.permissions,\n      if: options.condition,\n      outputs: options.outputs,\n      steps: [\n        ...preCheckoutSteps,\n\n        // check out sources.\n        WorkflowSteps.checkout({ with: checkoutWith }),\n\n        // sets git identity so we can push later\n        WorkflowSteps.setupGitIdentity({ gitIdentity }),\n\n        ...preBuildSteps,\n\n        // run the main build task\n        {\n          name: options.task.name,\n          run: this.github.project.runTaskCommand(options.task),\n        },\n\n        ...postBuildSteps,\n      ],\n    };\n\n    this.addJobs({ [this.jobId]: job });\n  }\n}\n\n/**\n * Represents the git identity.\n */\nexport interface GitIdentity {\n  /**\n   * The name of the user.\n   */\n  readonly name: string;\n\n  /**\n   * The email address of the git user.\n   */\n  readonly email: string;\n}\n"]}
36
+ TaskWorkflow[_a] = { fqn: "projen.github.TaskWorkflow", version: "0.78.11" };
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFzay13b3JrZmxvdy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9naXRodWIvdGFzay13b3JrZmxvdy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUNBLDJEQUE4RTtBQUM5RSwyQ0FBNkM7QUFJN0MsTUFBTSxjQUFjLEdBQUcsT0FBTyxDQUFDO0FBOEIvQjs7R0FFRztBQUNILE1BQWEsWUFBYSxTQUFRLDBCQUFjO0lBSTlDLFlBQVksTUFBYyxFQUFFLE9BQTRCO1FBQ3RELEtBQUssQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzVCLElBQUksQ0FBQyxLQUFLLEdBQUcsT0FBTyxDQUFDLEtBQUssSUFBSSxjQUFjLENBQUM7UUFDN0MsSUFBSSxDQUFDLGtCQUFrQixHQUFHLE9BQU8sQ0FBQyxrQkFBa0IsQ0FBQztRQUVyRCxJQUFJLE9BQU8sQ0FBQyxRQUFRLEVBQUU7WUFDcEIsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLFlBQVksRUFBRTtnQkFDakMseUlBQXlJO2dCQUN6SSxNQUFNLElBQUksS0FBSyxDQUNiLHFFQUFxRSxDQUN0RSxDQUFDO2FBQ0g7WUFFRCxJQUFJLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztTQUMzQjtRQUVELElBQUksQ0FBQyxFQUFFLENBQUM7WUFDTixnQkFBZ0IsRUFBRSxFQUFFLEVBQUUsMEJBQTBCO1NBQ2pELENBQUMsQ0FBQztRQUVILE1BQU0sR0FBRyxHQUFHLElBQUksbUNBQWUsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLElBQUksRUFBRTtZQUNsRCxHQUFHLE9BQU87WUFDVixXQUFXLEVBQUUsT0FBTyxDQUFDLFdBQVcsSUFBSSxNQUFNLENBQUMsV0FBVztTQUN2RCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUN0QyxDQUFDOztBQTlCSCxvQ0ErQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHaXRIdWIgfSBmcm9tIFwiLi9naXRodWJcIjtcbmltcG9ydCB7IFRhc2tXb3JrZmxvd0pvYiwgVGFza1dvcmtmbG93Sm9iT3B0aW9ucyB9IGZyb20gXCIuL3Rhc2std29ya2Zsb3ctam9iXCI7XG5pbXBvcnQgeyBHaXRodWJXb3JrZmxvdyB9IGZyb20gXCIuL3dvcmtmbG93c1wiO1xuaW1wb3J0IHsgVHJpZ2dlcnMgfSBmcm9tIFwiLi93b3JrZmxvd3MtbW9kZWxcIjtcbmltcG9ydCB7IFRhc2sgfSBmcm9tIFwiLi4vdGFza1wiO1xuXG5jb25zdCBERUZBVUxUX0pPQl9JRCA9IFwiYnVpbGRcIjtcblxuLyoqXG4gKiBPcHRpb25zIHRvIGNyZWF0ZSBhIFRhc2tXb3JrZmxvdy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUYXNrV29ya2Zsb3dPcHRpb25zIGV4dGVuZHMgVGFza1dvcmtmbG93Sm9iT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBUaGUgd29ya2Zsb3cgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHByaW1hcnkgam9iIGlkLlxuICAgKiBAZGVmYXVsdCBcImJ1aWxkXCJcbiAgICovXG4gIHJlYWRvbmx5IGpvYklkPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgdHJpZ2dlcnMgZm9yIHRoZSB3b3JrZmxvdy5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBieSBkZWZhdWx0IHdvcmtmbG93cyBjYW4gb25seSBiZSB0cmlnZ2VyZWQgYnkgbWFudWFsbHkuXG4gICAqL1xuICByZWFkb25seSB0cmlnZ2Vycz86IFRyaWdnZXJzO1xuXG4gIC8qKlxuICAgKiBUaGUgbWFpbiB0YXNrIHRvIGJlIGV4ZWN1dGVkLlxuICAgKi9cbiAgcmVhZG9ubHkgdGFzazogVGFzaztcbn1cblxuLyoqXG4gKiBBIEdpdEh1YiB3b3JrZmxvdyBmb3IgY29tbW9uIGJ1aWxkIHRhc2tzIHdpdGhpbiBhIHByb2plY3QuXG4gKi9cbmV4cG9ydCBjbGFzcyBUYXNrV29ya2Zsb3cgZXh0ZW5kcyBHaXRodWJXb3JrZmxvdyB7XG4gIHB1YmxpYyByZWFkb25seSBqb2JJZDogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgYXJ0aWZhY3RzRGlyZWN0b3J5Pzogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKGdpdGh1YjogR2l0SHViLCBvcHRpb25zOiBUYXNrV29ya2Zsb3dPcHRpb25zKSB7XG4gICAgc3VwZXIoZ2l0aHViLCBvcHRpb25zLm5hbWUpO1xuICAgIHRoaXMuam9iSWQgPSBvcHRpb25zLmpvYklkID8/IERFRkFVTFRfSk9CX0lEO1xuICAgIHRoaXMuYXJ0aWZhY3RzRGlyZWN0b3J5ID0gb3B0aW9ucy5hcnRpZmFjdHNEaXJlY3Rvcnk7XG5cbiAgICBpZiAob3B0aW9ucy50cmlnZ2Vycykge1xuICAgICAgaWYgKG9wdGlvbnMudHJpZ2dlcnMuaXNzdWVDb21tZW50KSB7XG4gICAgICAgIC8vIGh0dHBzOi8vZG9jcy5naXRodWIuY29tL2VuL2FjdGlvbnMvbGVhcm4tZ2l0aHViLWFjdGlvbnMvc2VjdXJpdHktaGFyZGVuaW5nLWZvci1naXRodWItYWN0aW9ucyNwb3RlbnRpYWwtaW1wYWN0LW9mLWEtY29tcHJvbWlzZWQtcnVubmVyXG4gICAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICAnVHJpZ2dlciBcImlzc3VlQ29tbWVudFwiIHNob3VsZCBub3QgYmUgdXNlZCBkdWUgdG8gYSBzZWN1cml0eSBjb25jZXJuJ1xuICAgICAgICApO1xuICAgICAgfVxuXG4gICAgICB0aGlzLm9uKG9wdGlvbnMudHJpZ2dlcnMpO1xuICAgIH1cblxuICAgIHRoaXMub24oe1xuICAgICAgd29ya2Zsb3dEaXNwYXRjaDoge30sIC8vIGFsbG93IG1hbnVhbCB0cmlnZ2VyaW5nXG4gICAgfSk7XG5cbiAgICBjb25zdCBqb2IgPSBuZXcgVGFza1dvcmtmbG93Sm9iKHRoaXMsIG9wdGlvbnMudGFzaywge1xuICAgICAgLi4ub3B0aW9ucyxcbiAgICAgIGRvd25sb2FkTGZzOiBvcHRpb25zLmRvd25sb2FkTGZzID8/IGdpdGh1Yi5kb3dubG9hZExmcyxcbiAgICB9KTtcblxuICAgIHRoaXMuYWRkSm9icyh7IFt0aGlzLmpvYklkXTogam9iIH0pO1xuICB9XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgZ2l0IGlkZW50aXR5LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEdpdElkZW50aXR5IHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSB1c2VyLlxuICAgKi9cbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgZW1haWwgYWRkcmVzcyBvZiB0aGUgZ2l0IHVzZXIuXG4gICAqL1xuICByZWFkb25seSBlbWFpbDogc3RyaW5nO1xufVxuIl19
@@ -39,12 +39,11 @@ class WorkflowActions {
39
39
  `git diff --staged --patch --exit-code > ${GIT_PATCH_FILE} || echo "${options.outputName}=true" >> $GITHUB_OUTPUT`,
40
40
  ].join("\n"),
41
41
  },
42
- {
42
+ workflow_steps_1.WorkflowSteps.uploadArtifact({
43
43
  if: MUTATIONS_FOUND,
44
44
  name: "Upload patch",
45
- uses: "actions/upload-artifact@v3",
46
45
  with: { name: GIT_PATCH_FILE, path: GIT_PATCH_FILE },
47
- },
46
+ }),
48
47
  ];
49
48
  if (options.mutationError) {
50
49
  steps.push({
@@ -144,5 +143,5 @@ class WorkflowActions {
144
143
  }
145
144
  exports.WorkflowActions = WorkflowActions;
146
145
  _a = JSII_RTTI_SYMBOL_1;
147
- WorkflowActions[_a] = { fqn: "projen.github.WorkflowActions", version: "0.78.9" };
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-actions.js","sourceRoot":"","sources":["../../src/github/workflow-actions.ts"],"names":[],"mappings":"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","sourcesContent":["import { GitIdentity, GithubCredentials } from \".\";\nimport { DEFAULT_GITHUB_ACTIONS_USER } from \"./constants\";\nimport { CheckoutWith, WorkflowSteps } from \"./workflow-steps\";\nimport { JobStep } from \"./workflows-model\";\n\nfunction context(value: string) {\n  return `\\${{ ${value} }}`;\n}\n\nconst REPO = context(\"github.repository\");\nconst RUN_ID = context(\"github.run_id\");\nconst SERVER_URL = context(\"github.server_url\");\nconst RUN_URL = `${SERVER_URL}/${REPO}/actions/runs/${RUN_ID}`;\nconst GIT_PATCH_FILE_DEFAULT = \".repo.patch\";\nconst RUNNER_TEMP = \"${{ runner.temp }}\";\n\n/**\n * A set of utility functions for creating GitHub actions in workflows.\n */\nexport class WorkflowActions {\n  /**\n   * Creates a .patch file from the current git diff and uploads it as an\n   * artifact. Use `checkoutWithPatch` to download and apply in another job.\n   *\n   * If a patch was uploaded, the action can optionally fail the job.\n   *\n   * @param options Options\n   * @returns Job steps\n   */\n  public static uploadGitPatch(options: UploadGitPatchOptions): JobStep[] {\n    const MUTATIONS_FOUND = `steps.${options.stepId}.outputs.${options.outputName}`;\n    const GIT_PATCH_FILE = options.patchFile ?? GIT_PATCH_FILE_DEFAULT;\n\n    const steps: JobStep[] = [\n      {\n        id: options.stepId,\n        name: options.stepName ?? \"Find mutations\",\n        run: [\n          \"git add .\",\n          `git diff --staged --patch --exit-code > ${GIT_PATCH_FILE} || echo \"${options.outputName}=true\" >> $GITHUB_OUTPUT`,\n        ].join(\"\\n\"),\n      },\n      {\n        if: MUTATIONS_FOUND,\n        name: \"Upload patch\",\n        uses: \"actions/upload-artifact@v3\",\n        with: { name: GIT_PATCH_FILE, path: GIT_PATCH_FILE },\n      },\n    ];\n\n    if (options.mutationError) {\n      steps.push({\n        name: \"Fail build on mutation\",\n        if: MUTATIONS_FOUND,\n        run: [\n          `echo \"::error::${options.mutationError}\"`,\n          `cat ${GIT_PATCH_FILE}`,\n          \"exit 1\",\n        ].join(\"\\n\"),\n      });\n    }\n\n    return steps;\n  }\n  /**\n   * Checks out a repository and applies a git patch that was created using\n   * `uploadGitPatch`.\n   *\n   * @param options Options\n   * @returns Job steps\n   */\n  public static checkoutWithPatch(\n    options: CheckoutWithPatchOptions = {}\n  ): JobStep[] {\n    const { patchFile, ...restOfOptions } = options;\n    const GIT_PATCH_FILE = options.patchFile ?? GIT_PATCH_FILE_DEFAULT;\n\n    return [\n      WorkflowSteps.checkout({ with: restOfOptions }),\n      {\n        name: \"Download patch\",\n        uses: \"actions/download-artifact@v3\",\n        with: { name: GIT_PATCH_FILE, path: RUNNER_TEMP },\n      },\n      {\n        name: \"Apply patch\",\n        run: `[ -s ${RUNNER_TEMP}/${GIT_PATCH_FILE} ] && git apply ${RUNNER_TEMP}/${GIT_PATCH_FILE} || echo \"Empty patch. Skipping.\"`,\n      },\n    ];\n  }\n\n  /**\n   * A step that creates a pull request based on the current repo state.\n   *\n   * @param options Options\n   * @returns Job steps\n   */\n  public static createPullRequest(\n    options: CreatePullRequestOptions\n  ): JobStep[] {\n    const workflowName = options.workflowName;\n    const branchName = options.branchName ?? `github-actions/${workflowName}`;\n    const stepId = options.stepId ?? \"create-pr\";\n    const stepName = options.stepName ?? \"Create Pull Request\";\n    const gitIdentity = options.gitIdentity ?? DEFAULT_GITHUB_ACTIONS_USER;\n    const committer = `${gitIdentity.name} <${gitIdentity.email}>`;\n    const pullRequestDescription = options.pullRequestDescription\n      .trimEnd()\n      .endsWith(\".\")\n      ? options.pullRequestDescription.trimEnd()\n      : `${options.pullRequestDescription.trimEnd()}.`;\n\n    const title = options.pullRequestTitle;\n    const description = [\n      `${pullRequestDescription} See details in [workflow run].`,\n      \"\",\n      `[Workflow Run]: ${RUN_URL}`,\n      \"\",\n      \"------\",\n      \"\",\n      `*Automatically created by projen via the \"${workflowName}\" workflow*`,\n    ].join(\"\\n\");\n\n    return [\n      {\n        name: stepName,\n        id: stepId,\n        uses: \"peter-evans/create-pull-request@v4\",\n        with: {\n          token: options.credentials?.tokenRef,\n          \"commit-message\": `${title}\\n\\n${description}`,\n          branch: branchName,\n          base: options.baseBranch,\n          title: title,\n          labels: options.labels?.join(\",\") || undefined,\n          assignees: options.assignees?.join(\",\") || undefined,\n          body: description,\n          author: committer,\n          committer: committer,\n          signoff: options.signoff ?? true,\n        },\n      },\n    ];\n  }\n\n  /**\n   * Configures the git identity (user name and email).\n   * @param id The identity to use\n   * @returns Job steps\n   *\n   * @deprecated use `WorkflowSteps.setupGitIdentity` instead\n   */\n  public static setupGitIdentity(id: GitIdentity): JobStep[] {\n    return [WorkflowSteps.setupGitIdentity({ gitIdentity: id })];\n  }\n}\n\n/**\n * Options for `checkoutWithPatch`.\n */\nexport interface CheckoutWithPatchOptions extends CheckoutWith {\n  /**\n   * The name of the artifact the patch is stored as.\n   * @default \".repo.patch\"\n   */\n  readonly patchFile?: string;\n}\n\n/**\n * Options for `uploadGitPatch`.\n */\nexport interface UploadGitPatchOptions {\n  /**\n   * The step ID which produces the output which indicates if a patch was created.\n   */\n  readonly stepId: string;\n\n  /**\n   * The name of the step.\n   * @default \"Find mutations\"\n   */\n  readonly stepName?: string;\n\n  /**\n   * The name of the artifact the patch is stored as.\n   * @default \".repo.patch\"\n   */\n  readonly patchFile?: string;\n\n  /**\n   * The name of the output to emit. It will be set to `true` if there was a diff.\n   */\n  readonly outputName: string;\n\n  /**\n   * Fail if a mutation was found and print this error message.\n   * @default - do not fail upon mutation\n   */\n  readonly mutationError?: string;\n}\n\nexport interface CreatePullRequestOptions {\n  /**\n   * The step ID which produces the output which indicates if a patch was created.\n   * @default \"create_pr\"\n   */\n  readonly stepId?: string;\n\n  /**\n   * The name of the step displayed on GitHub.\n   * @default \"Create Pull Request\"\n   */\n  readonly stepName?: string;\n\n  /**\n   * The job credentials used to create the pull request.\n   *\n   * Provided credentials must have permissions to create a pull request on the repository.\n   */\n  readonly credentials?: GithubCredentials;\n\n  /**\n   * The name of the workflow that will create the PR\n   */\n  readonly workflowName: string;\n\n  /**\n   * The full title used to create the pull request.\n   *\n   * If PR titles are validated in this repo, the title should comply with the respective rules.\n   */\n  readonly pullRequestTitle: string;\n\n  /**\n   * Description added to the pull request.\n   *\n   * Providence information are automatically added.\n   */\n  readonly pullRequestDescription: string;\n\n  /**\n   * Sets the pull request base branch.\n   *\n   * @default - The branch checked out in the workflow.\n   */\n  readonly baseBranch?: string;\n\n  /**\n   * The pull request branch name.\n   *\n   * @default `github-actions/${options.workflowName}`\n   */\n  readonly branchName?: string;\n\n  /**\n   * The git identity used to create the commit.\n   * @default - the default github-actions user\n   */\n  readonly gitIdentity?: GitIdentity;\n\n  /**\n   * Add Signed-off-by line by the committer at the end of the commit log message.\n   *\n   * @default true\n   */\n  readonly signoff?: boolean;\n\n  /**\n   * Labels to apply on the PR.\n   *\n   * @default - no labels.\n   */\n  readonly labels?: string[];\n\n  /**\n   * Assignees to add on the PR.\n   *\n   * @default - no assignees\n   */\n  readonly assignees?: string[];\n}\n"]}
146
+ WorkflowActions[_a] = { fqn: "projen.github.WorkflowActions", version: "0.78.11" };
147
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-actions.js","sourceRoot":"","sources":["../../src/github/workflow-actions.ts"],"names":[],"mappings":"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","sourcesContent":["import { GitIdentity, GithubCredentials } from \".\";\nimport { DEFAULT_GITHUB_ACTIONS_USER } from \"./constants\";\nimport { CheckoutWith, WorkflowSteps } from \"./workflow-steps\";\nimport { JobStep } from \"./workflows-model\";\n\nfunction context(value: string) {\n  return `\\${{ ${value} }}`;\n}\n\nconst REPO = context(\"github.repository\");\nconst RUN_ID = context(\"github.run_id\");\nconst SERVER_URL = context(\"github.server_url\");\nconst RUN_URL = `${SERVER_URL}/${REPO}/actions/runs/${RUN_ID}`;\nconst GIT_PATCH_FILE_DEFAULT = \".repo.patch\";\nconst RUNNER_TEMP = \"${{ runner.temp }}\";\n\n/**\n * A set of utility functions for creating GitHub actions in workflows.\n */\nexport class WorkflowActions {\n  /**\n   * Creates a .patch file from the current git diff and uploads it as an\n   * artifact. Use `checkoutWithPatch` to download and apply in another job.\n   *\n   * If a patch was uploaded, the action can optionally fail the job.\n   *\n   * @param options Options\n   * @returns Job steps\n   */\n  public static uploadGitPatch(options: UploadGitPatchOptions): JobStep[] {\n    const MUTATIONS_FOUND = `steps.${options.stepId}.outputs.${options.outputName}`;\n    const GIT_PATCH_FILE = options.patchFile ?? GIT_PATCH_FILE_DEFAULT;\n\n    const steps: JobStep[] = [\n      {\n        id: options.stepId,\n        name: options.stepName ?? \"Find mutations\",\n        run: [\n          \"git add .\",\n          `git diff --staged --patch --exit-code > ${GIT_PATCH_FILE} || echo \"${options.outputName}=true\" >> $GITHUB_OUTPUT`,\n        ].join(\"\\n\"),\n      },\n      WorkflowSteps.uploadArtifact({\n        if: MUTATIONS_FOUND,\n        name: \"Upload patch\",\n        with: { name: GIT_PATCH_FILE, path: GIT_PATCH_FILE },\n      }),\n    ];\n\n    if (options.mutationError) {\n      steps.push({\n        name: \"Fail build on mutation\",\n        if: MUTATIONS_FOUND,\n        run: [\n          `echo \"::error::${options.mutationError}\"`,\n          `cat ${GIT_PATCH_FILE}`,\n          \"exit 1\",\n        ].join(\"\\n\"),\n      });\n    }\n\n    return steps;\n  }\n  /**\n   * Checks out a repository and applies a git patch that was created using\n   * `uploadGitPatch`.\n   *\n   * @param options Options\n   * @returns Job steps\n   */\n  public static checkoutWithPatch(\n    options: CheckoutWithPatchOptions = {}\n  ): JobStep[] {\n    const { patchFile, ...restOfOptions } = options;\n    const GIT_PATCH_FILE = options.patchFile ?? GIT_PATCH_FILE_DEFAULT;\n\n    return [\n      WorkflowSteps.checkout({ with: restOfOptions }),\n      {\n        name: \"Download patch\",\n        uses: \"actions/download-artifact@v3\",\n        with: { name: GIT_PATCH_FILE, path: RUNNER_TEMP },\n      },\n      {\n        name: \"Apply patch\",\n        run: `[ -s ${RUNNER_TEMP}/${GIT_PATCH_FILE} ] && git apply ${RUNNER_TEMP}/${GIT_PATCH_FILE} || echo \"Empty patch. Skipping.\"`,\n      },\n    ];\n  }\n\n  /**\n   * A step that creates a pull request based on the current repo state.\n   *\n   * @param options Options\n   * @returns Job steps\n   */\n  public static createPullRequest(\n    options: CreatePullRequestOptions\n  ): JobStep[] {\n    const workflowName = options.workflowName;\n    const branchName = options.branchName ?? `github-actions/${workflowName}`;\n    const stepId = options.stepId ?? \"create-pr\";\n    const stepName = options.stepName ?? \"Create Pull Request\";\n    const gitIdentity = options.gitIdentity ?? DEFAULT_GITHUB_ACTIONS_USER;\n    const committer = `${gitIdentity.name} <${gitIdentity.email}>`;\n    const pullRequestDescription = options.pullRequestDescription\n      .trimEnd()\n      .endsWith(\".\")\n      ? options.pullRequestDescription.trimEnd()\n      : `${options.pullRequestDescription.trimEnd()}.`;\n\n    const title = options.pullRequestTitle;\n    const description = [\n      `${pullRequestDescription} See details in [workflow run].`,\n      \"\",\n      `[Workflow Run]: ${RUN_URL}`,\n      \"\",\n      \"------\",\n      \"\",\n      `*Automatically created by projen via the \"${workflowName}\" workflow*`,\n    ].join(\"\\n\");\n\n    return [\n      {\n        name: stepName,\n        id: stepId,\n        uses: \"peter-evans/create-pull-request@v4\",\n        with: {\n          token: options.credentials?.tokenRef,\n          \"commit-message\": `${title}\\n\\n${description}`,\n          branch: branchName,\n          base: options.baseBranch,\n          title: title,\n          labels: options.labels?.join(\",\") || undefined,\n          assignees: options.assignees?.join(\",\") || undefined,\n          body: description,\n          author: committer,\n          committer: committer,\n          signoff: options.signoff ?? true,\n        },\n      },\n    ];\n  }\n\n  /**\n   * Configures the git identity (user name and email).\n   * @param id The identity to use\n   * @returns Job steps\n   *\n   * @deprecated use `WorkflowSteps.setupGitIdentity` instead\n   */\n  public static setupGitIdentity(id: GitIdentity): JobStep[] {\n    return [WorkflowSteps.setupGitIdentity({ gitIdentity: id })];\n  }\n}\n\n/**\n * Options for `checkoutWithPatch`.\n */\nexport interface CheckoutWithPatchOptions extends CheckoutWith {\n  /**\n   * The name of the artifact the patch is stored as.\n   * @default \".repo.patch\"\n   */\n  readonly patchFile?: string;\n}\n\n/**\n * Options for `uploadGitPatch`.\n */\nexport interface UploadGitPatchOptions {\n  /**\n   * The step ID which produces the output which indicates if a patch was created.\n   */\n  readonly stepId: string;\n\n  /**\n   * The name of the step.\n   * @default \"Find mutations\"\n   */\n  readonly stepName?: string;\n\n  /**\n   * The name of the artifact the patch is stored as.\n   * @default \".repo.patch\"\n   */\n  readonly patchFile?: string;\n\n  /**\n   * The name of the output to emit. It will be set to `true` if there was a diff.\n   */\n  readonly outputName: string;\n\n  /**\n   * Fail if a mutation was found and print this error message.\n   * @default - do not fail upon mutation\n   */\n  readonly mutationError?: string;\n}\n\nexport interface CreatePullRequestOptions {\n  /**\n   * The step ID which produces the output which indicates if a patch was created.\n   * @default \"create_pr\"\n   */\n  readonly stepId?: string;\n\n  /**\n   * The name of the step displayed on GitHub.\n   * @default \"Create Pull Request\"\n   */\n  readonly stepName?: string;\n\n  /**\n   * The job credentials used to create the pull request.\n   *\n   * Provided credentials must have permissions to create a pull request on the repository.\n   */\n  readonly credentials?: GithubCredentials;\n\n  /**\n   * The name of the workflow that will create the PR\n   */\n  readonly workflowName: string;\n\n  /**\n   * The full title used to create the pull request.\n   *\n   * If PR titles are validated in this repo, the title should comply with the respective rules.\n   */\n  readonly pullRequestTitle: string;\n\n  /**\n   * Description added to the pull request.\n   *\n   * Providence information are automatically added.\n   */\n  readonly pullRequestDescription: string;\n\n  /**\n   * Sets the pull request base branch.\n   *\n   * @default - The branch checked out in the workflow.\n   */\n  readonly baseBranch?: string;\n\n  /**\n   * The pull request branch name.\n   *\n   * @default `github-actions/${options.workflowName}`\n   */\n  readonly branchName?: string;\n\n  /**\n   * The git identity used to create the commit.\n   * @default - the default github-actions user\n   */\n  readonly gitIdentity?: GitIdentity;\n\n  /**\n   * Add Signed-off-by line by the committer at the end of the commit log message.\n   *\n   * @default true\n   */\n  readonly signoff?: boolean;\n\n  /**\n   * Labels to apply on the PR.\n   *\n   * @default - no labels.\n   */\n  readonly labels?: string[];\n\n  /**\n   * Assignees to add on the PR.\n   *\n   * @default - no assignees\n   */\n  readonly assignees?: string[];\n}\n"]}
@@ -41,5 +41,5 @@ class WorkflowJobs {
41
41
  }
42
42
  exports.WorkflowJobs = WorkflowJobs;
43
43
  _a = JSII_RTTI_SYMBOL_1;
44
- WorkflowJobs[_a] = { fqn: "projen.github.WorkflowJobs", version: "0.78.9" };
44
+ WorkflowJobs[_a] = { fqn: "projen.github.WorkflowJobs", version: "0.78.11" };
45
45
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctam9icy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9naXRodWIvd29ya2Zsb3ctam9icy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHdCQU1XO0FBQ1gsMkNBQTBEO0FBRTFELHNEQUE4RTtBQUU5RTs7R0FFRztBQUNILE1BQWEsWUFBWTtJQUN2Qjs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLG9CQUFvQixDQUNoQyxPQUFvQztRQUVwQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsT0FBTyxJQUFJLHFCQUFxQixDQUFDO1FBQ3pELE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxXQUFXLElBQUksdUNBQTJCLENBQUM7UUFFdkUsTUFBTSxLQUFLLEdBQWM7WUFDdkIsR0FBRyxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsVUFBVSxJQUFJLEVBQUUsQ0FBQztZQUMxQyxHQUFHLGtCQUFlLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQztZQUNuRCxnQkFBYSxDQUFDLGdCQUFnQixDQUFDLEVBQUUsV0FBVyxFQUFFLENBQUM7WUFDL0MsR0FBRyxrQkFBZSxDQUFDLGlCQUFpQixDQUFDO2dCQUNuQyxHQUFHLE9BQU87Z0JBQ1YsV0FBVzthQUNaLENBQUM7U0FDSCxDQUFDO1FBRUYsT0FBTztZQUNMLElBQUksRUFBRSxPQUFPO1lBQ2IsRUFBRSxFQUFFLGNBQWMsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLFlBQVksT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLEtBQUs7WUFDOUUsS0FBSyxFQUFFLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUM7WUFDNUIsV0FBVyxFQUFFO2dCQUNYLFFBQVEsRUFBRSxZQUFTLENBQUMsYUFBYSxDQUFDLElBQUk7YUFDdkM7WUFDRCxHQUFHLElBQUEsc0NBQXFCLEVBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsV0FBVyxDQUFDO1lBQzdELEtBQUs7U0FDTixDQUFDO0lBQ0osQ0FBQzs7QUFoQ0gsb0NBaUNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hlY2tvdXRXaXRoUGF0Y2hPcHRpb25zLFxuICBDcmVhdGVQdWxsUmVxdWVzdE9wdGlvbnMsXG4gIFdvcmtmbG93QWN0aW9ucyxcbiAgV29ya2Zsb3dTdGVwcyxcbiAgd29ya2Zsb3dzLFxufSBmcm9tIFwiLlwiO1xuaW1wb3J0IHsgREVGQVVMVF9HSVRIVUJfQUNUSU9OU19VU0VSIH0gZnJvbSBcIi4vY29uc3RhbnRzXCI7XG5pbXBvcnQgeyBKb2IsIEpvYlN0ZXAgfSBmcm9tIFwiLi93b3JrZmxvd3MtbW9kZWxcIjtcbmltcG9ydCB7IEdyb3VwUnVubmVyT3B0aW9ucywgZmlsdGVyZWRSdW5zT25PcHRpb25zIH0gZnJvbSBcIi4uL3J1bm5lci1vcHRpb25zXCI7XG5cbi8qKlxuICogQSBzZXQgb2YgdXRpbGl0eSBmdW5jdGlvbnMgZm9yIGNyZWF0aW5nIGpvYnMgaW4gR2l0SHViIFdvcmtmbG93cy5cbiAqL1xuZXhwb3J0IGNsYXNzIFdvcmtmbG93Sm9icyB7XG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgcHVsbCByZXF1ZXN0IHdpdGggdGhlIGNoYW5nZXMgb2YgYSBwYXRjaCBmaWxlLlxuICAgKlxuICAgKiBAcmV0dXJucyBKb2JcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgcHVsbFJlcXVlc3RGcm9tUGF0Y2goXG4gICAgb3B0aW9uczogUHVsbFJlcXVlc3RGcm9tUGF0Y2hPcHRpb25zXG4gICk6IEpvYiB7XG4gICAgY29uc3Qgam9iTmFtZSA9IG9wdGlvbnMuam9iTmFtZSA/PyBcIkNyZWF0ZSBQdWxsIFJlcXVlc3RcIjtcbiAgICBjb25zdCBnaXRJZGVudGl0eSA9IG9wdGlvbnMuZ2l0SWRlbnRpdHkgPz8gREVGQVVMVF9HSVRIVUJfQUNUSU9OU19VU0VSO1xuXG4gICAgY29uc3Qgc3RlcHM6IEpvYlN0ZXBbXSA9IFtcbiAgICAgIC4uLihvcHRpb25zLmNyZWRlbnRpYWxzPy5zZXR1cFN0ZXBzIHx8IFtdKSxcbiAgICAgIC4uLldvcmtmbG93QWN0aW9ucy5jaGVja291dFdpdGhQYXRjaChvcHRpb25zLnBhdGNoKSxcbiAgICAgIFdvcmtmbG93U3RlcHMuc2V0dXBHaXRJZGVudGl0eSh7IGdpdElkZW50aXR5IH0pLFxuICAgICAgLi4uV29ya2Zsb3dBY3Rpb25zLmNyZWF0ZVB1bGxSZXF1ZXN0KHtcbiAgICAgICAgLi4ub3B0aW9ucyxcbiAgICAgICAgZ2l0SWRlbnRpdHksXG4gICAgICB9KSxcbiAgICBdO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIG5hbWU6IGpvYk5hbWUsXG4gICAgICBpZjogYFxcJHt7IG5lZWRzLiR7b3B0aW9ucy5wYXRjaC5qb2JJZH0ub3V0cHV0cy4ke29wdGlvbnMucGF0Y2gub3V0cHV0TmFtZX0gfX1gLFxuICAgICAgbmVlZHM6IFtvcHRpb25zLnBhdGNoLmpvYklkXSxcbiAgICAgIHBlcm1pc3Npb25zOiB7XG4gICAgICAgIGNvbnRlbnRzOiB3b3JrZmxvd3MuSm9iUGVybWlzc2lvbi5SRUFELFxuICAgICAgfSxcbiAgICAgIC4uLmZpbHRlcmVkUnVuc09uT3B0aW9ucyhvcHRpb25zLnJ1bnNPbiwgb3B0aW9ucy5ydW5zT25Hcm91cCksXG4gICAgICBzdGVwcyxcbiAgICB9O1xuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHVsbFJlcXVlc3RQYXRjaFNvdXJjZSBleHRlbmRzIENoZWNrb3V0V2l0aFBhdGNoT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBUaGUgaWQgb2YgdGhlIGpvYiB0aGF0IGNyZWF0ZWQgdGhlIHBhdGNoIGZpbGVcbiAgICovXG4gIHJlYWRvbmx5IGpvYklkOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBvdXRwdXQgdGhhdCBpbmRpY2F0ZXMgaWYgYSBwYXRjaCBoYXMgYmVlbiBjcmVhdGVkXG4gICAqL1xuICByZWFkb25seSBvdXRwdXROYW1lOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHVsbFJlcXVlc3RGcm9tUGF0Y2hPcHRpb25zIGV4dGVuZHMgQ3JlYXRlUHVsbFJlcXVlc3RPcHRpb25zIHtcbiAgLyoqXG4gICAqIEluZm9ybWF0aW9uIGFib3V0IHRoZSBwYXRjaCB0aGF0IGlzIHVzZWQgdG8gY3JlYXRlIHRoZSBwdWxsIHJlcXVlc3QuXG4gICAqL1xuICByZWFkb25seSBwYXRjaDogUHVsbFJlcXVlc3RQYXRjaFNvdXJjZTtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIGpvYiBkaXNwbGF5ZWQgb24gR2l0SHViLlxuICAgKiBAZGVmYXVsdCBcIkNyZWF0ZSBQdWxsIFJlcXVlc3RcIlxuICAgKi9cbiAgcmVhZG9ubHkgam9iTmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogR2l0aHViIFJ1bm5lciBzZWxlY3Rpb24gbGFiZWxzXG4gICAqIEBkZWZhdWx0IFtcInVidW50dS1sYXRlc3RcIl1cbiAgICogQGRlc2NyaXB0aW9uIERlZmluZXMgYSB0YXJnZXQgUnVubmVyIGJ5IGxhYmVsc1xuICAgKiBAdGhyb3dzIHtFcnJvcn0gaWYgYm90aCBgcnVuc09uYCBhbmQgYHJ1bnNPbkdyb3VwYCBhcmUgc3BlY2lmaWVkXG4gICAqL1xuICByZWFkb25seSBydW5zT24/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogR2l0aHViIFJ1bm5lciBHcm91cCBzZWxlY3Rpb24gb3B0aW9uc1xuICAgKiBAZGVzY3JpcHRpb24gRGVmaW5lcyBhIHRhcmdldCBSdW5uZXIgR3JvdXAgYnkgbmFtZSBhbmQvb3IgbGFiZWxzXG4gICAqIEB0aHJvd3Mge0Vycm9yfSBpZiBib3RoIGBydW5zT25gIGFuZCBgcnVuc09uR3JvdXBgIGFyZSBzcGVjaWZpZWRcbiAgICovXG4gIHJlYWRvbmx5IHJ1bnNPbkdyb3VwPzogR3JvdXBSdW5uZXJPcHRpb25zO1xufVxuIl19