@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,158 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AwsDeploymentTarget = exports.AWS_DEPLOY_TYPE = void 0;
4
+ const projen_1 = require("projen");
5
+ const aws_deployment_config_1 = require("./aws-deployment-config");
6
+ /*******************************************************************************
7
+ *
8
+ * AWS Deployment Configuration
9
+ *
10
+ * A single deployment target that CDK applications can be deployed into.
11
+ *
12
+ ******************************************************************************/
13
+ exports.AWS_DEPLOY_TYPE = {
14
+ /**
15
+ * Development environment, typically used for testing and development.
16
+ */
17
+ DEV: "dev",
18
+ /**
19
+ * Staging environment, used for pre-production testing.
20
+ */
21
+ STAGE: "stage",
22
+ /**
23
+ * Production environment, used for live deployments.
24
+ */
25
+ PROD: "prod",
26
+ };
27
+ class AwsDeploymentTarget extends projen_1.Component {
28
+ /**
29
+ * Static method to discovert targets in a project.
30
+ */
31
+ static of(project) {
32
+ const isDefined = (c) => c instanceof AwsDeploymentTarget;
33
+ return project.components.filter(isDefined);
34
+ }
35
+ constructor(project, options) {
36
+ super(project);
37
+ /**
38
+ * The AWS profile to use for this deployment target.
39
+ *
40
+ * @default ['main'] when prod release type, ['feature/*'] when dev type
41
+ */
42
+ this.branches = [];
43
+ /*****************************************************************************
44
+ *
45
+ * Deploy Tasks
46
+ *
47
+ * - If local deploy, add a deploy task.
48
+ *
49
+ ****************************************************************************/
50
+ this.configureDeployTask = () => {
51
+ if (this.localDeployment) {
52
+ const taskName = ["deploy", this.account, this.region].join(":");
53
+ const deployTask = this.project.tasks.addTask(taskName, {
54
+ env: this.awsDeploymentConfig.env,
55
+ });
56
+ deployTask.exec(`cdk deploy --lookups=false --require-approval=never --profile=${this.localDeploymentConfig?.profile} --app=${this.awsDeploymentConfig.cdkOut} "*-${this.account}-${this.region}"`);
57
+ }
58
+ };
59
+ /*****************************************************************************
60
+ *
61
+ * Watch tasks
62
+ *
63
+ * - Configure watch task to use the branch name
64
+ * - configure watch task to use the correct synth output location.
65
+ *
66
+ ****************************************************************************/
67
+ this.configureWatchTask = () => {
68
+ if (this.localDeployment) {
69
+ const taskName = ["watch", this.account, this.region].join(":");
70
+ const watchTask = this.project.tasks.addTask(taskName, {
71
+ env: this.awsDeploymentConfig.env,
72
+ });
73
+ // update the synth first
74
+ const synthSilent = this.project.tasks.tryFind("synth:silent");
75
+ if (synthSilent) {
76
+ watchTask.spawn(synthSilent);
77
+ }
78
+ // do a normal deploy
79
+ watchTask.exec(`cdk deploy --lookups=false --require-approval=never --profile=${this.localDeploymentConfig?.profile} --app=${this.awsDeploymentConfig.cdkOut} "*-${this.account}-${this.region}"`);
80
+ // watch for changes and log output
81
+ watchTask.exec(`cdk watch --lookups=false --require-approval=never --hotswap --profile=${this.localDeploymentConfig?.profile} "*-${this.account}-${this.region}"`);
82
+ }
83
+ };
84
+ /**
85
+ * Set target region and account.
86
+ */
87
+ this.account = options.account;
88
+ this.region = options.region;
89
+ /**
90
+ * Set default type
91
+ */
92
+ this.awsDeploymentType = options.awsDeploymentType || exports.AWS_DEPLOY_TYPE.DEV;
93
+ /**
94
+ * Set default Branches
95
+ */
96
+ this.branches =
97
+ options.branches || this.awsDeploymentType === exports.AWS_DEPLOY_TYPE.PROD
98
+ ? [
99
+ {
100
+ branch: "main",
101
+ },
102
+ ]
103
+ : [
104
+ {
105
+ branch: "feature/*",
106
+ },
107
+ ];
108
+ /**
109
+ * Set default for local deployment
110
+ */
111
+ this.localDeployment =
112
+ options.localDeployment ?? this.awsDeploymentType === exports.AWS_DEPLOY_TYPE.DEV;
113
+ /**
114
+ * Some default configurations for local deployments.
115
+ */
116
+ if (this.localDeployment) {
117
+ const roleName = options.localDeploymentConfig?.roleName?.toLowerCase() ||
118
+ "administratoraccess";
119
+ const profile = options.localDeploymentConfig?.profile ||
120
+ `${roleName}-${this.account}-${this.region}`;
121
+ this.localDeploymentConfig = {
122
+ profile,
123
+ roleName,
124
+ ...options.localDeploymentConfig,
125
+ };
126
+ }
127
+ /**
128
+ * Set CI deployment default
129
+ */
130
+ this.ciDeployment = options.ciDeployment ?? false;
131
+ /**
132
+ * Some defaults for CI deployments.
133
+ */
134
+ if (this.ciDeployment) {
135
+ const roleArn = options.ciDeploymentConfig?.roleArn ||
136
+ `arn:aws:iam::${this.account}:role/GitHubDeployer}`;
137
+ this.ciDeploymentConfig = {
138
+ roleArn,
139
+ ...options.ciDeploymentConfig,
140
+ };
141
+ }
142
+ /**
143
+ * Find or create CDK folder config for this project.
144
+ */
145
+ this.awsDeploymentConfig =
146
+ aws_deployment_config_1.AwsDeploymentConfig.of(project) || new aws_deployment_config_1.AwsDeploymentConfig(project);
147
+ /**
148
+ * Add the target to the deployment targets array.
149
+ */
150
+ this.awsDeploymentConfig.awsDeploymentTargets.push(this);
151
+ // Deploy tasks are configured per target.
152
+ this.configureDeployTask();
153
+ // Watch tasks are configured per target.
154
+ this.configureWatchTask();
155
+ }
156
+ }
157
+ exports.AwsDeploymentTarget = AwsDeploymentTarget;
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-deployment-target.js","sourceRoot":"","sources":["../../src/aws/aws-deployment-target.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"projen\";\nimport { AwsCdkTypeScriptApp } from \"projen/lib/awscdk\";\nimport { AwsDeploymentConfig } from \"./aws-deployment-config\";\nimport { GitBranch } from \"../git\";\n\n/*******************************************************************************\n *\n * AWS Deployment Configuration\n *\n * A single deployment target that CDK applications can be deployed into.\n *\n ******************************************************************************/\n\nexport const AWS_DEPLOY_TYPE = {\n  /**\n   * Development environment, typically used for testing and development.\n   */\n  DEV: \"dev\",\n\n  /**\n   * Staging environment, used for pre-production testing.\n   */\n  STAGE: \"stage\",\n\n  /**\n   * Production environment, used for live deployments.\n   */\n  PROD: \"prod\",\n} as const;\n\n/**\n * Above const as a type.\n */\nexport type AwsDeploymentType =\n  (typeof AWS_DEPLOY_TYPE)[keyof typeof AWS_DEPLOY_TYPE];\n\n/**\n * Represents the configuration for local deployment in AWS.\n */\nexport interface AwsLocalDeploymentConfig {\n  /**\n   * The AWS profile (in ~/.aws/config) to use for local deployment.\n   *\n   * @default generated dynamically based role name, account and region\n   */\n  readonly profile?: string;\n\n  /**\n   * Named Role used to conduct local deployments.\n   *\n   * @default \"administratoraccess\"\n   */\n  readonly roleName?: string;\n}\n\nexport interface CiDeploymentConfig {\n  /**\n   * The OIDC IAM Role to assume for CI deployments.\n   */\n  readonly roleArn: string;\n}\n\n/**\n * Represents a deployment target in AWS, including account and region, and\n * branches allowed to deploy to this target.\n */\nexport interface AwsDeploymentTargetOptions {\n  /**\n   * The account name for the deployment target.\n   */\n  readonly account: string;\n\n  /**\n   * The AWS region for the deployment target.\n   */\n  readonly region: string;\n\n  /**\n   * AWS deployment type, such as dev, stage, or prod.\n   *\n   * @default 'dev'\n   */\n  readonly awsDeploymentType?: AwsDeploymentType;\n\n  /**\n   * The AWS profile to use for this deployment target.\n   *\n   * @default ['main'] when prod release type, ['feature/*'] when dev type\n   */\n  readonly branches?: Array<GitBranch>;\n\n  /**\n   * Can this deployment target be used for local development?\n   *\n   * @default true for dev environments, false for prod environments\n   */\n  readonly localDeployment?: boolean;\n\n  /**\n   * Configuration when deploying to this target locally.\n   */\n  readonly localDeploymentConfig?: AwsLocalDeploymentConfig;\n\n  /**\n   * Can this deployment target be used in CI deployments?\n   *\n   * @default false\n   */\n  readonly ciDeployment?: boolean;\n\n  /*\n   * Configuration when deploying to this target in CI.\n\n   */\n  readonly ciDeploymentConfig?: CiDeploymentConfig;\n}\n\nexport class AwsDeploymentTarget extends Component {\n  /**\n   * Static method to discovert targets in a project.\n   */\n  public static of(\n    project: AwsCdkTypeScriptApp,\n  ): Array<AwsDeploymentTarget> | undefined {\n    const isDefined = (c: Component): c is AwsDeploymentTarget =>\n      c instanceof AwsDeploymentTarget;\n    return project.components.filter(isDefined);\n  }\n\n  /**\n   * The account name for the deployment target.\n   */\n  public account: string;\n\n  /**\n   * The AWS region for the deployment target.\n   */\n  public region: string;\n\n  /**'\n   * AWS deployment type, such as dev, stage, or prod.\n   *\n   * @default 'dev'\n   */\n  public awsDeploymentType?: AwsDeploymentType;\n\n  /**\n   * The AWS profile to use for this deployment target.\n   *\n   * @default ['main'] when prod release type, ['feature/*'] when dev type\n   */\n  public branches: Array<GitBranch> = [];\n\n  /**\n   * Can this deployment target be used for local development?\n   *\n   * @default true for dev environments, false for prod environments\n   */\n  public localDeployment?: boolean;\n\n  /**\n   * Configuration when deploying to this target locally.\n   */\n  public localDeploymentConfig?: AwsLocalDeploymentConfig;\n\n  /**\n   * Can this deployment target be used in CI deployments?\n   *\n   * @default false\n   */\n  public ciDeployment?: boolean;\n\n  /*\n   * Configuration when deploying to this target in CI.\n   */\n  public ciDeploymentConfig?: Required<CiDeploymentConfig>;\n\n  /**\n   * Configuration for the CDK output directory for this deployment target.\n   */\n  public awsDeploymentConfig: AwsDeploymentConfig;\n\n  constructor(\n    project: AwsCdkTypeScriptApp,\n    options: AwsDeploymentTargetOptions,\n  ) {\n    super(project);\n\n    /**\n     * Set target region and account.\n     */\n    this.account = options.account;\n    this.region = options.region;\n\n    /**\n     * Set default type\n     */\n    this.awsDeploymentType = options.awsDeploymentType || AWS_DEPLOY_TYPE.DEV;\n\n    /**\n     * Set default Branches\n     */\n\n    this.branches =\n      options.branches || this.awsDeploymentType === AWS_DEPLOY_TYPE.PROD\n        ? [\n            {\n              branch: \"main\",\n            },\n          ]\n        : [\n            {\n              branch: \"feature/*\",\n            },\n          ];\n\n    /**\n     * Set default for local deployment\n     */\n    this.localDeployment =\n      options.localDeployment ?? this.awsDeploymentType === AWS_DEPLOY_TYPE.DEV;\n\n    /**\n     * Some default configurations for local deployments.\n     */\n    if (this.localDeployment) {\n      const roleName =\n        options.localDeploymentConfig?.roleName?.toLowerCase() ||\n        \"administratoraccess\";\n      const profile =\n        options.localDeploymentConfig?.profile ||\n        `${roleName}-${this.account}-${this.region}`;\n\n      this.localDeploymentConfig = {\n        profile,\n        roleName,\n        ...options.localDeploymentConfig,\n      };\n    }\n\n    /**\n     * Set CI deployment default\n     */\n    this.ciDeployment = options.ciDeployment ?? false;\n\n    /**\n     * Some defaults for CI deployments.\n     */\n    if (this.ciDeployment) {\n      const roleArn =\n        options.ciDeploymentConfig?.roleArn ||\n        `arn:aws:iam::${this.account}:role/GitHubDeployer}`;\n\n      this.ciDeploymentConfig = {\n        roleArn,\n        ...options.ciDeploymentConfig,\n      };\n    }\n\n    /**\n     * Find or create CDK folder config for this project.\n     */\n    this.awsDeploymentConfig =\n      AwsDeploymentConfig.of(project) || new AwsDeploymentConfig(project);\n\n    /**\n     * Add the target to the deployment targets array.\n     */\n    this.awsDeploymentConfig.awsDeploymentTargets.push(this);\n\n    // Deploy tasks are configured per target.\n    this.configureDeployTask();\n\n    // Watch tasks are configured per target.\n    this.configureWatchTask();\n  }\n\n  /*****************************************************************************\n   *\n   * Deploy Tasks\n   *\n   * - If local deploy, add a deploy task.\n   *\n   ****************************************************************************/\n\n  private configureDeployTask = (): void => {\n    if (this.localDeployment) {\n      const taskName = [\"deploy\", this.account, this.region].join(\":\");\n      const deployTask = this.project.tasks.addTask(taskName, {\n        env: this.awsDeploymentConfig.env,\n      });\n      deployTask.exec(\n        `cdk deploy --lookups=false --require-approval=never --profile=${this.localDeploymentConfig?.profile} --app=${this.awsDeploymentConfig.cdkOut} \"*-${this.account}-${this.region}\"`,\n      );\n    }\n  };\n\n  /*****************************************************************************\n   *\n   * Watch tasks\n   *\n   * - Configure watch task to use the branch name\n   * - configure watch task to use the correct synth output location.\n   *\n   ****************************************************************************/\n\n  private configureWatchTask = (): void => {\n    if (this.localDeployment) {\n      const taskName = [\"watch\", this.account, this.region].join(\":\");\n      const watchTask = this.project.tasks.addTask(taskName, {\n        env: this.awsDeploymentConfig.env,\n      });\n\n      // update the synth first\n      const synthSilent = this.project.tasks.tryFind(\"synth:silent\");\n      if (synthSilent) {\n        watchTask.spawn(synthSilent);\n      }\n\n      // do a normal deploy\n      watchTask.exec(\n        `cdk deploy --lookups=false --require-approval=never --profile=${this.localDeploymentConfig?.profile} --app=${this.awsDeploymentConfig.cdkOut} \"*-${this.account}-${this.region}\"`,\n      );\n\n      // watch for changes and log output\n      watchTask.exec(\n        `cdk watch --lookups=false --require-approval=never --hotswap --profile=${this.localDeploymentConfig?.profile} \"*-${this.account}-${this.region}\"`,\n      );\n    }\n  };\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { Component } from "projen/lib";
1
+ import { Component, Project } from "projen/lib";
2
2
  import { NodeProject } from "projen/lib/javascript";
3
3
  import { TurboRepoTask } from "./turbo-repo-task";
4
4
  /*******************************************************************************
@@ -123,6 +123,10 @@ export interface TurboRepoOptions {
123
123
  }
124
124
  export declare class TurboRepo extends Component {
125
125
  readonly project: NodeProject;
126
+ /**
127
+ * Static method to discovert turbo in a project.
128
+ */
129
+ static of(project: Project): Array<TurboRepo> | undefined;
126
130
  /**
127
131
  * Version of turborepo to use.
128
132
  */
@@ -11,6 +11,13 @@ const turbo_repo_task_1 = require("./turbo-repo-task");
11
11
  exports.ROOT_TURBO_TASK_NAME = "turbo:build";
12
12
  exports.ROOT_CI_TASK_NAME = "build:all";
13
13
  class TurboRepo extends lib_1.Component {
14
+ /**
15
+ * Static method to discovert turbo in a project.
16
+ */
17
+ static of(project) {
18
+ const isDefined = (c) => c instanceof TurboRepo;
19
+ return project.components.filter(isDefined);
20
+ }
14
21
  constructor(project, options = {}) {
15
22
  super(project);
16
23
  this.project = project;
@@ -82,13 +89,6 @@ class TurboRepo extends lib_1.Component {
82
89
  });
83
90
  buildAll.exec("turbo telemetry disable");
84
91
  buildAll.exec(`turbo ${exports.ROOT_TURBO_TASK_NAME} --summarize --concurrency=10`);
85
- /**
86
- * Attach build all turbo runner to the build workflow at github.
87
- */
88
- project.buildWorkflow?.addPostBuildSteps({
89
- name: "Build Sub Projects",
90
- run: `npx projen ${exports.ROOT_CI_TASK_NAME}`,
91
- });
92
92
  }
93
93
  /**
94
94
  * SUB-PROJECT
@@ -207,4 +207,4 @@ class TurboRepo extends lib_1.Component {
207
207
  }
208
208
  }
209
209
  exports.TurboRepo = TurboRepo;
210
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"turbo-repo.js","sourceRoot":"","sources":["../../src/turbo/turbo-repo.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, JsonFile, Task } from \"projen/lib\";\nimport { NodeProject } from \"projen/lib/javascript\";\nimport { TurboRepoTask } from \"./turbo-repo-task\";\n\n/*******************************************************************************\n *\n * Turbo Repo Config\n *\n ******************************************************************************/\n\nexport const ROOT_TURBO_TASK_NAME = \"turbo:build\";\nexport const ROOT_CI_TASK_NAME = \"build:all\";\n\nexport interface TurboRepoOptions {\n  /**\n   * Version of turborepo to use.\n   *\n   * @default: specified in versions file\n   */\n  readonly turboVersion?: string;\n\n  /**\n   * Extend from the root turbo.json to create specific configuration for a package using Package Configurations.\n   *\n   * The only valid value for extends is [\"//\"] to inherit configuration from the root turbo.json.\n   * If extends is used in the root turbo.json, it will be ignored.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#extends\n   */\n  readonly extends?: Array<string>;\n\n  /**\n   * A list of globs that you want to include in all task hashes. If any file matching these globs changes, all tasks will miss cache. Globs are relative to the location of turbo.json.\n   *\n   * By default, all files in source control in the Workspace root are included in the global hash.\n   *\n   * Globs must be in the repository's source control root. Globs outside of the repository aren't supported.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globaldependencies\n   */\n  readonly globalDependencies?: Array<string>;\n\n  /**\n   * A list of environment variables that you want to impact the hash of all tasks. Any change to these environment variables will cause all tasks to miss cache.\n   *\n   * For more on wildcard and negation syntax, see the env section.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globalenv\n   */\n  readonly globalEnv?: Array<string>;\n\n  /**\n   * A list of environment variables that you want to make available to tasks.\n   * Using this key opts all tasks into Strict\n   * Environment Variable Mode.\n   *\n   * Additionally, Turborepo has a built-in set of global passthrough variables\n   * for common cases, like operating system environment variables. This\n   * includes variables like HOME, PATH, APPDATA, SHELL, PWD, and more. The full\n   * list can be found in the source code.\n   *\n   * Passthrough values do not contribute to hashes for caching\n   *\n   * If you want changes in these variables to cause cache misses, you will need\n   * to include them in env or globalEnv.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globalpassthroughenv\n   */\n  readonly globalPassThroughEnv?: Array<string>;\n\n  /**\n   * @default: \"stream\"\n   *\n   * Select a terminal UI for the repository.\n   *\n   * \"tui\" allows for viewing each log at once and interacting with the task.\n   * \"stream\" outputs logs as they come in and is not interactive.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#ui\n   */\n  readonly ui?: \"tui\" | \"stream\";\n\n  /**\n   * @default: false\n   *\n   * Turborepo uses your repository's lockfile to determine caching behavior,\n   * Package Graphs, and more. Because of this, we use the packageManager field\n   * to help you stabilize your Turborepo.\n   *\n   * To help with incremental migration or in situations where you can't use\n   * the packageManager field, you may use\n   * --dangerously-disable-package-manager-check to opt out of this check and\n   * assume the risks of unstable lockfiles producing unpredictable behavior.\n   * When disabled, Turborepo will attempt a best-effort discovery of the\n   * intended package manager meant for the repository.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#dangerouslydisablepackagemanagercheck\n   */\n  readonly dangerouslyDisablePackageManagerCheck?: boolean;\n\n  /**\n   * @default: \".turbo/cache\"\n   *\n   * Specify the filesystem cache directory.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#cachedir\n   */\n  readonly cacheDir?: string;\n\n  /**\n   * @default: true\n   *\n   * Turborepo runs a background process to pre-calculate some expensive\n   * operations. This standalone process (daemon) is a performance optimization,\n   * and not required for proper functioning of turbo.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#daemon\n   */\n  readonly daemon?: boolean;\n\n  /**\n   * @default: \"strict\"\n   *\n   * Turborepo's Environment Modes allow you to control which environment\n   * variables are available to a task at runtime:\n   *\n   *\"strict\": Filter environment variables to only those that are specified\n   * in the env and globalEnv keys in turbo.json.\n   *\n   * \"loose\": Allow all environment variables for the process to be available.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#envmode\n   */\n  readonly envMode?: string;\n}\n\nexport class TurboRepo extends Component {\n  /**\n   * Version of turborepo to use.\n   */\n  public readonly turboVersion: string;\n\n  /**\n   * Extend from the root turbo.json to create specific configuration for a package using Package Configurations.\n   *\n   * The only valid value for extends is [\"//\"] to inherit configuration from the root turbo.json.\n   * If extends is used in the root turbo.json, it will be ignored.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#extends\n   */\n  public readonly extends: Array<string>;\n\n  /**\n   * A list of globs that you want to include in all task hashes. If any file matching these globs changes, all tasks will miss cache. Globs are relative to the location of turbo.json.\n   *\n   * By default, all files in source control in the Workspace root are included in the global hash.\n   *\n   * Globs must be in the repository's source control root. Globs outside of the repository aren't supported.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globaldependencies\n   */\n  public readonly globalDependencies: Array<string>;\n\n  /**\n   * A list of environment variables that you want to impact the hash of all tasks. Any change to these environment variables will cause all tasks to miss cache.\n   *\n   * For more on wildcard and negation syntax, see the env section.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globalenv\n   */\n  public readonly globalEnv: Array<string>;\n\n  /**\n   * A list of environment variables that you want to make available to tasks.\n   * Using this key opts all tasks into Strict\n   * Environment Variable Mode.\n   *\n   * Additionally, Turborepo has a built-in set of global passthrough variables\n   * for common cases, like operating system environment variables. This\n   * includes variables like HOME, PATH, APPDATA, SHELL, PWD, and more. The full\n   * list can be found in the source code.\n   *\n   * Passthrough values do not contribute to hashes for caching\n   *\n   * If you want changes in these variables to cause cache misses, you will need\n   * to include them in env or globalEnv.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globalpassthroughenv\n   */\n  public readonly globalPassThroughEnv: Array<string>;\n\n  /**\n   * @default: \"stream\"\n   *\n   * Select a terminal UI for the repository.\n   *\n   * \"tui\" allows for viewing each log at once and interacting with the task.\n   * \"stream\" outputs logs as they come in and is not interactive.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#ui\n   */\n  public readonly ui: \"tui\" | \"stream\";\n\n  /**\n   * @default: false\n   *\n   * Turborepo uses your repository's lockfile to determine caching behavior,\n   * Package Graphs, and more. Because of this, we use the packageManager field\n   * to help you stabilize your Turborepo.\n   *\n   * To help with incremental migration or in situations where you can't use\n   * the packageManager field, you may use\n   * --dangerously-disable-package-manager-check to opt out of this check and\n   * assume the risks of unstable lockfiles producing unpredictable behavior.\n   * When disabled, Turborepo will attempt a best-effort discovery of the\n   * intended package manager meant for the repository.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#dangerouslydisablepackagemanagercheck\n   */\n  public readonly dangerouslyDisablePackageManagerCheck: boolean;\n\n  /**\n   * @default: \".turbo/cache\"\n   *\n   * Specify the filesystem cache directory.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#cachedir\n   */\n  public readonly cacheDir: string;\n\n  /**\n   * @default: true\n   *\n   * Turborepo runs a background process to pre-calculate some expensive\n   * operations. This standalone process (daemon) is a performance optimization,\n   * and not required for proper functioning of turbo.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#daemon\n   */\n  public readonly daemon: boolean;\n\n  /**\n   * @default: \"strict\"\n   *\n   * Turborepo's Environment Modes allow you to control which environment\n   * variables are available to a task at runtime:\n   *\n   *\"strict\": Filter environment variables to only those that are specified\n   * in the env and globalEnv keys in turbo.json.\n   *\n   * \"loose\": Allow all environment variables for the process to be available.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#envmode\n   */\n  public readonly envMode: string;\n\n  /**\n   * is this the root project?\n   */\n  public readonly isRootProject: boolean;\n\n  /**\n   * Main turbo:build task\n   */\n  public readonly buildTask: TurboRepoTask;\n\n  /**\n   *\n   */\n  public readonly preCompileTask?: TurboRepoTask;\n  /**\n   *\n   */\n  public readonly compileTask?: TurboRepoTask;\n\n  /**\n   *\n   */\n  public readonly postCompileTask?: TurboRepoTask;\n\n  /**\n   *\n   */\n  public readonly testTask?: TurboRepoTask;\n\n  /**\n   *\n   */\n  public readonly packageTask?: TurboRepoTask;\n\n  /**\n   * Sub-Tasks to run\n   */\n  public readonly tasks: Array<TurboRepoTask> = [];\n\n  constructor(\n    public readonly project: NodeProject,\n    options: TurboRepoOptions = {},\n  ) {\n    super(project);\n\n    this.turboVersion = options.turboVersion ?? \"^2.0.0\";\n    this.isRootProject = project === project.root;\n\n    /**\n     * Add turborepo package to root project.\n     */\n    if (this.isRootProject) {\n      project.addDevDeps(`turbo@${this.turboVersion}`);\n    }\n\n    /**\n     * Ignore the working cache for turbo.\n     */\n    project.gitignore.addPatterns(\"/.turbo\");\n    project.npmignore?.addPatterns(\"/.turbo/\");\n\n    /***************************************************************************\n     *\n     * Set some default options\n     *\n     **************************************************************************/\n\n    this.extends = options.extends ?? (this.isRootProject ? [] : [\"//\"]);\n    this.globalDependencies = options.globalDependencies ?? [];\n    this.globalEnv = options.globalEnv ?? [];\n    this.globalPassThroughEnv = options.globalPassThroughEnv ?? [];\n    this.ui = options.ui ?? \"stream\";\n    this.dangerouslyDisablePackageManagerCheck =\n      options.dangerouslyDisablePackageManagerCheck ?? false;\n    this.cacheDir = options.cacheDir ?? \".turbo/cache\";\n    this.daemon = options.daemon ?? true;\n    this.envMode = options.envMode ?? \"strict\";\n\n    /***************************************************************************\n     *\n     * Turbo Build Task\n     *\n     * All turbo configs contain a turbo build task.\n     *\n     **************************************************************************/\n\n    /**\n     * The turbo entry point definition for the turbo:build task. This exists\n     * in each project and is written tot he turbo.json file. This task is not\n     * a projen task or a Node task.\n     */\n    this.buildTask = new TurboRepoTask(this.project, {\n      name: ROOT_TURBO_TASK_NAME,\n      dependsOn: this.isRootProject ? [`^${ROOT_TURBO_TASK_NAME}`] : [],\n    });\n\n    /***************************************************************************\n     *\n     * Turbo Build All Task\n     *\n     * The Projen entry point. This only exists in the root and is a projen\n     * task that can be run using pnpm.\n     *\n     * - Turns off telemetry\n     * - Runs root turbo task to build all sub-projects.\n     *\n     **************************************************************************/\n\n    if (this.isRootProject) {\n      /**\n       * Create and configure the build all task.\n       */\n      const buildAll = this.project.tasks.addTask(ROOT_CI_TASK_NAME, {\n        description:\n          \"Root build followed by sub-project builds. Mimics the CI build process in one step.\",\n      });\n      buildAll.exec(\"turbo telemetry disable\");\n      buildAll.exec(\n        `turbo ${ROOT_TURBO_TASK_NAME} --summarize --concurrency=10`,\n      );\n\n      /**\n       * Attach build all turbo runner to the build workflow at github.\n       */\n      project.buildWorkflow?.addPostBuildSteps({\n        name: \"Build Sub Projects\",\n        run: `npx projen ${ROOT_CI_TASK_NAME}`,\n      });\n    }\n\n    /**\n     * SUB-PROJECT\n     *\n     * Creates tasks for the typical lifecycle for all project projects.\n     */\n    if (!this.isRootProject) {\n      this.preCompileTask = new TurboRepoTask(project, {\n        name: \"pre-compile\",\n        inputs: [\"src/**/*\", \"*.json\"],\n      });\n      this.compileTask = new TurboRepoTask(project, { name: \"compile\" });\n      this.postCompileTask = new TurboRepoTask(project, {\n        name: \"post-compile\",\n      });\n      this.testTask = new TurboRepoTask(project, { name: \"test\" });\n      this.packageTask = new TurboRepoTask(project, {\n        name: \"package\",\n        inputs: [\".npmignore\"],\n      });\n      this.tasks.push(\n        this.preCompileTask,\n        this.compileTask,\n        this.postCompileTask,\n        this.testTask,\n        this.packageTask,\n      );\n    }\n  }\n\n  preSynthesize(): void {\n    /**\n     * Add any local workspace specific deps to dependsOn so that we know\n     * compile has finished before attempting to use any distribution artifacts.\n     *\n     * Do this in presynth so that we can be sure all project dependencies have\n     * been defined first.\n     */\n    let nextDependsOn = this.project.deps.all\n      .filter((d) => d.version === \"workspace:*\")\n      .map((d) => [d.name, ROOT_TURBO_TASK_NAME].join(\"#\"));\n\n    /**\n     * Loop over all projen tasks and their corresponding turbo task\n     * definitions. Chain them together using dependsOn, along with any outside\n     * package dependencies.\n     */\n    if (!this.isRootProject) {\n      (\n        [\n          [this.project.preCompileTask, this.preCompileTask],\n          [this.project.compileTask, this.compileTask],\n          [this.project.postCompileTask, this.postCompileTask],\n          [this.project.testTask, this.testTask],\n          [this.project.packageTask, this.packageTask],\n        ] as Array<[Task, TurboRepoTask]>\n      ).forEach(([pjTask, turboTask]) => {\n        /**\n         * If steps exist chain using dependsOn\n         */\n        if (pjTask && turboTask && pjTask.steps.length > 0) {\n          if (nextDependsOn.length > 0) {\n            turboTask.dependsOn.push(...nextDependsOn);\n          }\n          nextDependsOn = [turboTask.name];\n\n          /**\n           * Otherwise, if a task doesn't do anything, deactivate it.\n           */\n        } else {\n          turboTask.isActive = false;\n        }\n      });\n\n      /**\n       * Main build entry point depends on whatever was last.\n       */\n      this.buildTask.dependsOn.push(...nextDependsOn);\n    }\n\n    /**\n     * The name for the turbo config file.\n     */\n    const fileName: string = \"turbo.json\";\n\n    /**\n     * Ensure that turbo config doesn't end up in any package distributions.\n     */\n    this.project.addPackageIgnore(fileName);\n\n    /**\n     * The content of this YAML file will be resolved at synth time. By then,\n     * any sub-projects will be defined and this will be a complete list.\n     */\n    new JsonFile(this.project, fileName, {\n      obj: {\n        extends: this.extends.length ? this.extends : undefined,\n        globalDependencies:\n          this.isRootProject && this.globalDependencies.length\n            ? this.globalDependencies\n            : undefined,\n        globalEnv:\n          this.isRootProject && this.globalEnv.length\n            ? this.globalEnv\n            : undefined,\n        globalPassThroughEnv:\n          this.isRootProject && this.globalPassThroughEnv.length\n            ? this.globalPassThroughEnv\n            : undefined,\n        ui: this.isRootProject ? this.ui : undefined,\n        dangerouslyDisablePackageManagerCheck: this.isRootProject\n          ? this.dangerouslyDisablePackageManagerCheck\n          : undefined,\n        cacheDir: this.isRootProject ? this.cacheDir : undefined,\n        daemon: this.isRootProject ? this.daemon : undefined,\n        envMode: this.isRootProject ? this.envMode : undefined,\n        /**\n         * All tasks\n         */\n        tasks: this.tasks\n          .filter((task) => task.isActive)\n          .reduce(\n            (acc, task) => {\n              acc[task.name] = {\n                ...task.taskConfig(),\n              };\n              return acc;\n            },\n            {\n              [this.buildTask.name]: { ...this.buildTask.taskConfig() },\n            } as Record<string, any>,\n          ),\n      },\n    });\n\n    super.preSynthesize();\n  }\n}\n"]}
210
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"turbo-repo.js","sourceRoot":"","sources":["../../src/turbo/turbo-repo.ts"],"names":[],"mappings":";;;AAAA,oCAAgE;AAEhE,uDAAkD;AAElD;;;;gFAIgF;AAEnE,QAAA,oBAAoB,GAAG,aAAa,CAAC;AACrC,QAAA,iBAAiB,GAAG,WAAW,CAAC;AA6H7C,MAAa,SAAU,SAAQ,eAAS;IACtC;;OAEG;IACI,MAAM,CAAC,EAAE,CAAC,OAAgB;QAC/B,MAAM,SAAS,GAAG,CAAC,CAAY,EAAkB,EAAE,CAAC,CAAC,YAAY,SAAS,CAAC;QAC3E,OAAO,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IAC9C,CAAC;IAgKD,YACkB,OAAoB,EACpC,UAA4B,EAAE;QAE9B,KAAK,CAAC,OAAO,CAAC,CAAC;QAHC,YAAO,GAAP,OAAO,CAAa;QANtC;;WAEG;QACa,UAAK,GAAyB,EAAE,CAAC;QAQ/C,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,IAAI,QAAQ,CAAC;QACrD,IAAI,CAAC,aAAa,GAAG,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC;QAE9C;;WAEG;QACH,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,OAAO,CAAC,UAAU,CAAC,SAAS,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QACnD,CAAC;QAED;;WAEG;QACH,OAAO,CAAC,SAAS,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QACzC,OAAO,CAAC,SAAS,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC;QAE3C;;;;oFAI4E;QAE5E,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACrE,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC,kBAAkB,IAAI,EAAE,CAAC;QAC3D,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;QACzC,IAAI,CAAC,oBAAoB,GAAG,OAAO,CAAC,oBAAoB,IAAI,EAAE,CAAC;QAC/D,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC,EAAE,IAAI,QAAQ,CAAC;QACjC,IAAI,CAAC,qCAAqC;YACxC,OAAO,CAAC,qCAAqC,IAAI,KAAK,CAAC;QACzD,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,cAAc,CAAC;QACnD,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC;QACrC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,QAAQ,CAAC;QAE3C;;;;;;oFAM4E;QAE5E;;;;WAIG;QACH,IAAI,CAAC,SAAS,GAAG,IAAI,+BAAa,CAAC,IAAI,CAAC,OAAO,EAAE;YAC/C,IAAI,EAAE,4BAAoB;YAC1B,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,4BAAoB,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE;SAClE,CAAC,CAAC;QAEH;;;;;;;;;;oFAU4E;QAE5E,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB;;eAEG;YACH,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAiB,EAAE;gBAC7D,WAAW,EACT,qFAAqF;aACxF,CAAC,CAAC;YACH,QAAQ,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;YACzC,QAAQ,CAAC,IAAI,CACX,SAAS,4BAAoB,+BAA+B,CAC7D,CAAC;QACJ,CAAC;QAED;;;;WAIG;QACH,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACxB,IAAI,CAAC,cAAc,GAAG,IAAI,+BAAa,CAAC,OAAO,EAAE;gBAC/C,IAAI,EAAE,aAAa;gBACnB,MAAM,EAAE,CAAC,UAAU,EAAE,QAAQ,CAAC;aAC/B,CAAC,CAAC;YACH,IAAI,CAAC,WAAW,GAAG,IAAI,+BAAa,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;YACnE,IAAI,CAAC,eAAe,GAAG,IAAI,+BAAa,CAAC,OAAO,EAAE;gBAChD,IAAI,EAAE,cAAc;aACrB,CAAC,CAAC;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,+BAAa,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;YAC7D,IAAI,CAAC,WAAW,GAAG,IAAI,+BAAa,CAAC,OAAO,EAAE;gBAC5C,IAAI,EAAE,SAAS;gBACf,MAAM,EAAE,CAAC,YAAY,CAAC;aACvB,CAAC,CAAC;YACH,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,IAAI,CAAC,cAAc,EACnB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,WAAW,CACjB,CAAC;QACJ,CAAC;IACH,CAAC;IAED,aAAa;QACX;;;;;;WAMG;QACH,IAAI,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG;aACtC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,aAAa,CAAC;aAC1C,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,4BAAoB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QAExD;;;;WAIG;QACH,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YAEtB;gBACE,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,IAAI,CAAC,cAAc,CAAC;gBAClD,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC;gBAC5C,CAAC,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,IAAI,CAAC,eAAe,CAAC;gBACpD,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC;gBACtC,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC;aAE/C,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,EAAE,SAAS,CAAC,EAAE,EAAE;gBAChC;;mBAEG;gBACH,IAAI,MAAM,IAAI,SAAS,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACnD,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;wBAC7B,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC,CAAC;oBAC7C,CAAC;oBACD,aAAa,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;oBAEjC;;uBAEG;gBACL,CAAC;qBAAM,CAAC;oBACN,SAAS,CAAC,QAAQ,GAAG,KAAK,CAAC;gBAC7B,CAAC;YACH,CAAC,CAAC,CAAC;YAEH;;eAEG;YACH,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC,CAAC;QAClD,CAAC;QAED;;WAEG;QACH,MAAM,QAAQ,GAAW,YAAY,CAAC;QAEtC;;WAEG;QACH,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAExC;;;WAGG;QACH,IAAI,cAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE;YACnC,GAAG,EAAE;gBACH,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;gBACvD,kBAAkB,EAChB,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,kBAAkB,CAAC,MAAM;oBAClD,CAAC,CAAC,IAAI,CAAC,kBAAkB;oBACzB,CAAC,CAAC,SAAS;gBACf,SAAS,EACP,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM;oBACzC,CAAC,CAAC,IAAI,CAAC,SAAS;oBAChB,CAAC,CAAC,SAAS;gBACf,oBAAoB,EAClB,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM;oBACpD,CAAC,CAAC,IAAI,CAAC,oBAAoB;oBAC3B,CAAC,CAAC,SAAS;gBACf,EAAE,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS;gBAC5C,qCAAqC,EAAE,IAAI,CAAC,aAAa;oBACvD,CAAC,CAAC,IAAI,CAAC,qCAAqC;oBAC5C,CAAC,CAAC,SAAS;gBACb,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;gBACxD,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;gBACpD,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;gBACtD;;mBAEG;gBACH,KAAK,EAAE,IAAI,CAAC,KAAK;qBACd,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;qBAC/B,MAAM,CACL,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;oBACZ,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG;wBACf,GAAG,IAAI,CAAC,UAAU,EAAE;qBACrB,CAAC;oBACF,OAAO,GAAG,CAAC;gBACb,CAAC,EACD;oBACE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,EAAE;iBACnC,CACzB;aACJ;SACF,CAAC,CAAC;QAEH,KAAK,CAAC,aAAa,EAAE,CAAC;IACxB,CAAC;CACF;AAlYD,8BAkYC","sourcesContent":["import { Component, JsonFile, Project, Task } from \"projen/lib\";\nimport { NodeProject } from \"projen/lib/javascript\";\nimport { TurboRepoTask } from \"./turbo-repo-task\";\n\n/*******************************************************************************\n *\n * Turbo Repo Config\n *\n ******************************************************************************/\n\nexport const ROOT_TURBO_TASK_NAME = \"turbo:build\";\nexport const ROOT_CI_TASK_NAME = \"build:all\";\n\nexport interface TurboRepoOptions {\n  /**\n   * Version of turborepo to use.\n   *\n   * @default: specified in versions file\n   */\n  readonly turboVersion?: string;\n\n  /**\n   * Extend from the root turbo.json to create specific configuration for a package using Package Configurations.\n   *\n   * The only valid value for extends is [\"//\"] to inherit configuration from the root turbo.json.\n   * If extends is used in the root turbo.json, it will be ignored.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#extends\n   */\n  readonly extends?: Array<string>;\n\n  /**\n   * A list of globs that you want to include in all task hashes. If any file matching these globs changes, all tasks will miss cache. Globs are relative to the location of turbo.json.\n   *\n   * By default, all files in source control in the Workspace root are included in the global hash.\n   *\n   * Globs must be in the repository's source control root. Globs outside of the repository aren't supported.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globaldependencies\n   */\n  readonly globalDependencies?: Array<string>;\n\n  /**\n   * A list of environment variables that you want to impact the hash of all tasks. Any change to these environment variables will cause all tasks to miss cache.\n   *\n   * For more on wildcard and negation syntax, see the env section.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globalenv\n   */\n  readonly globalEnv?: Array<string>;\n\n  /**\n   * A list of environment variables that you want to make available to tasks.\n   * Using this key opts all tasks into Strict\n   * Environment Variable Mode.\n   *\n   * Additionally, Turborepo has a built-in set of global passthrough variables\n   * for common cases, like operating system environment variables. This\n   * includes variables like HOME, PATH, APPDATA, SHELL, PWD, and more. The full\n   * list can be found in the source code.\n   *\n   * Passthrough values do not contribute to hashes for caching\n   *\n   * If you want changes in these variables to cause cache misses, you will need\n   * to include them in env or globalEnv.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globalpassthroughenv\n   */\n  readonly globalPassThroughEnv?: Array<string>;\n\n  /**\n   * @default: \"stream\"\n   *\n   * Select a terminal UI for the repository.\n   *\n   * \"tui\" allows for viewing each log at once and interacting with the task.\n   * \"stream\" outputs logs as they come in and is not interactive.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#ui\n   */\n  readonly ui?: \"tui\" | \"stream\";\n\n  /**\n   * @default: false\n   *\n   * Turborepo uses your repository's lockfile to determine caching behavior,\n   * Package Graphs, and more. Because of this, we use the packageManager field\n   * to help you stabilize your Turborepo.\n   *\n   * To help with incremental migration or in situations where you can't use\n   * the packageManager field, you may use\n   * --dangerously-disable-package-manager-check to opt out of this check and\n   * assume the risks of unstable lockfiles producing unpredictable behavior.\n   * When disabled, Turborepo will attempt a best-effort discovery of the\n   * intended package manager meant for the repository.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#dangerouslydisablepackagemanagercheck\n   */\n  readonly dangerouslyDisablePackageManagerCheck?: boolean;\n\n  /**\n   * @default: \".turbo/cache\"\n   *\n   * Specify the filesystem cache directory.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#cachedir\n   */\n  readonly cacheDir?: string;\n\n  /**\n   * @default: true\n   *\n   * Turborepo runs a background process to pre-calculate some expensive\n   * operations. This standalone process (daemon) is a performance optimization,\n   * and not required for proper functioning of turbo.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#daemon\n   */\n  readonly daemon?: boolean;\n\n  /**\n   * @default: \"strict\"\n   *\n   * Turborepo's Environment Modes allow you to control which environment\n   * variables are available to a task at runtime:\n   *\n   *\"strict\": Filter environment variables to only those that are specified\n   * in the env and globalEnv keys in turbo.json.\n   *\n   * \"loose\": Allow all environment variables for the process to be available.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#envmode\n   */\n  readonly envMode?: string;\n}\n\nexport class TurboRepo extends Component {\n  /**\n   * Static method to discovert turbo in a project.\n   */\n  public static of(project: Project): Array<TurboRepo> | undefined {\n    const isDefined = (c: Component): c is TurboRepo => c instanceof TurboRepo;\n    return project.components.filter(isDefined);\n  }\n\n  /**\n   * Version of turborepo to use.\n   */\n  public readonly turboVersion: string;\n\n  /**\n   * Extend from the root turbo.json to create specific configuration for a package using Package Configurations.\n   *\n   * The only valid value for extends is [\"//\"] to inherit configuration from the root turbo.json.\n   * If extends is used in the root turbo.json, it will be ignored.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#extends\n   */\n  public readonly extends: Array<string>;\n\n  /**\n   * A list of globs that you want to include in all task hashes. If any file matching these globs changes, all tasks will miss cache. Globs are relative to the location of turbo.json.\n   *\n   * By default, all files in source control in the Workspace root are included in the global hash.\n   *\n   * Globs must be in the repository's source control root. Globs outside of the repository aren't supported.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globaldependencies\n   */\n  public readonly globalDependencies: Array<string>;\n\n  /**\n   * A list of environment variables that you want to impact the hash of all tasks. Any change to these environment variables will cause all tasks to miss cache.\n   *\n   * For more on wildcard and negation syntax, see the env section.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globalenv\n   */\n  public readonly globalEnv: Array<string>;\n\n  /**\n   * A list of environment variables that you want to make available to tasks.\n   * Using this key opts all tasks into Strict\n   * Environment Variable Mode.\n   *\n   * Additionally, Turborepo has a built-in set of global passthrough variables\n   * for common cases, like operating system environment variables. This\n   * includes variables like HOME, PATH, APPDATA, SHELL, PWD, and more. The full\n   * list can be found in the source code.\n   *\n   * Passthrough values do not contribute to hashes for caching\n   *\n   * If you want changes in these variables to cause cache misses, you will need\n   * to include them in env or globalEnv.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#globalpassthroughenv\n   */\n  public readonly globalPassThroughEnv: Array<string>;\n\n  /**\n   * @default: \"stream\"\n   *\n   * Select a terminal UI for the repository.\n   *\n   * \"tui\" allows for viewing each log at once and interacting with the task.\n   * \"stream\" outputs logs as they come in and is not interactive.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#ui\n   */\n  public readonly ui: \"tui\" | \"stream\";\n\n  /**\n   * @default: false\n   *\n   * Turborepo uses your repository's lockfile to determine caching behavior,\n   * Package Graphs, and more. Because of this, we use the packageManager field\n   * to help you stabilize your Turborepo.\n   *\n   * To help with incremental migration or in situations where you can't use\n   * the packageManager field, you may use\n   * --dangerously-disable-package-manager-check to opt out of this check and\n   * assume the risks of unstable lockfiles producing unpredictable behavior.\n   * When disabled, Turborepo will attempt a best-effort discovery of the\n   * intended package manager meant for the repository.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#dangerouslydisablepackagemanagercheck\n   */\n  public readonly dangerouslyDisablePackageManagerCheck: boolean;\n\n  /**\n   * @default: \".turbo/cache\"\n   *\n   * Specify the filesystem cache directory.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#cachedir\n   */\n  public readonly cacheDir: string;\n\n  /**\n   * @default: true\n   *\n   * Turborepo runs a background process to pre-calculate some expensive\n   * operations. This standalone process (daemon) is a performance optimization,\n   * and not required for proper functioning of turbo.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#daemon\n   */\n  public readonly daemon: boolean;\n\n  /**\n   * @default: \"strict\"\n   *\n   * Turborepo's Environment Modes allow you to control which environment\n   * variables are available to a task at runtime:\n   *\n   *\"strict\": Filter environment variables to only those that are specified\n   * in the env and globalEnv keys in turbo.json.\n   *\n   * \"loose\": Allow all environment variables for the process to be available.\n   *\n   * https://turbo.build/repo/docs/reference/configuration#envmode\n   */\n  public readonly envMode: string;\n\n  /**\n   * is this the root project?\n   */\n  public readonly isRootProject: boolean;\n\n  /**\n   * Main turbo:build task\n   */\n  public readonly buildTask: TurboRepoTask;\n\n  /**\n   *\n   */\n  public readonly preCompileTask?: TurboRepoTask;\n  /**\n   *\n   */\n  public readonly compileTask?: TurboRepoTask;\n\n  /**\n   *\n   */\n  public readonly postCompileTask?: TurboRepoTask;\n\n  /**\n   *\n   */\n  public readonly testTask?: TurboRepoTask;\n\n  /**\n   *\n   */\n  public readonly packageTask?: TurboRepoTask;\n\n  /**\n   * Sub-Tasks to run\n   */\n  public readonly tasks: Array<TurboRepoTask> = [];\n\n  constructor(\n    public readonly project: NodeProject,\n    options: TurboRepoOptions = {},\n  ) {\n    super(project);\n\n    this.turboVersion = options.turboVersion ?? \"^2.0.0\";\n    this.isRootProject = project === project.root;\n\n    /**\n     * Add turborepo package to root project.\n     */\n    if (this.isRootProject) {\n      project.addDevDeps(`turbo@${this.turboVersion}`);\n    }\n\n    /**\n     * Ignore the working cache for turbo.\n     */\n    project.gitignore.addPatterns(\"/.turbo\");\n    project.npmignore?.addPatterns(\"/.turbo/\");\n\n    /***************************************************************************\n     *\n     * Set some default options\n     *\n     **************************************************************************/\n\n    this.extends = options.extends ?? (this.isRootProject ? [] : [\"//\"]);\n    this.globalDependencies = options.globalDependencies ?? [];\n    this.globalEnv = options.globalEnv ?? [];\n    this.globalPassThroughEnv = options.globalPassThroughEnv ?? [];\n    this.ui = options.ui ?? \"stream\";\n    this.dangerouslyDisablePackageManagerCheck =\n      options.dangerouslyDisablePackageManagerCheck ?? false;\n    this.cacheDir = options.cacheDir ?? \".turbo/cache\";\n    this.daemon = options.daemon ?? true;\n    this.envMode = options.envMode ?? \"strict\";\n\n    /***************************************************************************\n     *\n     * Turbo Build Task\n     *\n     * All turbo configs contain a turbo build task.\n     *\n     **************************************************************************/\n\n    /**\n     * The turbo entry point definition for the turbo:build task. This exists\n     * in each project and is written tot he turbo.json file. This task is not\n     * a projen task or a Node task.\n     */\n    this.buildTask = new TurboRepoTask(this.project, {\n      name: ROOT_TURBO_TASK_NAME,\n      dependsOn: this.isRootProject ? [`^${ROOT_TURBO_TASK_NAME}`] : [],\n    });\n\n    /***************************************************************************\n     *\n     * Turbo Build All Task\n     *\n     * The Projen entry point. This only exists in the root and is a projen\n     * task that can be run using pnpm.\n     *\n     * - Turns off telemetry\n     * - Runs root turbo task to build all sub-projects.\n     *\n     **************************************************************************/\n\n    if (this.isRootProject) {\n      /**\n       * Create and configure the build all task.\n       */\n      const buildAll = this.project.tasks.addTask(ROOT_CI_TASK_NAME, {\n        description:\n          \"Root build followed by sub-project builds. Mimics the CI build process in one step.\",\n      });\n      buildAll.exec(\"turbo telemetry disable\");\n      buildAll.exec(\n        `turbo ${ROOT_TURBO_TASK_NAME} --summarize --concurrency=10`,\n      );\n    }\n\n    /**\n     * SUB-PROJECT\n     *\n     * Creates tasks for the typical lifecycle for all project projects.\n     */\n    if (!this.isRootProject) {\n      this.preCompileTask = new TurboRepoTask(project, {\n        name: \"pre-compile\",\n        inputs: [\"src/**/*\", \"*.json\"],\n      });\n      this.compileTask = new TurboRepoTask(project, { name: \"compile\" });\n      this.postCompileTask = new TurboRepoTask(project, {\n        name: \"post-compile\",\n      });\n      this.testTask = new TurboRepoTask(project, { name: \"test\" });\n      this.packageTask = new TurboRepoTask(project, {\n        name: \"package\",\n        inputs: [\".npmignore\"],\n      });\n      this.tasks.push(\n        this.preCompileTask,\n        this.compileTask,\n        this.postCompileTask,\n        this.testTask,\n        this.packageTask,\n      );\n    }\n  }\n\n  preSynthesize(): void {\n    /**\n     * Add any local workspace specific deps to dependsOn so that we know\n     * compile has finished before attempting to use any distribution artifacts.\n     *\n     * Do this in presynth so that we can be sure all project dependencies have\n     * been defined first.\n     */\n    let nextDependsOn = this.project.deps.all\n      .filter((d) => d.version === \"workspace:*\")\n      .map((d) => [d.name, ROOT_TURBO_TASK_NAME].join(\"#\"));\n\n    /**\n     * Loop over all projen tasks and their corresponding turbo task\n     * definitions. Chain them together using dependsOn, along with any outside\n     * package dependencies.\n     */\n    if (!this.isRootProject) {\n      (\n        [\n          [this.project.preCompileTask, this.preCompileTask],\n          [this.project.compileTask, this.compileTask],\n          [this.project.postCompileTask, this.postCompileTask],\n          [this.project.testTask, this.testTask],\n          [this.project.packageTask, this.packageTask],\n        ] as Array<[Task, TurboRepoTask]>\n      ).forEach(([pjTask, turboTask]) => {\n        /**\n         * If steps exist chain using dependsOn\n         */\n        if (pjTask && turboTask && pjTask.steps.length > 0) {\n          if (nextDependsOn.length > 0) {\n            turboTask.dependsOn.push(...nextDependsOn);\n          }\n          nextDependsOn = [turboTask.name];\n\n          /**\n           * Otherwise, if a task doesn't do anything, deactivate it.\n           */\n        } else {\n          turboTask.isActive = false;\n        }\n      });\n\n      /**\n       * Main build entry point depends on whatever was last.\n       */\n      this.buildTask.dependsOn.push(...nextDependsOn);\n    }\n\n    /**\n     * The name for the turbo config file.\n     */\n    const fileName: string = \"turbo.json\";\n\n    /**\n     * Ensure that turbo config doesn't end up in any package distributions.\n     */\n    this.project.addPackageIgnore(fileName);\n\n    /**\n     * The content of this YAML file will be resolved at synth time. By then,\n     * any sub-projects will be defined and this will be a complete list.\n     */\n    new JsonFile(this.project, fileName, {\n      obj: {\n        extends: this.extends.length ? this.extends : undefined,\n        globalDependencies:\n          this.isRootProject && this.globalDependencies.length\n            ? this.globalDependencies\n            : undefined,\n        globalEnv:\n          this.isRootProject && this.globalEnv.length\n            ? this.globalEnv\n            : undefined,\n        globalPassThroughEnv:\n          this.isRootProject && this.globalPassThroughEnv.length\n            ? this.globalPassThroughEnv\n            : undefined,\n        ui: this.isRootProject ? this.ui : undefined,\n        dangerouslyDisablePackageManagerCheck: this.isRootProject\n          ? this.dangerouslyDisablePackageManagerCheck\n          : undefined,\n        cacheDir: this.isRootProject ? this.cacheDir : undefined,\n        daemon: this.isRootProject ? this.daemon : undefined,\n        envMode: this.isRootProject ? this.envMode : undefined,\n        /**\n         * All tasks\n         */\n        tasks: this.tasks\n          .filter((task) => task.isActive)\n          .reduce(\n            (acc, task) => {\n              acc[task.name] = {\n                ...task.taskConfig(),\n              };\n              return acc;\n            },\n            {\n              [this.buildTask.name]: { ...this.buildTask.taskConfig() },\n            } as Record<string, any>,\n          ),\n      },\n    });\n\n    super.preSynthesize();\n  }\n}\n"]}
package/lib/versions.d.ts CHANGED
@@ -1,12 +1,16 @@
1
1
  export declare const VERSION: {
2
2
  /**
3
- * CDK CLI for workflows and command line operations..
3
+ * CDK CLI for workflows and command line operations.
4
+ *
5
+ * CLI and lib are versioned separately, so this is the CLI version.
4
6
  */
5
- readonly CDK_CLI_VERISON: "2.1018.0";
7
+ readonly AWS_CDK_CLI_VERSION: "2.1024.0";
6
8
  /**
7
9
  * CDK Version to use for construct projects.
10
+ *
11
+ * CLI and lib are versioned separately, so this is the lib version.
8
12
  */
9
- readonly CDK_LIB_VERISON: "2.200.1";
13
+ readonly AWS_CDK_LIB_VERSION: "2.210.0";
10
14
  /**
11
15
  * Version of Node.js to use in workflows at github actions.
12
16
  */
package/lib/versions.js CHANGED
@@ -3,13 +3,17 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.VERSION = void 0;
4
4
  exports.VERSION = {
5
5
  /**
6
- * CDK CLI for workflows and command line operations..
6
+ * CDK CLI for workflows and command line operations.
7
+ *
8
+ * CLI and lib are versioned separately, so this is the CLI version.
7
9
  */
8
- CDK_CLI_VERISON: "2.1018.0",
10
+ AWS_CDK_CLI_VERSION: "2.1024.0",
9
11
  /**
10
12
  * CDK Version to use for construct projects.
13
+ *
14
+ * CLI and lib are versioned separately, so this is the lib version.
11
15
  */
12
- CDK_LIB_VERISON: "2.200.1",
16
+ AWS_CDK_LIB_VERSION: "2.210.0",
13
17
  /**
14
18
  * Version of Node.js to use in workflows at github actions.
15
19
  */
@@ -23,4 +27,4 @@ exports.VERSION = {
23
27
  */
24
28
  TURBO_VERSION: "2.5.4",
25
29
  };
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdmVyc2lvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQWEsUUFBQSxPQUFPLEdBQUc7SUFDckI7O09BRUc7SUFDSCxlQUFlLEVBQUUsVUFBVTtJQUUzQjs7T0FFRztJQUNILGVBQWUsRUFBRSxTQUFTO0lBRTFCOztPQUVHO0lBQ0gsY0FBYyxFQUFFLElBQUk7SUFFcEI7O09BRUc7SUFDSCxZQUFZLEVBQUUsU0FBUztJQUV2Qjs7T0FFRztJQUNILGFBQWEsRUFBRSxPQUFPO0NBQ2QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBWRVJTSU9OID0ge1xuICAvKipcbiAgICogQ0RLIENMSSBmb3Igd29ya2Zsb3dzIGFuZCBjb21tYW5kIGxpbmUgb3BlcmF0aW9ucy4uXG4gICAqL1xuICBDREtfQ0xJX1ZFUklTT046IFwiMi4xMDE4LjBcIixcblxuICAvKipcbiAgICogQ0RLIFZlcnNpb24gdG8gdXNlIGZvciBjb25zdHJ1Y3QgcHJvamVjdHMuXG4gICAqL1xuICBDREtfTElCX1ZFUklTT046IFwiMi4yMDAuMVwiLFxuXG4gIC8qKlxuICAgKiBWZXJzaW9uIG9mIE5vZGUuanMgdG8gdXNlIGluIHdvcmtmbG93cyBhdCBnaXRodWIgYWN0aW9ucy5cbiAgICovXG4gIE5PREVfV09SS0ZMT1dTOiBcIjIwXCIsXG5cbiAgLyoqXG4gICAqIFZlcnNpb24gb2YgUE5QTSB0byB1c2UgaW4gd29ya2Zsb3dzIGF0IGdpdGh1YiBhY3Rpb25zLlxuICAgKi9cbiAgUE5QTV9WRVJTSU9OOiBcIjEwLjEzLjFcIixcblxuICAvKipcbiAgICogV2hhdCB2ZXJzaW9uIG9mIHRoZSB0dXJib3JlcG8gbGlicmFyeSBzaG91bGQgd2UgdXNlP1xuICAgKi9cbiAgVFVSQk9fVkVSU0lPTjogXCIyLjUuNFwiLFxufSBhcyBjb25zdDtcbiJdfQ==
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdmVyc2lvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQWEsUUFBQSxPQUFPLEdBQUc7SUFDckI7Ozs7T0FJRztJQUNILG1CQUFtQixFQUFFLFVBQVU7SUFFL0I7Ozs7T0FJRztJQUNILG1CQUFtQixFQUFFLFNBQVM7SUFFOUI7O09BRUc7SUFDSCxjQUFjLEVBQUUsSUFBSTtJQUVwQjs7T0FFRztJQUNILFlBQVksRUFBRSxTQUFTO0lBRXZCOztPQUVHO0lBQ0gsYUFBYSxFQUFFLE9BQU87Q0FDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFZFUlNJT04gPSB7XG4gIC8qKlxuICAgKiBDREsgQ0xJIGZvciB3b3JrZmxvd3MgYW5kIGNvbW1hbmQgbGluZSBvcGVyYXRpb25zLlxuICAgKlxuICAgKiBDTEkgYW5kIGxpYiBhcmUgdmVyc2lvbmVkIHNlcGFyYXRlbHksIHNvIHRoaXMgaXMgdGhlIENMSSB2ZXJzaW9uLlxuICAgKi9cbiAgQVdTX0NES19DTElfVkVSU0lPTjogXCIyLjEwMjQuMFwiLFxuXG4gIC8qKlxuICAgKiBDREsgVmVyc2lvbiB0byB1c2UgZm9yIGNvbnN0cnVjdCBwcm9qZWN0cy5cbiAgICpcbiAgICogQ0xJIGFuZCBsaWIgYXJlIHZlcnNpb25lZCBzZXBhcmF0ZWx5LCBzbyB0aGlzIGlzIHRoZSBsaWIgdmVyc2lvbi5cbiAgICovXG4gIEFXU19DREtfTElCX1ZFUlNJT046IFwiMi4yMTAuMFwiLFxuXG4gIC8qKlxuICAgKiBWZXJzaW9uIG9mIE5vZGUuanMgdG8gdXNlIGluIHdvcmtmbG93cyBhdCBnaXRodWIgYWN0aW9ucy5cbiAgICovXG4gIE5PREVfV09SS0ZMT1dTOiBcIjIwXCIsXG5cbiAgLyoqXG4gICAqIFZlcnNpb24gb2YgUE5QTSB0byB1c2UgaW4gd29ya2Zsb3dzIGF0IGdpdGh1YiBhY3Rpb25zLlxuICAgKi9cbiAgUE5QTV9WRVJTSU9OOiBcIjEwLjEzLjFcIixcblxuICAvKipcbiAgICogV2hhdCB2ZXJzaW9uIG9mIHRoZSB0dXJib3JlcG8gbGlicmFyeSBzaG91bGQgd2UgdXNlP1xuICAgKi9cbiAgVFVSQk9fVkVSU0lPTjogXCIyLjUuNFwiLFxufSBhcyBjb25zdDtcbiJdfQ==
@@ -0,0 +1,54 @@
1
+ import { Component } from "projen";
2
+ import { AwsCdkTypeScriptApp } from "projen/lib/awscdk";
3
+ import { BuildWorkflow, BuildWorkflowOptions } from "projen/lib/build";
4
+ import { ValueOf } from "type-fest";
5
+ import { AWS_DEPLOY_TYPE, AwsDeploymentTarget } from "../aws/aws-deployment-target";
6
+ export declare const PROD_DEPLOY_NAME = "prod-deploy";
7
+ export interface DeployWorkflowOptions {
8
+ /**
9
+ * What type of deploy is this workflow for?
10
+ *
11
+ * @default AWS_DEPLOY_TYPE.DEV
12
+ */
13
+ readonly awsDeployType?: ValueOf<typeof AWS_DEPLOY_TYPE>;
14
+ /**
15
+ * Optionally feed a list of targets to deploy to.
16
+ *
17
+ * @default discovers all targets using deployType
18
+ */
19
+ readonly awsDeploymentTargets?: Array<AwsDeploymentTarget>;
20
+ /**
21
+ * Existing workflow, useful if we're tacking deployments onto an existing
22
+ * build workflow
23
+ */
24
+ readonly buildWorkflow?: BuildWorkflow;
25
+ /**
26
+ * Options for the build workflow, if no build workflow is provided.
27
+ */
28
+ readonly buildWorkflowOptions?: BuildWorkflowOptions;
29
+ }
30
+ export declare class AwsDeployWorkflow extends Component {
31
+ project: AwsCdkTypeScriptApp;
32
+ static of(project: AwsCdkTypeScriptApp, buildWorkflow: BuildWorkflow): AwsDeployWorkflow | undefined;
33
+ /**
34
+ * The root project for this deploy workflow. Must be a monorepo project.
35
+ */
36
+ private rootProject;
37
+ /**
38
+ * What type of deploy is this workflow for?
39
+ */
40
+ awsDeployType: ValueOf<typeof AWS_DEPLOY_TYPE>;
41
+ /**
42
+ * The list of targets to deploy to.
43
+ */
44
+ readonly awsDeploymentTargets: Array<AwsDeploymentTarget>;
45
+ /**
46
+ * Hold the deploy workflow so we can add to it in preSynth
47
+ */
48
+ buildWorkflow: BuildWorkflow;
49
+ constructor(project: AwsCdkTypeScriptApp, options?: DeployWorkflowOptions);
50
+ private setupNode;
51
+ private setupPnpm;
52
+ private deploySteps;
53
+ preSynthesize(): void;
54
+ }