@codedrifters/configulator 0.0.21 → 0.0.22

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.
@@ -0,0 +1,218 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AwsDeployWorkflow = exports.PROD_DEPLOY_NAME = void 0;
4
+ const projen_1 = require("projen");
5
+ const build_1 = require("projen/lib/build");
6
+ const github_1 = require("projen/lib/github");
7
+ const workflows_model_1 = require("projen/lib/github/workflows-model");
8
+ const aws_1 = require("../aws");
9
+ const aws_deployment_target_1 = require("../aws/aws-deployment-target");
10
+ const projects_1 = require("../projects");
11
+ const turbo_1 = require("../turbo");
12
+ const versions_1 = require("../versions");
13
+ exports.PROD_DEPLOY_NAME = "prod-deploy";
14
+ class AwsDeployWorkflow extends projen_1.Component {
15
+ static of(project, buildWorkflow) {
16
+ const isDefined = (c) => c instanceof AwsDeployWorkflow && c.buildWorkflow === buildWorkflow;
17
+ return project.components.find(isDefined);
18
+ }
19
+ constructor(project, options = {}) {
20
+ super(project);
21
+ this.project = project;
22
+ this.setupNode = () => {
23
+ return [
24
+ {
25
+ name: "Setup Node",
26
+ uses: "actions/setup-node@v4",
27
+ with: {
28
+ ["node-version"]: versions_1.VERSION.NODE_WORKFLOWS,
29
+ },
30
+ // occasionally this step fails due to internal issues at github
31
+ timeoutMinutes: 1,
32
+ },
33
+ ];
34
+ };
35
+ this.setupPnpm = () => {
36
+ return [
37
+ {
38
+ name: "Setup PNPM",
39
+ uses: "pnpm/action-setup@v3",
40
+ with: {
41
+ version: versions_1.VERSION.PNPM_VERSION,
42
+ },
43
+ },
44
+ ];
45
+ };
46
+ this.deploySteps = (target) => {
47
+ const { awsDeploymentType, account, region, ciDeploymentConfig, awsDeploymentConfig, } = target;
48
+ const { roleArn } = ciDeploymentConfig ?? {};
49
+ const { cdkOut } = awsDeploymentConfig;
50
+ return [
51
+ ...this.setupPnpm(),
52
+ ...this.setupNode(),
53
+ /**
54
+ * Install CDK
55
+ */
56
+ {
57
+ name: "Install CDK",
58
+ run: "pnpm add aws-cdk",
59
+ },
60
+ /**
61
+ * Configure AWS creds.
62
+ */
63
+ {
64
+ name: `AWS Creds ${awsDeploymentType}/${account}/${region}`,
65
+ uses: "aws-actions/configure-aws-credentials@v4",
66
+ with: {
67
+ "role-to-assume": roleArn,
68
+ "aws-region": region,
69
+ "role-duration-seconds": 900, // 15 minutes
70
+ },
71
+ },
72
+ /**
73
+ * Run CDK Deploy
74
+ */
75
+ {
76
+ name: `Deploy ${target.awsDeploymentType}/${target.account}/${target.region}`,
77
+ run: `pnpm dlx aws-cdk deploy --no-rollback --require-approval=never --app=${cdkOut} "*-${account}-${region}"`,
78
+ },
79
+ ];
80
+ };
81
+ /***************************************************************************
82
+ *
83
+ * Root project check
84
+ *
85
+ * Detect the root project and ensure it's of type MonorepoProject.
86
+ *
87
+ **************************************************************************/
88
+ if (!(project.root instanceof projects_1.MonorepoProject)) {
89
+ throw new Error("AwsDeployWorkflow requires the root project to be a MonorepoProject");
90
+ }
91
+ this.rootProject = project.root;
92
+ /***************************************************************************
93
+ *
94
+ * GitHub Check
95
+ *
96
+ * Make sure github config is active in the project. This is to ensure all
97
+ * workflows will be output properly during synth.
98
+ *
99
+ **************************************************************************/
100
+ const github = github_1.GitHub.of(this.rootProject);
101
+ if (!github) {
102
+ throw new Error("AwsDeployWorkflow requires a GitHub component in the root project");
103
+ }
104
+ /***************************************************************************
105
+ *
106
+ * Workflow Deploy Type
107
+ *
108
+ * What type of environments are we deploying into? We'll default to dev to
109
+ * be safe.
110
+ *
111
+ **************************************************************************/
112
+ this.awsDeployType = options.awsDeployType ?? aws_deployment_target_1.AWS_DEPLOY_TYPE.DEV;
113
+ /***************************************************************************
114
+ *
115
+ * Workflow Deploy Targets
116
+ *
117
+ * Use provided targets or discover them based on the deploy type. Only
118
+ * include targets that are marked for CI/CD.
119
+ *
120
+ **************************************************************************/
121
+ this.awsDeploymentTargets =
122
+ options.awsDeploymentTargets ??
123
+ aws_1.AwsDeploymentConfig.of(project)?.awsDeploymentTargets.filter((target) => target.awsDeploymentType === this.awsDeployType &&
124
+ target.ciDeployment) ??
125
+ [];
126
+ /***************************************************************************
127
+ *
128
+ * Build Workflow Options
129
+ *
130
+ * Can't use the options if an existing workflow was passed in.
131
+ *
132
+ **************************************************************************/
133
+ if (options.buildWorkflow && options.buildWorkflowOptions) {
134
+ throw new Error("Cannot provide both buildWorkflow and buildWorkflowOptions");
135
+ }
136
+ /***************************************************************************
137
+ *
138
+ * Build Workflow
139
+ *
140
+ * Create a workflow either based on input or from scratch.
141
+ *
142
+ **************************************************************************/
143
+ this.buildWorkflow =
144
+ options.buildWorkflow ??
145
+ new build_1.BuildWorkflow(project, {
146
+ /**
147
+ * Name based on project and environment.
148
+ */
149
+ name: ["deploy", project.name, this.awsDeployType].join("-"),
150
+ /**
151
+ * Use the root projects build task.
152
+ */
153
+ buildTask: this.rootProject.buildTask,
154
+ /**
155
+ * Use push triggers based n the branch config for each environment.
156
+ */
157
+ workflowTriggers: {
158
+ push: {
159
+ branches: [
160
+ ...this.awsDeploymentTargets.flatMap((t) => t.branches.map((b) => b.branch)),
161
+ ],
162
+ },
163
+ workflowDispatch: {},
164
+ ...options.buildWorkflowOptions?.workflowTriggers,
165
+ },
166
+ /**
167
+ * Never allow mutations for deploys. This should have been handled
168
+ * during build.
169
+ */
170
+ mutableBuild: false,
171
+ /**
172
+ * Setup Config steps to run before the build.
173
+ */
174
+ preBuildSteps: [
175
+ ...this.setupPnpm(),
176
+ ...this.setupNode(),
177
+ {
178
+ name: "Install dependencies",
179
+ run: "pnpm i --no-frozen-lockfile",
180
+ },
181
+ ],
182
+ ...options.buildWorkflowOptions,
183
+ });
184
+ /***************************************************************************
185
+ *
186
+ * Add Deployments to workflow
187
+ *
188
+ **************************************************************************/
189
+ this.awsDeploymentTargets.forEach((target) => {
190
+ const deployJobName = `${target.awsDeploymentType}-deploy-${this.project.name}-${target.account}-${target.region}`;
191
+ this.buildWorkflow.addPostBuildJob(deployJobName, {
192
+ name: `Deploy ${target.awsDeploymentType}/${target.account}/${target.region}`,
193
+ runsOn: ["ubuntu-latest"],
194
+ permissions: {
195
+ contents: workflows_model_1.JobPermission.READ,
196
+ idToken: workflows_model_1.JobPermission.WRITE,
197
+ },
198
+ concurrency: deployJobName,
199
+ steps: [...this.deploySteps(target)],
200
+ });
201
+ });
202
+ }
203
+ preSynthesize() {
204
+ /***************************************************************************
205
+ *
206
+ * Add turbo to all workflow, if turbo is in use by root project
207
+ *
208
+ **************************************************************************/
209
+ if (turbo_1.TurboRepo.of(this.rootProject)) {
210
+ this.buildWorkflow.addPostBuildSteps({
211
+ name: "Build Sub Projects",
212
+ run: `npx projen ${turbo_1.ROOT_CI_TASK_NAME}`,
213
+ });
214
+ }
215
+ }
216
+ }
217
+ exports.AwsDeployWorkflow = AwsDeployWorkflow;
218
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-deploy-workflow.js","sourceRoot":"","sources":["../../src/workflows/aws-deploy-workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"projen\";\nimport { AwsCdkTypeScriptApp } from \"projen/lib/awscdk\";\nimport { BuildWorkflow, BuildWorkflowOptions } from \"projen/lib/build\";\nimport { GitHub } from \"projen/lib/github\";\nimport { JobPermission, JobStep } from \"projen/lib/github/workflows-model\";\nimport { ValueOf } from \"type-fest\";\nimport { AwsDeploymentConfig } from \"../aws\";\nimport {\n  AWS_DEPLOY_TYPE,\n  AwsDeploymentTarget,\n} from \"../aws/aws-deployment-target\";\nimport { MonorepoProject } from \"../projects\";\nimport { ROOT_CI_TASK_NAME, TurboRepo } from \"../turbo\";\nimport { VERSION } from \"../versions\";\n\nexport const PROD_DEPLOY_NAME = \"prod-deploy\";\n\nexport interface DeployWorkflowOptions {\n  /**\n   * What type of deploy is this workflow for?\n   *\n   * @default AWS_DEPLOY_TYPE.DEV\n   */\n  readonly awsDeployType?: ValueOf<typeof AWS_DEPLOY_TYPE>;\n\n  /**\n   * Optionally feed a list of targets to deploy to.\n   *\n   * @default discovers all targets using deployType\n   */\n  readonly awsDeploymentTargets?: Array<AwsDeploymentTarget>;\n\n  /**\n   * Existing workflow, useful if we're tacking deployments onto an existing\n   * build workflow\n   */\n  readonly buildWorkflow?: BuildWorkflow;\n\n  /**\n   * Options for the build workflow, if no build workflow is provided.\n   */\n  readonly buildWorkflowOptions?: BuildWorkflowOptions;\n}\n\nexport class AwsDeployWorkflow extends Component {\n  public static of(\n    project: AwsCdkTypeScriptApp,\n    buildWorkflow: BuildWorkflow,\n  ): AwsDeployWorkflow | undefined {\n    const isDefined = (c: Component): c is AwsDeployWorkflow =>\n      c instanceof AwsDeployWorkflow && c.buildWorkflow === buildWorkflow;\n    return project.components.find(isDefined);\n  }\n\n  /**\n   * The root project for this deploy workflow. Must be a monorepo project.\n   */\n  private rootProject: MonorepoProject;\n\n  /**\n   * What type of deploy is this workflow for?\n   */\n  public awsDeployType: ValueOf<typeof AWS_DEPLOY_TYPE>;\n\n  /**\n   * The list of targets to deploy to.\n   */\n  readonly awsDeploymentTargets: Array<AwsDeploymentTarget>;\n\n  /**\n   * Hold the deploy workflow so we can add to it in preSynth\n   */\n  public buildWorkflow: BuildWorkflow;\n\n  constructor(\n    public project: AwsCdkTypeScriptApp,\n    options: DeployWorkflowOptions = {},\n  ) {\n    super(project);\n\n    /***************************************************************************\n     *\n     * Root project check\n     *\n     * Detect the root project and ensure it's of type MonorepoProject.\n     *\n     **************************************************************************/\n\n    if (!(project.root instanceof MonorepoProject)) {\n      throw new Error(\n        \"AwsDeployWorkflow requires the root project to be a MonorepoProject\",\n      );\n    }\n\n    this.rootProject = project.root;\n\n    /***************************************************************************\n     *\n     * GitHub Check\n     *\n     * Make sure github config is active in the project. This is to ensure all\n     * workflows will be output properly during synth.\n     *\n     **************************************************************************/\n\n    const github = GitHub.of(this.rootProject);\n\n    if (!github) {\n      throw new Error(\n        \"AwsDeployWorkflow requires a GitHub component in the root project\",\n      );\n    }\n\n    /***************************************************************************\n     *\n     * Workflow Deploy Type\n     *\n     * What type of environments are we deploying into? We'll default to dev to\n     * be safe.\n     *\n     **************************************************************************/\n\n    this.awsDeployType = options.awsDeployType ?? AWS_DEPLOY_TYPE.DEV;\n\n    /***************************************************************************\n     *\n     * Workflow Deploy Targets\n     *\n     * Use provided targets or discover them based on the deploy type. Only\n     * include targets that are marked for CI/CD.\n     *\n     **************************************************************************/\n\n    this.awsDeploymentTargets =\n      options.awsDeploymentTargets ??\n      AwsDeploymentConfig.of(project)?.awsDeploymentTargets.filter(\n        (target) =>\n          target.awsDeploymentType === this.awsDeployType &&\n          target.ciDeployment,\n      ) ??\n      [];\n\n    /***************************************************************************\n     *\n     * Build Workflow Options\n     *\n     * Can't use the options if an existing workflow was passed in.\n     *\n     **************************************************************************/\n\n    if (options.buildWorkflow && options.buildWorkflowOptions) {\n      throw new Error(\n        \"Cannot provide both buildWorkflow and buildWorkflowOptions\",\n      );\n    }\n\n    /***************************************************************************\n     *\n     * Build Workflow\n     *\n     * Create a workflow either based on input or from scratch.\n     *\n     **************************************************************************/\n\n    this.buildWorkflow =\n      options.buildWorkflow ??\n      new BuildWorkflow(project, {\n        /**\n         * Name based on project and environment.\n         */\n        name: [\"deploy\", project.name, this.awsDeployType].join(\"-\"),\n\n        /**\n         * Use the root projects build task.\n         */\n        buildTask: this.rootProject.buildTask,\n\n        /**\n         * Use push triggers based n the branch config for each environment.\n         */\n        workflowTriggers: {\n          push: {\n            branches: [\n              ...this.awsDeploymentTargets.flatMap((t) =>\n                t.branches.map((b) => b.branch),\n              ),\n            ],\n          },\n          workflowDispatch: {},\n          ...options.buildWorkflowOptions?.workflowTriggers,\n        },\n\n        /**\n         * Never allow mutations for deploys. This should have been handled\n         * during build.\n         */\n        mutableBuild: false,\n\n        /**\n         * Setup Config steps to run before the build.\n         */\n        preBuildSteps: [\n          ...this.setupPnpm(),\n          ...this.setupNode(),\n          {\n            name: \"Install dependencies\",\n            run: \"pnpm i --no-frozen-lockfile\",\n          },\n        ],\n        ...options.buildWorkflowOptions,\n      });\n\n    /***************************************************************************\n     *\n     * Add Deployments to workflow\n     *\n     **************************************************************************/\n\n    this.awsDeploymentTargets.forEach((target) => {\n      const deployJobName = `${target.awsDeploymentType}-deploy-${this.project.name}-${target.account}-${target.region}`;\n\n      this.buildWorkflow.addPostBuildJob(deployJobName, {\n        name: `Deploy ${target.awsDeploymentType}/${target.account}/${target.region}`,\n        runsOn: [\"ubuntu-latest\"],\n        permissions: {\n          contents: JobPermission.READ,\n          idToken: JobPermission.WRITE,\n        },\n        concurrency: deployJobName,\n        steps: [...this.deploySteps(target)],\n      });\n    });\n  }\n\n  private setupNode = (): Array<JobStep> => {\n    return [\n      {\n        name: \"Setup Node\",\n        uses: \"actions/setup-node@v4\",\n        with: {\n          [\"node-version\"]: VERSION.NODE_WORKFLOWS,\n        },\n        // occasionally this step fails due to internal issues at github\n        timeoutMinutes: 1,\n      },\n    ];\n  };\n\n  private setupPnpm = (): Array<JobStep> => {\n    return [\n      {\n        name: \"Setup PNPM\",\n        uses: \"pnpm/action-setup@v3\",\n        with: {\n          version: VERSION.PNPM_VERSION,\n        },\n      },\n    ];\n  };\n\n  private deploySteps = (target: AwsDeploymentTarget): Array<JobStep> => {\n    const {\n      awsDeploymentType,\n      account,\n      region,\n      ciDeploymentConfig,\n      awsDeploymentConfig,\n    } = target;\n    const { roleArn } = ciDeploymentConfig ?? {};\n    const { cdkOut } = awsDeploymentConfig;\n\n    return [\n      ...this.setupPnpm(),\n      ...this.setupNode(),\n\n      /**\n       * Install CDK\n       */\n      {\n        name: \"Install CDK\",\n        run: \"pnpm add aws-cdk\",\n      },\n\n      /**\n       * Configure AWS creds.\n       */\n      {\n        name: `AWS Creds ${awsDeploymentType}/${account}/${region}`,\n        uses: \"aws-actions/configure-aws-credentials@v4\",\n        with: {\n          \"role-to-assume\": roleArn,\n          \"aws-region\": region,\n          \"role-duration-seconds\": 900, // 15 minutes\n        },\n      },\n\n      /**\n       * Run CDK Deploy\n       */\n      {\n        name: `Deploy ${target.awsDeploymentType}/${target.account}/${target.region}`,\n        run: `pnpm dlx aws-cdk deploy --no-rollback --require-approval=never --app=${cdkOut} \"*-${account}-${region}\"`,\n      },\n    ];\n  };\n\n  preSynthesize(): void {\n    /***************************************************************************\n     *\n     * Add turbo to all workflow, if turbo is in use by root project\n     *\n     **************************************************************************/\n\n    if (TurboRepo.of(this.rootProject)) {\n      this.buildWorkflow.addPostBuildSteps({\n        name: \"Build Sub Projects\",\n        run: `npx projen ${ROOT_CI_TASK_NAME}`,\n      });\n    }\n  }\n}\n"]}
@@ -1,2 +1 @@
1
- export * from "./build-workflow";
2
- export * from "./deploy-workflow";
1
+ export * from "./aws-deploy-workflow";
@@ -14,6 +14,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./build-workflow"), exports);
18
- __exportStar(require("./deploy-workflow"), exports);
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvd29ya2Zsb3dzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxtREFBaUM7QUFDakMsb0RBQWtDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYnVpbGQtd29ya2Zsb3dcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RlcGxveS13b3JrZmxvd1wiO1xuIl19
17
+ __exportStar(require("./aws-deploy-workflow"), exports);
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvd29ya2Zsb3dzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSx3REFBc0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9hd3MtZGVwbG95LXdvcmtmbG93XCI7XG4iXX0=
package/package.json CHANGED
@@ -39,7 +39,7 @@
39
39
  },
40
40
  "main": "lib/index.js",
41
41
  "license": "MIT",
42
- "version": "0.0.21",
42
+ "version": "0.0.22",
43
43
  "types": "lib/index.d.ts",
44
44
  "//": "~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\".",
45
45
  "scripts": {
@@ -1,13 +0,0 @@
1
- import { Component } from "projen";
2
- import { TypeScriptAppProject } from "projen/lib/typescript";
3
- export declare const PREVIEW_DEPLOY_NAME = "preview-deploy";
4
- export declare class BuildWorkflow extends Component {
5
- project: TypeScriptAppProject;
6
- constructor(project: TypeScriptAppProject);
7
- /**
8
- * This runs after all the projects are setup but before any files are
9
- * synthesized. This allows us to update the build yaml with complete
10
- * information.
11
- */
12
- preSynthesize(): void;
13
- }
@@ -1,64 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BuildWorkflow = exports.PREVIEW_DEPLOY_NAME = void 0;
4
- const projen_1 = require("projen");
5
- const awscdk_1 = require("projen/lib/awscdk");
6
- const workflows_model_1 = require("projen/lib/github/workflows-model");
7
- const deploy_1 = require("./steps/deploy");
8
- const aws_deployment_config_1 = require("../aws/aws-deployment-config");
9
- exports.PREVIEW_DEPLOY_NAME = "preview-deploy";
10
- class BuildWorkflow extends projen_1.Component {
11
- constructor(project) {
12
- super(project);
13
- this.project = project;
14
- }
15
- /**
16
- * This runs after all the projects are setup but before any files are
17
- * synthesized. This allows us to update the build yaml with complete
18
- * information.
19
- */
20
- preSynthesize() {
21
- super.preSynthesize();
22
- /**
23
- * Deploy PR preview to dev environment(s)
24
- */
25
- this.project.subprojects
26
- // only AwsCdkTypeScriptApp projects
27
- .filter((subproject) => subproject instanceof awscdk_1.AwsCdkTypeScriptApp)
28
- .forEach((subproject) => {
29
- /**
30
- * an array of all deployment configs.
31
- */
32
- const deployConfigs = aws_deployment_config_1.AwsDeploymentConfig.of(subproject);
33
- /**
34
- * Any configs? let's see if any have CI support for PR deploys!
35
- */
36
- if (deployConfigs) {
37
- deployConfigs.forEach((config) => {
38
- config.deploymentTargets
39
- // only development targets for CI
40
- .filter((dt) => dt.ciDeployment &&
41
- dt.awsDeploymentType === aws_deployment_config_1.AWS_DEPLOY_TYPE.DEV)
42
- .forEach((dt) => {
43
- /**
44
- * Nice long annoying but unique name.
45
- */
46
- const deployJobName = `${exports.PREVIEW_DEPLOY_NAME}-${this.project.name}-${dt.account}-${dt.region}`;
47
- this.project.buildWorkflow?.addPostBuildJob(deployJobName, {
48
- name: `Deploy PR Preview to ${dt.account}/${dt.region}`,
49
- runsOn: ["ubuntu-latest"],
50
- permissions: {
51
- contents: workflows_model_1.JobPermission.READ,
52
- idToken: workflows_model_1.JobPermission.WRITE,
53
- },
54
- concurrency: deployJobName,
55
- steps: [...(0, deploy_1.deploySteps)(subproject, dt)],
56
- });
57
- });
58
- });
59
- }
60
- });
61
- }
62
- }
63
- exports.BuildWorkflow = BuildWorkflow;
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtd29ya2Zsb3cuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvd29ya2Zsb3dzL2J1aWxkLXdvcmtmbG93LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLG1DQUFtQztBQUNuQyw4Q0FBd0Q7QUFDeEQsdUVBQWtFO0FBRWxFLDJDQUE2QztBQUM3Qyx3RUFHc0M7QUFFekIsUUFBQSxtQkFBbUIsR0FBRyxnQkFBZ0IsQ0FBQztBQUVwRCxNQUFhLGFBQWMsU0FBUSxrQkFBUztJQUMxQyxZQUFtQixPQUE2QjtRQUM5QyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFERSxZQUFPLEdBQVAsT0FBTyxDQUFzQjtJQUVoRCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILGFBQWE7UUFDWCxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUM7UUFFdEI7O1dBRUc7UUFDSCxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVc7WUFDdEIsb0NBQW9DO2FBQ25DLE1BQU0sQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUMsVUFBVSxZQUFZLDRCQUFtQixDQUFDO2FBQ2pFLE9BQU8sQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFO1lBQ3RCOztlQUVHO1lBQ0gsTUFBTSxhQUFhLEdBQUcsMkNBQW1CLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBRXpEOztlQUVHO1lBQ0gsSUFBSSxhQUFhLEVBQUUsQ0FBQztnQkFDbEIsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO29CQUMvQixNQUFNLENBQUMsaUJBQWlCO3dCQUN0QixrQ0FBa0M7eUJBQ2pDLE1BQU0sQ0FDTCxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQ0wsRUFBRSxDQUFDLFlBQVk7d0JBQ2YsRUFBRSxDQUFDLGlCQUFpQixLQUFLLHVDQUFlLENBQUMsR0FBRyxDQUMvQzt5QkFDQSxPQUFPLENBQUMsQ0FBQyxFQUFFLEVBQUUsRUFBRTt3QkFDZDs7MkJBRUc7d0JBQ0gsTUFBTSxhQUFhLEdBQUcsR0FBRywyQkFBbUIsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQzt3QkFFL0YsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsZUFBZSxDQUFDLGFBQWEsRUFBRTs0QkFDekQsSUFBSSxFQUFFLHdCQUF3QixFQUFFLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEVBQUU7NEJBQ3ZELE1BQU0sRUFBRSxDQUFDLGVBQWUsQ0FBQzs0QkFDekIsV0FBVyxFQUFFO2dDQUNYLFFBQVEsRUFBRSwrQkFBYSxDQUFDLElBQUk7Z0NBQzVCLE9BQU8sRUFBRSwrQkFBYSxDQUFDLEtBQUs7NkJBQzdCOzRCQUNELFdBQVcsRUFBRSxhQUFhOzRCQUMxQixLQUFLLEVBQUUsQ0FBQyxHQUFHLElBQUEsb0JBQVcsRUFBQyxVQUFVLEVBQUUsRUFBRSxDQUFDLENBQUM7eUJBQ3hDLENBQUMsQ0FBQztvQkFDTCxDQUFDLENBQUMsQ0FBQztnQkFDUCxDQUFDLENBQUMsQ0FBQztZQUNMLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7Q0FDRjtBQTFERCxzQ0EwREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tIFwicHJvamVuXCI7XG5pbXBvcnQgeyBBd3NDZGtUeXBlU2NyaXB0QXBwIH0gZnJvbSBcInByb2plbi9saWIvYXdzY2RrXCI7XG5pbXBvcnQgeyBKb2JQZXJtaXNzaW9uIH0gZnJvbSBcInByb2plbi9saWIvZ2l0aHViL3dvcmtmbG93cy1tb2RlbFwiO1xuaW1wb3J0IHsgVHlwZVNjcmlwdEFwcFByb2plY3QgfSBmcm9tIFwicHJvamVuL2xpYi90eXBlc2NyaXB0XCI7XG5pbXBvcnQgeyBkZXBsb3lTdGVwcyB9IGZyb20gXCIuL3N0ZXBzL2RlcGxveVwiO1xuaW1wb3J0IHtcbiAgQVdTX0RFUExPWV9UWVBFLFxuICBBd3NEZXBsb3ltZW50Q29uZmlnLFxufSBmcm9tIFwiLi4vYXdzL2F3cy1kZXBsb3ltZW50LWNvbmZpZ1wiO1xuXG5leHBvcnQgY29uc3QgUFJFVklFV19ERVBMT1lfTkFNRSA9IFwicHJldmlldy1kZXBsb3lcIjtcblxuZXhwb3J0IGNsYXNzIEJ1aWxkV29ya2Zsb3cgZXh0ZW5kcyBDb21wb25lbnQge1xuICBjb25zdHJ1Y3RvcihwdWJsaWMgcHJvamVjdDogVHlwZVNjcmlwdEFwcFByb2plY3QpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGlzIHJ1bnMgYWZ0ZXIgYWxsIHRoZSBwcm9qZWN0cyBhcmUgc2V0dXAgYnV0IGJlZm9yZSBhbnkgZmlsZXMgYXJlXG4gICAqIHN5bnRoZXNpemVkLiBUaGlzIGFsbG93cyB1cyB0byB1cGRhdGUgdGhlIGJ1aWxkIHlhbWwgd2l0aCBjb21wbGV0ZVxuICAgKiBpbmZvcm1hdGlvbi5cbiAgICovXG4gIHByZVN5bnRoZXNpemUoKTogdm9pZCB7XG4gICAgc3VwZXIucHJlU3ludGhlc2l6ZSgpO1xuXG4gICAgLyoqXG4gICAgICogRGVwbG95IFBSIHByZXZpZXcgdG8gZGV2IGVudmlyb25tZW50KHMpXG4gICAgICovXG4gICAgdGhpcy5wcm9qZWN0LnN1YnByb2plY3RzXG4gICAgICAvLyBvbmx5IEF3c0Nka1R5cGVTY3JpcHRBcHAgcHJvamVjdHNcbiAgICAgIC5maWx0ZXIoKHN1YnByb2plY3QpID0+IHN1YnByb2plY3QgaW5zdGFuY2VvZiBBd3NDZGtUeXBlU2NyaXB0QXBwKVxuICAgICAgLmZvckVhY2goKHN1YnByb2plY3QpID0+IHtcbiAgICAgICAgLyoqXG4gICAgICAgICAqIGFuIGFycmF5IG9mIGFsbCBkZXBsb3ltZW50IGNvbmZpZ3MuXG4gICAgICAgICAqL1xuICAgICAgICBjb25zdCBkZXBsb3lDb25maWdzID0gQXdzRGVwbG95bWVudENvbmZpZy5vZihzdWJwcm9qZWN0KTtcblxuICAgICAgICAvKipcbiAgICAgICAgICogQW55IGNvbmZpZ3M/IGxldCdzIHNlZSBpZiBhbnkgaGF2ZSBDSSBzdXBwb3J0IGZvciBQUiBkZXBsb3lzIVxuICAgICAgICAgKi9cbiAgICAgICAgaWYgKGRlcGxveUNvbmZpZ3MpIHtcbiAgICAgICAgICBkZXBsb3lDb25maWdzLmZvckVhY2goKGNvbmZpZykgPT4ge1xuICAgICAgICAgICAgY29uZmlnLmRlcGxveW1lbnRUYXJnZXRzXG4gICAgICAgICAgICAgIC8vIG9ubHkgZGV2ZWxvcG1lbnQgdGFyZ2V0cyBmb3IgQ0lcbiAgICAgICAgICAgICAgLmZpbHRlcihcbiAgICAgICAgICAgICAgICAoZHQpID0+XG4gICAgICAgICAgICAgICAgICBkdC5jaURlcGxveW1lbnQgJiZcbiAgICAgICAgICAgICAgICAgIGR0LmF3c0RlcGxveW1lbnRUeXBlID09PSBBV1NfREVQTE9ZX1RZUEUuREVWLFxuICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgIC5mb3JFYWNoKChkdCkgPT4ge1xuICAgICAgICAgICAgICAgIC8qKlxuICAgICAgICAgICAgICAgICAqIE5pY2UgbG9uZyBhbm5veWluZyBidXQgdW5pcXVlIG5hbWUuXG4gICAgICAgICAgICAgICAgICovXG4gICAgICAgICAgICAgICAgY29uc3QgZGVwbG95Sm9iTmFtZSA9IGAke1BSRVZJRVdfREVQTE9ZX05BTUV9LSR7dGhpcy5wcm9qZWN0Lm5hbWV9LSR7ZHQuYWNjb3VudH0tJHtkdC5yZWdpb259YDtcblxuICAgICAgICAgICAgICAgIHRoaXMucHJvamVjdC5idWlsZFdvcmtmbG93Py5hZGRQb3N0QnVpbGRKb2IoZGVwbG95Sm9iTmFtZSwge1xuICAgICAgICAgICAgICAgICAgbmFtZTogYERlcGxveSBQUiBQcmV2aWV3IHRvICR7ZHQuYWNjb3VudH0vJHtkdC5yZWdpb259YCxcbiAgICAgICAgICAgICAgICAgIHJ1bnNPbjogW1widWJ1bnR1LWxhdGVzdFwiXSxcbiAgICAgICAgICAgICAgICAgIHBlcm1pc3Npb25zOiB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnRlbnRzOiBKb2JQZXJtaXNzaW9uLlJFQUQsXG4gICAgICAgICAgICAgICAgICAgIGlkVG9rZW46IEpvYlBlcm1pc3Npb24uV1JJVEUsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgICAgY29uY3VycmVuY3k6IGRlcGxveUpvYk5hbWUsXG4gICAgICAgICAgICAgICAgICBzdGVwczogWy4uLmRlcGxveVN0ZXBzKHN1YnByb2plY3QsIGR0KV0sXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgfVxufVxuIl19
@@ -1,17 +0,0 @@
1
- import { Component } from "projen";
2
- import { TypeScriptAppProject } from "projen/lib/typescript";
3
- export declare const PROD_DEPLOY_NAME = "prod-deploy";
4
- export declare class DeployWorkflow extends Component {
5
- project: TypeScriptAppProject;
6
- /**
7
- * Hold the deploy workflow so we can add to it in preSynth
8
- */
9
- private workflow;
10
- constructor(project: TypeScriptAppProject);
11
- /**
12
- * This runs after all the projects are setup but before any files are
13
- * synthesized. This allows us to update the build yaml with complete
14
- * information.
15
- */
16
- preSynthesize(): void;
17
- }
@@ -1,113 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DeployWorkflow = exports.PROD_DEPLOY_NAME = void 0;
4
- const projen_1 = require("projen");
5
- const awscdk_1 = require("projen/lib/awscdk");
6
- const build_1 = require("projen/lib/build");
7
- const github_1 = require("projen/lib/github");
8
- const workflows_model_1 = require("projen/lib/github/workflows-model");
9
- const versions_1 = require("../versions");
10
- const deploy_1 = require("./steps/deploy");
11
- const aws_deployment_config_1 = require("../aws/aws-deployment-config");
12
- const turbo_repo_1 = require("../turbo/turbo-repo");
13
- exports.PROD_DEPLOY_NAME = "prod-deploy";
14
- class DeployWorkflow extends projen_1.Component {
15
- constructor(project) {
16
- super(project);
17
- this.project = project;
18
- const github = github_1.GitHub.of(project);
19
- if (!github) {
20
- throw new Error("DeployWorkflow requires a GitHub component in the project");
21
- }
22
- /***************************************************************************
23
- *
24
- * Build normally
25
- *
26
- * TODO: This should really be using a released artifact from a
27
- * versioned build.
28
- *
29
- **************************************************************************/
30
- this.workflow = new build_1.BuildWorkflow(project, {
31
- name: "deploy",
32
- buildTask: project.buildTask,
33
- workflowTriggers: {
34
- push: {
35
- branches: ["main"],
36
- },
37
- workflowDispatch: {},
38
- },
39
- mutableBuild: false,
40
- preBuildSteps: [
41
- {
42
- name: "Setup PNPM",
43
- uses: "pnpm/action-setup@v3",
44
- with: {
45
- version: versions_1.VERSION.PNPM_VERSION,
46
- },
47
- },
48
- {
49
- name: "Install dependencies",
50
- run: "pnpm i --no-frozen-lockfile",
51
- },
52
- ],
53
- });
54
- /**
55
- * Attach build all turbo runner to the build workflow.
56
- */
57
- this.workflow.addPostBuildSteps({
58
- name: "Build Sub Projects",
59
- run: `npx projen ${turbo_repo_1.ROOT_CI_TASK_NAME}`,
60
- });
61
- }
62
- /**
63
- * This runs after all the projects are setup but before any files are
64
- * synthesized. This allows us to update the build yaml with complete
65
- * information.
66
- */
67
- preSynthesize() {
68
- super.preSynthesize();
69
- /***************************************************************************
70
- *
71
- * Production Deploy
72
- *
73
- **************************************************************************/
74
- this.project.subprojects
75
- // only AwsCdkTypeScriptApp projects
76
- .filter((subproject) => subproject instanceof awscdk_1.AwsCdkTypeScriptApp)
77
- .forEach((subproject) => {
78
- /**
79
- * An array of all deployment configs.
80
- */
81
- const deployConfigs = aws_deployment_config_1.AwsDeploymentConfig.of(subproject);
82
- /**
83
- * Any configs? let's see if any have CI support for PR deploys!
84
- */
85
- if (deployConfigs) {
86
- deployConfigs.forEach((config) => {
87
- config.deploymentTargets
88
- // only development targets for CI
89
- .filter((dt) => dt.ciDeployment &&
90
- dt.awsDeploymentType === aws_deployment_config_1.AWS_DEPLOY_TYPE.PROD)
91
- .forEach((dt) => {
92
- /**
93
- * Nice long annoying but unique name.
94
- */
95
- const deployJobName = `deploy-${this.project.name}-${dt.account}-${dt.region}`;
96
- this.workflow.addPostBuildJob(deployJobName, {
97
- name: `Deploy Prod to ${dt.account}/${dt.region}`,
98
- runsOn: ["ubuntu-latest"],
99
- permissions: {
100
- contents: workflows_model_1.JobPermission.READ,
101
- idToken: workflows_model_1.JobPermission.WRITE,
102
- },
103
- concurrency: deployJobName,
104
- steps: [...(0, deploy_1.deploySteps)(subproject, dt)],
105
- });
106
- });
107
- });
108
- }
109
- });
110
- }
111
- }
112
- exports.DeployWorkflow = DeployWorkflow;
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deploy-workflow.js","sourceRoot":"","sources":["../../src/workflows/deploy-workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"projen\";\nimport { AwsCdkTypeScriptApp } from \"projen/lib/awscdk\";\nimport { BuildWorkflow } from \"projen/lib/build\";\nimport { GitHub } from \"projen/lib/github\";\nimport { JobPermission } from \"projen/lib/github/workflows-model\";\nimport { TypeScriptAppProject } from \"projen/lib/typescript\";\nimport { VERSION } from \"../versions\";\nimport { deploySteps } from \"./steps/deploy\";\nimport {\n  AWS_DEPLOY_TYPE,\n  AwsDeploymentConfig,\n} from \"../aws/aws-deployment-config\";\nimport { ROOT_CI_TASK_NAME } from \"../turbo/turbo-repo\";\n\nexport const PROD_DEPLOY_NAME = \"prod-deploy\";\n\nexport class DeployWorkflow extends Component {\n  /**\n   * Hold the deploy workflow so we can add to it in preSynth\n   */\n  private workflow: BuildWorkflow;\n\n  constructor(public project: TypeScriptAppProject) {\n    super(project);\n\n    const github = GitHub.of(project);\n\n    if (!github) {\n      throw new Error(\n        \"DeployWorkflow requires a GitHub component in the project\",\n      );\n    }\n\n    /***************************************************************************\n     *\n     * Build normally\n     *\n     * TODO: This should really be using a released artifact from a\n     *        versioned build.\n     *\n     **************************************************************************/\n\n    this.workflow = new BuildWorkflow(project, {\n      name: \"deploy\",\n      buildTask: project.buildTask,\n      workflowTriggers: {\n        push: {\n          branches: [\"main\"],\n        },\n        workflowDispatch: {},\n      },\n      mutableBuild: false,\n\n      preBuildSteps: [\n        {\n          name: \"Setup PNPM\",\n          uses: \"pnpm/action-setup@v3\",\n          with: {\n            version: VERSION.PNPM_VERSION,\n          },\n        },\n        {\n          name: \"Install dependencies\",\n          run: \"pnpm i --no-frozen-lockfile\",\n        },\n      ],\n    });\n\n    /**\n     * Attach build all turbo runner to the build workflow.\n     */\n    this.workflow.addPostBuildSteps({\n      name: \"Build Sub Projects\",\n      run: `npx projen ${ROOT_CI_TASK_NAME}`,\n    });\n  }\n\n  /**\n   * This runs after all the projects are setup but before any files are\n   * synthesized. This allows us to update the build yaml with complete\n   * information.\n   */\n  preSynthesize(): void {\n    super.preSynthesize();\n\n    /***************************************************************************\n     *\n     * Production Deploy\n     *\n     **************************************************************************/\n\n    this.project.subprojects\n      // only AwsCdkTypeScriptApp projects\n      .filter((subproject) => subproject instanceof AwsCdkTypeScriptApp)\n      .forEach((subproject) => {\n        /**\n         * An array of all deployment configs.\n         */\n        const deployConfigs = AwsDeploymentConfig.of(subproject);\n\n        /**\n         * Any configs? let's see if any have CI support for PR deploys!\n         */\n        if (deployConfigs) {\n          deployConfigs.forEach((config) => {\n            config.deploymentTargets\n              // only development targets for CI\n              .filter(\n                (dt) =>\n                  dt.ciDeployment &&\n                  dt.awsDeploymentType === AWS_DEPLOY_TYPE.PROD,\n              )\n              .forEach((dt) => {\n                /**\n                 * Nice long annoying but unique name.\n                 */\n                const deployJobName = `deploy-${this.project.name}-${dt.account}-${dt.region}`;\n\n                this.workflow.addPostBuildJob(deployJobName, {\n                  name: `Deploy Prod to ${dt.account}/${dt.region}`,\n                  runsOn: [\"ubuntu-latest\"],\n                  permissions: {\n                    contents: JobPermission.READ,\n                    idToken: JobPermission.WRITE,\n                  },\n                  concurrency: deployJobName,\n                  steps: [...deploySteps(subproject, dt)],\n                });\n              });\n          });\n        }\n      });\n  }\n}\n"]}
@@ -1,4 +0,0 @@
1
- import { AwsCdkTypeScriptApp } from "projen/lib/awscdk";
2
- import { JobStep } from "projen/lib/github/workflows-model";
3
- import { AwsDeploymentTarget } from "../../aws/aws-deployment-config";
4
- export declare const deploySteps: (project: AwsCdkTypeScriptApp, deployTarget: AwsDeploymentTarget) => Array<JobStep>;
@@ -1,62 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.deploySteps = void 0;
4
- const node_path_1 = require("node:path");
5
- const versions_1 = require("../../versions");
6
- const deploySteps = (project, deployTarget) => {
7
- const projectPath = (0, node_path_1.relative)(project.root.outdir, project.outdir);
8
- const cdkOut = (0, node_path_1.join)("dist", projectPath, "cdk.out");
9
- return [
10
- /**
11
- * Setup PNPM
12
- */
13
- {
14
- name: "Setup PNPM",
15
- uses: "pnpm/action-setup@v3",
16
- with: {
17
- version: versions_1.VERSION.PNPM_VERSION,
18
- },
19
- },
20
- /**
21
- * Setup Node
22
- */
23
- {
24
- name: "Setup Node",
25
- uses: "actions/setup-node@v4",
26
- with: {
27
- ["node-version"]: versions_1.VERSION.NODE_WORKFLOWS,
28
- },
29
- // occasionally this step fails due to internal issues at github
30
- timeoutMinutes: 1,
31
- },
32
- /**
33
- * Install CDK
34
- */
35
- {
36
- name: "Install CDK",
37
- run: "pnpm add aws-cdk",
38
- },
39
- /**
40
- * Configure AWS creds.
41
- */
42
- {
43
- name: `Configure AWS Credentials for ${deployTarget.account}/${deployTarget.region}`,
44
- uses: "aws-actions/configure-aws-credentials@v4",
45
- with: {
46
- "role-to-assume": deployTarget.ciDeploymentConfig?.roleArn ??
47
- "ERROR: No role ARN provided",
48
- "aws-region": deployTarget.region,
49
- "role-duration-seconds": 900, // 15 minutes
50
- },
51
- },
52
- /**
53
- * Run CDK Deploy
54
- */
55
- {
56
- name: `Deploy To ${deployTarget.account}/${deployTarget.region}`,
57
- run: `pnpm dlx aws-cdk deploy --no-rollback --require-approval=never --app=${cdkOut} "*-${deployTarget.account}-${deployTarget.region}"`,
58
- },
59
- ];
60
- };
61
- exports.deploySteps = deploySteps;
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVwbG95LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3dvcmtmbG93cy9zdGVwcy9kZXBsb3kudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEseUNBQTJDO0FBSTNDLDZDQUF5QztBQUVsQyxNQUFNLFdBQVcsR0FBRyxDQUN6QixPQUE0QixFQUM1QixZQUFpQyxFQUNqQixFQUFFO0lBQ2xCLE1BQU0sV0FBVyxHQUFHLElBQUEsb0JBQVEsRUFBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7SUFFbEUsTUFBTSxNQUFNLEdBQUcsSUFBQSxnQkFBSSxFQUFDLE1BQU0sRUFBRSxXQUFXLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFFcEQsT0FBTztRQUNMOztXQUVHO1FBQ0g7WUFDRSxJQUFJLEVBQUUsWUFBWTtZQUNsQixJQUFJLEVBQUUsc0JBQXNCO1lBQzVCLElBQUksRUFBRTtnQkFDSixPQUFPLEVBQUUsa0JBQU8sQ0FBQyxZQUFZO2FBQzlCO1NBQ0Y7UUFFRDs7V0FFRztRQUNIO1lBQ0UsSUFBSSxFQUFFLFlBQVk7WUFDbEIsSUFBSSxFQUFFLHVCQUF1QjtZQUM3QixJQUFJLEVBQUU7Z0JBQ0osQ0FBQyxjQUFjLENBQUMsRUFBRSxrQkFBTyxDQUFDLGNBQWM7YUFDekM7WUFDRCxnRUFBZ0U7WUFDaEUsY0FBYyxFQUFFLENBQUM7U0FDbEI7UUFFRDs7V0FFRztRQUNIO1lBQ0UsSUFBSSxFQUFFLGFBQWE7WUFDbkIsR0FBRyxFQUFFLGtCQUFrQjtTQUN4QjtRQUVEOztXQUVHO1FBQ0g7WUFDRSxJQUFJLEVBQUUsaUNBQWlDLFlBQVksQ0FBQyxPQUFPLElBQUksWUFBWSxDQUFDLE1BQU0sRUFBRTtZQUNwRixJQUFJLEVBQUUsMENBQTBDO1lBQ2hELElBQUksRUFBRTtnQkFDSixnQkFBZ0IsRUFDZCxZQUFZLENBQUMsa0JBQWtCLEVBQUUsT0FBTztvQkFDeEMsNkJBQTZCO2dCQUMvQixZQUFZLEVBQUUsWUFBWSxDQUFDLE1BQU07Z0JBQ2pDLHVCQUF1QixFQUFFLEdBQUcsRUFBRSxhQUFhO2FBQzVDO1NBQ0Y7UUFFRDs7V0FFRztRQUNIO1lBQ0UsSUFBSSxFQUFFLGFBQWEsWUFBWSxDQUFDLE9BQU8sSUFBSSxZQUFZLENBQUMsTUFBTSxFQUFFO1lBQ2hFLEdBQUcsRUFBRSx3RUFBd0UsTUFBTSxPQUFPLFlBQVksQ0FBQyxPQUFPLElBQUksWUFBWSxDQUFDLE1BQU0sR0FBRztTQUN6STtLQUNGLENBQUM7QUFDSixDQUFDLENBQUM7QUFoRVcsUUFBQSxXQUFXLGVBZ0V0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGpvaW4sIHJlbGF0aXZlIH0gZnJvbSBcIm5vZGU6cGF0aFwiO1xuaW1wb3J0IHsgQXdzQ2RrVHlwZVNjcmlwdEFwcCB9IGZyb20gXCJwcm9qZW4vbGliL2F3c2Nka1wiO1xuaW1wb3J0IHsgSm9iU3RlcCB9IGZyb20gXCJwcm9qZW4vbGliL2dpdGh1Yi93b3JrZmxvd3MtbW9kZWxcIjtcbmltcG9ydCB7IEF3c0RlcGxveW1lbnRUYXJnZXQgfSBmcm9tIFwiLi4vLi4vYXdzL2F3cy1kZXBsb3ltZW50LWNvbmZpZ1wiO1xuaW1wb3J0IHsgVkVSU0lPTiB9IGZyb20gXCIuLi8uLi92ZXJzaW9uc1wiO1xuXG5leHBvcnQgY29uc3QgZGVwbG95U3RlcHMgPSAoXG4gIHByb2plY3Q6IEF3c0Nka1R5cGVTY3JpcHRBcHAsXG4gIGRlcGxveVRhcmdldDogQXdzRGVwbG95bWVudFRhcmdldCxcbik6IEFycmF5PEpvYlN0ZXA+ID0+IHtcbiAgY29uc3QgcHJvamVjdFBhdGggPSByZWxhdGl2ZShwcm9qZWN0LnJvb3Qub3V0ZGlyLCBwcm9qZWN0Lm91dGRpcik7XG5cbiAgY29uc3QgY2RrT3V0ID0gam9pbihcImRpc3RcIiwgcHJvamVjdFBhdGgsIFwiY2RrLm91dFwiKTtcblxuICByZXR1cm4gW1xuICAgIC8qKlxuICAgICAqIFNldHVwIFBOUE1cbiAgICAgKi9cbiAgICB7XG4gICAgICBuYW1lOiBcIlNldHVwIFBOUE1cIixcbiAgICAgIHVzZXM6IFwicG5wbS9hY3Rpb24tc2V0dXBAdjNcIixcbiAgICAgIHdpdGg6IHtcbiAgICAgICAgdmVyc2lvbjogVkVSU0lPTi5QTlBNX1ZFUlNJT04sXG4gICAgICB9LFxuICAgIH0sXG5cbiAgICAvKipcbiAgICAgKiBTZXR1cCBOb2RlXG4gICAgICovXG4gICAge1xuICAgICAgbmFtZTogXCJTZXR1cCBOb2RlXCIsXG4gICAgICB1c2VzOiBcImFjdGlvbnMvc2V0dXAtbm9kZUB2NFwiLFxuICAgICAgd2l0aDoge1xuICAgICAgICBbXCJub2RlLXZlcnNpb25cIl06IFZFUlNJT04uTk9ERV9XT1JLRkxPV1MsXG4gICAgICB9LFxuICAgICAgLy8gb2NjYXNpb25hbGx5IHRoaXMgc3RlcCBmYWlscyBkdWUgdG8gaW50ZXJuYWwgaXNzdWVzIGF0IGdpdGh1YlxuICAgICAgdGltZW91dE1pbnV0ZXM6IDEsXG4gICAgfSxcblxuICAgIC8qKlxuICAgICAqIEluc3RhbGwgQ0RLXG4gICAgICovXG4gICAge1xuICAgICAgbmFtZTogXCJJbnN0YWxsIENES1wiLFxuICAgICAgcnVuOiBcInBucG0gYWRkIGF3cy1jZGtcIixcbiAgICB9LFxuXG4gICAgLyoqXG4gICAgICogQ29uZmlndXJlIEFXUyBjcmVkcy5cbiAgICAgKi9cbiAgICB7XG4gICAgICBuYW1lOiBgQ29uZmlndXJlIEFXUyBDcmVkZW50aWFscyBmb3IgJHtkZXBsb3lUYXJnZXQuYWNjb3VudH0vJHtkZXBsb3lUYXJnZXQucmVnaW9ufWAsXG4gICAgICB1c2VzOiBcImF3cy1hY3Rpb25zL2NvbmZpZ3VyZS1hd3MtY3JlZGVudGlhbHNAdjRcIixcbiAgICAgIHdpdGg6IHtcbiAgICAgICAgXCJyb2xlLXRvLWFzc3VtZVwiOlxuICAgICAgICAgIGRlcGxveVRhcmdldC5jaURlcGxveW1lbnRDb25maWc/LnJvbGVBcm4gPz9cbiAgICAgICAgICBcIkVSUk9SOiBObyByb2xlIEFSTiBwcm92aWRlZFwiLFxuICAgICAgICBcImF3cy1yZWdpb25cIjogZGVwbG95VGFyZ2V0LnJlZ2lvbixcbiAgICAgICAgXCJyb2xlLWR1cmF0aW9uLXNlY29uZHNcIjogOTAwLCAvLyAxNSBtaW51dGVzXG4gICAgICB9LFxuICAgIH0sXG5cbiAgICAvKipcbiAgICAgKiBSdW4gQ0RLIERlcGxveVxuICAgICAqL1xuICAgIHtcbiAgICAgIG5hbWU6IGBEZXBsb3kgVG8gJHtkZXBsb3lUYXJnZXQuYWNjb3VudH0vJHtkZXBsb3lUYXJnZXQucmVnaW9ufWAsXG4gICAgICBydW46IGBwbnBtIGRseCBhd3MtY2RrIGRlcGxveSAtLW5vLXJvbGxiYWNrIC0tcmVxdWlyZS1hcHByb3ZhbD1uZXZlciAtLWFwcD0ke2Nka091dH0gXCIqLSR7ZGVwbG95VGFyZ2V0LmFjY291bnR9LSR7ZGVwbG95VGFyZ2V0LnJlZ2lvbn1cImAsXG4gICAgfSxcbiAgXTtcbn07XG4iXX0=