@codedrifters/configulator 0.0.85 → 0.0.87

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/lib/index.d.mts +1311 -0
  2. package/lib/index.d.ts +1311 -10
  3. package/lib/index.js +1508 -26
  4. package/lib/index.js.map +1 -0
  5. package/lib/index.mjs +1497 -0
  6. package/lib/index.mjs.map +1 -0
  7. package/package.json +11 -8
  8. package/lib/aws/aws-deployment-config.d.ts +0 -78
  9. package/lib/aws/aws-deployment-config.js +0 -134
  10. package/lib/aws/aws-deployment-target.d.ts +0 -183
  11. package/lib/aws/aws-deployment-target.js +0 -163
  12. package/lib/aws/aws-types.d.ts +0 -63
  13. package/lib/aws/aws-types.js +0 -9
  14. package/lib/aws/index.d.ts +0 -2
  15. package/lib/aws/index.js +0 -19
  16. package/lib/git/git-types.d.ts +0 -18
  17. package/lib/git/git-types.js +0 -9
  18. package/lib/git/index.d.ts +0 -1
  19. package/lib/git/index.js +0 -18
  20. package/lib/jsii/index.d.ts +0 -1
  21. package/lib/jsii/index.js +0 -18
  22. package/lib/jsii/jsii-faker.d.ts +0 -47
  23. package/lib/jsii/jsii-faker.js +0 -103
  24. package/lib/pnpm/index.d.ts +0 -1
  25. package/lib/pnpm/index.js +0 -18
  26. package/lib/pnpm/pnpm-workspace.d.ts +0 -244
  27. package/lib/pnpm/pnpm-workspace.js +0 -176
  28. package/lib/projects/index.d.ts +0 -2
  29. package/lib/projects/index.js +0 -19
  30. package/lib/projects/monorepo-project.d.ts +0 -82
  31. package/lib/projects/monorepo-project.js +0 -277
  32. package/lib/projects/typescript-project.d.ts +0 -20
  33. package/lib/projects/typescript-project.js +0 -181
  34. package/lib/tasks/index.d.ts +0 -1
  35. package/lib/tasks/index.js +0 -18
  36. package/lib/tasks/reset-task.d.ts +0 -51
  37. package/lib/tasks/reset-task.js +0 -149
  38. package/lib/turbo/index.d.ts +0 -2
  39. package/lib/turbo/index.js +0 -19
  40. package/lib/turbo/turbo-repo-task.d.ts +0 -36
  41. package/lib/turbo/turbo-repo-task.js +0 -43
  42. package/lib/turbo/turbo-repo.d.ts +0 -375
  43. package/lib/turbo/turbo-repo.js +0 -299
  44. package/lib/typescript/index.d.ts +0 -1
  45. package/lib/typescript/index.js +0 -18
  46. package/lib/typescript/typescript-config.d.ts +0 -13
  47. package/lib/typescript/typescript-config.js +0 -40
  48. package/lib/versions.d.ts +0 -34
  49. package/lib/versions.js +0 -38
  50. package/lib/vscode/index.d.ts +0 -1
  51. package/lib/vscode/index.js +0 -18
  52. package/lib/vscode/vscode.d.ts +0 -10
  53. package/lib/vscode/vscode.js +0 -38
  54. package/lib/workflows/aws-deploy-workflow.d.ts +0 -86
  55. package/lib/workflows/aws-deploy-workflow.js +0 -313
  56. package/lib/workflows/index.d.ts +0 -1
  57. package/lib/workflows/index.js +0 -18
@@ -1,51 +0,0 @@
1
- import { Component, Project } from "projen";
2
- /*******************************************************************************
3
- *
4
- * Reset Task Component
5
- *
6
- * Adds a "reset" task that deletes all build artifacts produced by the build
7
- * process. This includes node_modules, lib, dist, coverage, test-reports,
8
- * .turbo, and tsconfig.tsbuildinfo.
9
- *
10
- ******************************************************************************/
11
- export interface ResetTaskOptions {
12
- /**
13
- * Custom output directory to delete (overrides tsconfig artifactsDirectory detection).
14
- *
15
- * @default - detected from typescript project.artifactsDirectory or "lib"
16
- */
17
- readonly artifactsDirectory?: string;
18
- /**
19
- * Array of glob patterns for paths to remove.
20
- * If empty, the artifactsDirectory will be added automatically.
21
- *
22
- * @default []
23
- */
24
- readonly pathsToRemove?: string[];
25
- /**
26
- * Name of the task to create.
27
- *
28
- * @default "reset"
29
- */
30
- readonly taskName?: string;
31
- }
32
- export declare class ResetTask extends Component {
33
- readonly project: Project;
34
- /**
35
- * Static method to discover reset task in a project.
36
- */
37
- static of(project: Project): ResetTask | undefined;
38
- /**
39
- * The output directory to delete (from tsconfig or custom).
40
- */
41
- readonly artifactsDirectory: string;
42
- /**
43
- * The final array of paths that will be removed by the reset task.
44
- */
45
- readonly pathsToRemove: string[];
46
- /**
47
- * The name of the task that was created.
48
- */
49
- readonly taskName: string;
50
- constructor(project: Project, options?: ResetTaskOptions);
51
- }
@@ -1,149 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ResetTask = void 0;
4
- const projen_1 = require("projen");
5
- const typescript_project_1 = require("../projects/typescript-project");
6
- const turbo_repo_1 = require("../turbo/turbo-repo");
7
- const turbo_repo_task_1 = require("../turbo/turbo-repo-task");
8
- class ResetTask extends projen_1.Component {
9
- /**
10
- * Static method to discover reset task in a project.
11
- */
12
- static of(project) {
13
- const isDefined = (c) => c instanceof ResetTask;
14
- return project.components.find(isDefined);
15
- }
16
- constructor(project, options = {}) {
17
- super(project);
18
- this.project = project;
19
- /**
20
- * Determine the output directory.
21
- * 1. Use custom artifactsDirectory if provided
22
- * 2. Use the artifacts directory if project is TypeScriptProject
23
- * 3. Default to "lib"
24
- */
25
- this.artifactsDirectory = options.artifactsDirectory
26
- ? options.artifactsDirectory
27
- : project instanceof typescript_project_1.TypeScriptProject
28
- ? project.artifactsDirectory
29
- : "lib";
30
- /**
31
- * Build the paths array to remove.
32
- * If pathsToRemove is empty, add artifactsDirectory.
33
- * If pathsToRemove is not empty, use it as-is (artifactsDirectory is not automatically added).
34
- * Remove duplicate entries from the array.
35
- */
36
- const pathsToRemove = options.pathsToRemove ?? [];
37
- const finalPaths = pathsToRemove.length === 0 ? [this.artifactsDirectory] : pathsToRemove;
38
- /**
39
- * Remove duplicate paths from the array.
40
- */
41
- this.pathsToRemove = Array.from(new Set(finalPaths));
42
- /**
43
- * Determine the task name.
44
- */
45
- this.taskName = options.taskName ?? "reset";
46
- /**
47
- * Create the reset task.
48
- */
49
- const resetTask = this.project.tasks.addTask(this.taskName, {
50
- description: "Delete build artifacts specified by pathsToRemove option, or artifactsDirectory if pathsToRemove is empty",
51
- });
52
- /**
53
- * Delete build artifacts with existence checks.
54
- * Using shell conditionals to only delete if paths exist.
55
- * Using -e to check existence (works for both files and directories).
56
- */
57
- this.pathsToRemove.forEach((path) => {
58
- resetTask.exec(`[ -e "${path}" ] && rm -rf ${path} || true`);
59
- });
60
- /**
61
- * Turbo tasks are added after all components are created.
62
- * This assumes turbo is built first so that it's available to be
63
- * referenced. This could introduce problems in future but works for now.
64
- */
65
- /**
66
- * Check if turborepo is active.
67
- */
68
- const rootHasTurbo = turbo_repo_1.TurboRepo.of(this.project.root) !== undefined;
69
- const isSubproject = this.project !== this.project.root;
70
- const isRootProject = this.project === this.project.root;
71
- /**
72
- * If turborepo is active for the subproject, add turbo tasks.
73
- */
74
- if (isSubproject && rootHasTurbo) {
75
- /**
76
- * Get TurboRepo instance for this subproject.
77
- * It should exist by now since preSynthesize runs after all components are created.
78
- */
79
- const turbo = turbo_repo_1.TurboRepo.of(this.project);
80
- if (turbo && !turbo.isRootProject) {
81
- /**
82
- * Create turbo:reset task (or turbo:${taskName}).
83
- */
84
- const turboResetTask = new turbo_repo_task_1.TurboRepoTask(this.project, {
85
- name: `turbo:${this.taskName}`,
86
- cache: false,
87
- });
88
- turbo.tasks.push(turboResetTask);
89
- /**
90
- * Create a turbo task with the same name as the reset task.
91
- */
92
- const turboTaskWithSameName = new turbo_repo_task_1.TurboRepoTask(this.project, {
93
- name: this.taskName,
94
- cache: false,
95
- });
96
- turbo.tasks.push(turboTaskWithSameName);
97
- /**
98
- * turboResetTask depends on turboTaskWithSameName so that the reset task
99
- * can be run across all suprojects using turbo:reset as the entry point.
100
- */
101
- turboResetTask.dependsOn.push(turboTaskWithSameName.name);
102
- }
103
- }
104
- /**
105
- * If reset-task is in the root project, add a turbo task that will trigger
106
- * all the subtasks using dependsOn of "^turbo:reset".
107
- */
108
- if (isRootProject && rootHasTurbo) {
109
- const turbo = turbo_repo_1.TurboRepo.of(this.project);
110
- if (turbo && turbo.isRootProject) {
111
- /**
112
- * Create turbo:reset task (or turbo:${taskName}) in the root project.
113
- * The ^ prefix means "run this task in all dependencies first".
114
- */
115
- const rootTurboResetTask = new turbo_repo_task_1.TurboRepoTask(this.project, {
116
- name: `turbo:${this.taskName}`,
117
- dependsOn: [`^turbo:${this.taskName}`],
118
- cache: false,
119
- });
120
- turbo.tasks.push(rootTurboResetTask);
121
- /**
122
- * Create a turbo task with the same name as the reset task.
123
- */
124
- const turboTaskWithSameName = new turbo_repo_task_1.TurboRepoTask(this.project, {
125
- name: this.taskName,
126
- cache: false,
127
- });
128
- turbo.tasks.push(turboTaskWithSameName);
129
- /**
130
- * rootTurboResetTask depends on turboTaskWithSameName so that the reset task
131
- * can be run across all suprojects using turbo:reset as the entry point.
132
- */
133
- rootTurboResetTask.dependsOn.push(turboTaskWithSameName.name);
134
- /**
135
- * Create reset:all task - a projen task that calls the turbo task.
136
- * This is similar to build:all in turbo-repo.ts.
137
- */
138
- const resetAllTask = this.project.tasks.addTask(`${this.taskName}:all`, {
139
- description: `Reset all build artifacts across the monorepo by running turbo:${this.taskName} in all subprojects.`,
140
- });
141
- resetAllTask.exec("turbo telemetry disable");
142
- resetAllTask.exec(`turbo turbo:${this.taskName} --summarize --concurrency=10`);
143
- resetAllTask.exec(`pnpm ${this.taskName}`);
144
- }
145
- }
146
- }
147
- }
148
- exports.ResetTask = ResetTask;
149
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reset-task.js","sourceRoot":"","sources":["../../src/tasks/reset-task.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Project } from \"projen\";\nimport { TypeScriptProject } from \"../projects/typescript-project\";\nimport { TurboRepo } from \"../turbo/turbo-repo\";\nimport { TurboRepoTask } from \"../turbo/turbo-repo-task\";\n\n/*******************************************************************************\n *\n * Reset Task Component\n *\n * Adds a \"reset\" task that deletes all build artifacts produced by the build\n * process. This includes node_modules, lib, dist, coverage, test-reports,\n * .turbo, and tsconfig.tsbuildinfo.\n *\n ******************************************************************************/\n\nexport interface ResetTaskOptions {\n  /**\n   * Custom output directory to delete (overrides tsconfig artifactsDirectory detection).\n   *\n   * @default - detected from typescript project.artifactsDirectory or \"lib\"\n   */\n  readonly artifactsDirectory?: string;\n\n  /**\n   * Array of glob patterns for paths to remove.\n   * If empty, the artifactsDirectory will be added automatically.\n   *\n   * @default []\n   */\n  readonly pathsToRemove?: string[];\n\n  /**\n   * Name of the task to create.\n   *\n   * @default \"reset\"\n   */\n  readonly taskName?: string;\n}\n\nexport class ResetTask extends Component {\n  /**\n   * Static method to discover reset task in a project.\n   */\n  public static of(project: Project): ResetTask | undefined {\n    const isDefined = (c: Component): c is ResetTask => c instanceof ResetTask;\n    return project.components.find(isDefined);\n  }\n\n  /**\n   * The output directory to delete (from tsconfig or custom).\n   */\n  public readonly artifactsDirectory: string;\n\n  /**\n   * The final array of paths that will be removed by the reset task.\n   */\n  public readonly pathsToRemove: string[];\n\n  /**\n   * The name of the task that was created.\n   */\n  public readonly taskName: string;\n\n  constructor(\n    public readonly project: Project,\n    options: ResetTaskOptions = {},\n  ) {\n    super(project);\n\n    /**\n     * Determine the output directory.\n     * 1. Use custom artifactsDirectory if provided\n     * 2. Use the artifacts directory if project is TypeScriptProject\n     * 3. Default to \"lib\"\n     */\n    this.artifactsDirectory = options.artifactsDirectory\n      ? options.artifactsDirectory\n      : project instanceof TypeScriptProject\n        ? project.artifactsDirectory\n        : \"lib\";\n\n    /**\n     * Build the paths array to remove.\n     * If pathsToRemove is empty, add artifactsDirectory.\n     * If pathsToRemove is not empty, use it as-is (artifactsDirectory is not automatically added).\n     * Remove duplicate entries from the array.\n     */\n    const pathsToRemove = options.pathsToRemove ?? [];\n    const finalPaths =\n      pathsToRemove.length === 0 ? [this.artifactsDirectory] : pathsToRemove;\n\n    /**\n     * Remove duplicate paths from the array.\n     */\n    this.pathsToRemove = Array.from(new Set(finalPaths));\n\n    /**\n     * Determine the task name.\n     */\n    this.taskName = options.taskName ?? \"reset\";\n\n    /**\n     * Create the reset task.\n     */\n    const resetTask = this.project.tasks.addTask(this.taskName, {\n      description:\n        \"Delete build artifacts specified by pathsToRemove option, or artifactsDirectory if pathsToRemove is empty\",\n    });\n\n    /**\n     * Delete build artifacts with existence checks.\n     * Using shell conditionals to only delete if paths exist.\n     * Using -e to check existence (works for both files and directories).\n     */\n    this.pathsToRemove.forEach((path) => {\n      resetTask.exec(`[ -e \"${path}\" ] && rm -rf ${path} || true`);\n    });\n\n    /**\n     * Turbo tasks are added after all components are created.\n     * This assumes turbo is built first so that it's available to be\n     * referenced. This could introduce problems in future but works for now.\n     */\n\n    /**\n     * Check if turborepo is active.\n     */\n    const rootHasTurbo = TurboRepo.of(this.project.root) !== undefined;\n    const isSubproject = this.project !== this.project.root;\n    const isRootProject = this.project === this.project.root;\n\n    /**\n     * If turborepo is active for the subproject, add turbo tasks.\n     */\n    if (isSubproject && rootHasTurbo) {\n      /**\n       * Get TurboRepo instance for this subproject.\n       * It should exist by now since preSynthesize runs after all components are created.\n       */\n      const turbo = TurboRepo.of(this.project);\n      if (turbo && !turbo.isRootProject) {\n        /**\n         * Create turbo:reset task (or turbo:${taskName}).\n         */\n        const turboResetTask = new TurboRepoTask(this.project, {\n          name: `turbo:${this.taskName}`,\n          cache: false,\n        });\n        turbo.tasks.push(turboResetTask);\n\n        /**\n         * Create a turbo task with the same name as the reset task.\n         */\n        const turboTaskWithSameName = new TurboRepoTask(this.project, {\n          name: this.taskName,\n          cache: false,\n        });\n        turbo.tasks.push(turboTaskWithSameName);\n\n        /**\n         * turboResetTask depends on turboTaskWithSameName so that the reset task\n         * can be run across all suprojects using turbo:reset as the entry point.\n         */\n        turboResetTask.dependsOn.push(turboTaskWithSameName.name);\n      }\n    }\n\n    /**\n     * If reset-task is in the root project, add a turbo task that will trigger\n     * all the subtasks using dependsOn of \"^turbo:reset\".\n     */\n    if (isRootProject && rootHasTurbo) {\n      const turbo = TurboRepo.of(this.project);\n      if (turbo && turbo.isRootProject) {\n        /**\n         * Create turbo:reset task (or turbo:${taskName}) in the root project.\n         * The ^ prefix means \"run this task in all dependencies first\".\n         */\n        const rootTurboResetTask = new TurboRepoTask(this.project, {\n          name: `turbo:${this.taskName}`,\n          dependsOn: [`^turbo:${this.taskName}`],\n          cache: false,\n        });\n        turbo.tasks.push(rootTurboResetTask);\n\n        /**\n         * Create a turbo task with the same name as the reset task.\n         */\n        const turboTaskWithSameName = new TurboRepoTask(this.project, {\n          name: this.taskName,\n          cache: false,\n        });\n        turbo.tasks.push(turboTaskWithSameName);\n\n        /**\n         * rootTurboResetTask depends on turboTaskWithSameName so that the reset task\n         * can be run across all suprojects using turbo:reset as the entry point.\n         */\n        rootTurboResetTask.dependsOn.push(turboTaskWithSameName.name);\n\n        /**\n         * Create reset:all task - a projen task that calls the turbo task.\n         * This is similar to build:all in turbo-repo.ts.\n         */\n        const resetAllTask = this.project.tasks.addTask(\n          `${this.taskName}:all`,\n          {\n            description: `Reset all build artifacts across the monorepo by running turbo:${this.taskName} in all subprojects.`,\n          },\n        );\n        resetAllTask.exec(\"turbo telemetry disable\");\n        resetAllTask.exec(\n          `turbo turbo:${this.taskName} --summarize --concurrency=10`,\n        );\n        resetAllTask.exec(`pnpm ${this.taskName}`);\n      }\n    }\n  }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export * from "./turbo-repo-task";
2
- export * from "./turbo-repo";
@@ -1,19 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./turbo-repo-task"), exports);
18
- __exportStar(require("./turbo-repo"), exports);
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHVyYm8vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLG9EQUFrQztBQUNsQywrQ0FBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi90dXJiby1yZXBvLXRhc2tcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3R1cmJvLXJlcG9cIjtcbiJdfQ==
@@ -1,36 +0,0 @@
1
- import { Component, Project } from "projen/lib";
2
- /**
3
- * Each of the below options corresponds to a task property found here:
4
- * * https://turborepo.com/docs/reference/configuration#defining-tasks
5
- */
6
- export interface TurboRepoTaskOptions {
7
- readonly name: string;
8
- readonly dependsOn?: Array<string>;
9
- readonly env?: Array<string>;
10
- readonly passThroughEnv?: Array<string>;
11
- readonly outputs?: Array<string>;
12
- readonly cache?: boolean;
13
- readonly inputs?: Array<string>;
14
- readonly outputLogs?: "full" | "hash-only" | "new-only" | "errors-only" | "none";
15
- readonly persistent?: boolean;
16
- readonly interactive?: boolean;
17
- }
18
- export declare class TurboRepoTask extends Component {
19
- readonly project: Project;
20
- readonly name: string;
21
- dependsOn: Array<string>;
22
- readonly env: Array<string>;
23
- readonly passThroughEnv: Array<string>;
24
- outputs: Array<string>;
25
- cache: boolean;
26
- inputs: Array<string>;
27
- readonly outputLogs: "full" | "hash-only" | "new-only" | "errors-only" | "none";
28
- readonly persistent: boolean;
29
- readonly interactive: boolean;
30
- /**
31
- * Include this task in turbo.json output?
32
- */
33
- isActive: boolean;
34
- constructor(project: Project, options: TurboRepoTaskOptions);
35
- taskConfig(): Record<string, any>;
36
- }
@@ -1,43 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.TurboRepoTask = void 0;
4
- const lib_1 = require("projen/lib");
5
- class TurboRepoTask extends lib_1.Component {
6
- constructor(project, options) {
7
- super(project);
8
- this.project = project;
9
- this.name = options.name;
10
- this.dependsOn = options.dependsOn ?? [];
11
- this.env = options.env ?? [];
12
- this.passThroughEnv = options.passThroughEnv ?? [];
13
- this.outputs = options.outputs ?? [];
14
- this.cache = options.cache ?? true;
15
- this.inputs = [
16
- ...(options.inputs ?? []),
17
- // rerun if projen config changes
18
- ".projen/**",
19
- // ignore mac files
20
- "!.DS_Store",
21
- "!**/.DS_Store",
22
- ];
23
- this.outputLogs = options.outputLogs ?? "new-only";
24
- this.persistent = options.persistent ?? false;
25
- this.interactive = options.interactive ?? false;
26
- this.isActive = true;
27
- }
28
- taskConfig() {
29
- return {
30
- dependsOn: this.dependsOn,
31
- env: this.env,
32
- passThroughEnv: this.passThroughEnv,
33
- outputs: this.outputs,
34
- cache: this.cache,
35
- inputs: this.inputs,
36
- outputLogs: this.outputLogs,
37
- persistent: this.persistent,
38
- interactive: this.interactive,
39
- };
40
- }
41
- }
42
- exports.TurboRepoTask = TurboRepoTask;
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHVyYm8tcmVwby10YXNrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R1cmJvL3R1cmJvLXJlcG8tdGFzay50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxvQ0FBZ0Q7QUF3QmhELE1BQWEsYUFBYyxTQUFRLGVBQVM7SUFzQjFDLFlBQ2tCLE9BQWdCLEVBQ2hDLE9BQTZCO1FBRTdCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUhDLFlBQU8sR0FBUCxPQUFPLENBQVM7UUFLaEMsSUFBSSxDQUFDLElBQUksR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDLFNBQVMsSUFBSSxFQUFFLENBQUM7UUFDekMsSUFBSSxDQUFDLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxJQUFJLEVBQUUsQ0FBQztRQUM3QixJQUFJLENBQUMsY0FBYyxHQUFHLE9BQU8sQ0FBQyxjQUFjLElBQUksRUFBRSxDQUFDO1FBQ25ELElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUM7UUFDckMsSUFBSSxDQUFDLEtBQUssR0FBRyxPQUFPLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQztRQUNuQyxJQUFJLENBQUMsTUFBTSxHQUFHO1lBQ1osR0FBRyxDQUFDLE9BQU8sQ0FBQyxNQUFNLElBQUksRUFBRSxDQUFDO1lBQ3pCLGlDQUFpQztZQUNqQyxZQUFZO1lBQ1osbUJBQW1CO1lBQ25CLFlBQVk7WUFDWixlQUFlO1NBQ2hCLENBQUM7UUFDRixJQUFJLENBQUMsVUFBVSxHQUFHLE9BQU8sQ0FBQyxVQUFVLElBQUksVUFBVSxDQUFDO1FBQ25ELElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDLFVBQVUsSUFBSSxLQUFLLENBQUM7UUFDOUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxPQUFPLENBQUMsV0FBVyxJQUFJLEtBQUssQ0FBQztRQUNoRCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztJQUN2QixDQUFDO0lBRU0sVUFBVTtRQUNmLE9BQU87WUFDTCxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVM7WUFDekIsR0FBRyxFQUFFLElBQUksQ0FBQyxHQUFHO1lBQ2IsY0FBYyxFQUFFLElBQUksQ0FBQyxjQUFjO1lBQ25DLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7WUFDakIsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNO1lBQ25CLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUMzQixVQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVU7WUFDM0IsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO1NBQzlCLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUE3REQsc0NBNkRDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBQcm9qZWN0IH0gZnJvbSBcInByb2plbi9saWJcIjtcblxuLyoqXG4gKiBFYWNoIG9mIHRoZSBiZWxvdyBvcHRpb25zIGNvcnJlc3BvbmRzIHRvIGEgdGFzayBwcm9wZXJ0eSBmb3VuZCBoZXJlOlxuICogICogaHR0cHM6Ly90dXJib3JlcG8uY29tL2RvY3MvcmVmZXJlbmNlL2NvbmZpZ3VyYXRpb24jZGVmaW5pbmctdGFza3NcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUdXJib1JlcG9UYXNrT3B0aW9ucyB7XG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgcmVhZG9ubHkgZGVwZW5kc09uPzogQXJyYXk8c3RyaW5nPjtcbiAgcmVhZG9ubHkgZW52PzogQXJyYXk8c3RyaW5nPjtcbiAgcmVhZG9ubHkgcGFzc1Rocm91Z2hFbnY/OiBBcnJheTxzdHJpbmc+O1xuICByZWFkb25seSBvdXRwdXRzPzogQXJyYXk8c3RyaW5nPjtcbiAgcmVhZG9ubHkgY2FjaGU/OiBib29sZWFuO1xuICByZWFkb25seSBpbnB1dHM/OiBBcnJheTxzdHJpbmc+O1xuICByZWFkb25seSBvdXRwdXRMb2dzPzpcbiAgICB8IFwiZnVsbFwiXG4gICAgfCBcImhhc2gtb25seVwiXG4gICAgfCBcIm5ldy1vbmx5XCJcbiAgICB8IFwiZXJyb3JzLW9ubHlcIlxuICAgIHwgXCJub25lXCI7XG4gIHJlYWRvbmx5IHBlcnNpc3RlbnQ/OiBib29sZWFuO1xuICByZWFkb25seSBpbnRlcmFjdGl2ZT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjbGFzcyBUdXJib1JlcG9UYXNrIGV4dGVuZHMgQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgcHVibGljIGRlcGVuZHNPbjogQXJyYXk8c3RyaW5nPjtcbiAgcHVibGljIHJlYWRvbmx5IGVudjogQXJyYXk8c3RyaW5nPjtcbiAgcHVibGljIHJlYWRvbmx5IHBhc3NUaHJvdWdoRW52OiBBcnJheTxzdHJpbmc+O1xuICBwdWJsaWMgb3V0cHV0czogQXJyYXk8c3RyaW5nPjtcbiAgcHVibGljIGNhY2hlOiBib29sZWFuO1xuICBwdWJsaWMgaW5wdXRzOiBBcnJheTxzdHJpbmc+O1xuICBwdWJsaWMgcmVhZG9ubHkgb3V0cHV0TG9nczpcbiAgICB8IFwiZnVsbFwiXG4gICAgfCBcImhhc2gtb25seVwiXG4gICAgfCBcIm5ldy1vbmx5XCJcbiAgICB8IFwiZXJyb3JzLW9ubHlcIlxuICAgIHwgXCJub25lXCI7XG4gIHB1YmxpYyByZWFkb25seSBwZXJzaXN0ZW50OiBib29sZWFuO1xuICBwdWJsaWMgcmVhZG9ubHkgaW50ZXJhY3RpdmU6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEluY2x1ZGUgdGhpcyB0YXNrIGluIHR1cmJvLmpzb24gb3V0cHV0P1xuICAgKi9cbiAgcHVibGljIGlzQWN0aXZlOiBib29sZWFuO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZWFkb25seSBwcm9qZWN0OiBQcm9qZWN0LFxuICAgIG9wdGlvbnM6IFR1cmJvUmVwb1Rhc2tPcHRpb25zLFxuICApIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcblxuICAgIHRoaXMubmFtZSA9IG9wdGlvbnMubmFtZTtcbiAgICB0aGlzLmRlcGVuZHNPbiA9IG9wdGlvbnMuZGVwZW5kc09uID8/IFtdO1xuICAgIHRoaXMuZW52ID0gb3B0aW9ucy5lbnYgPz8gW107XG4gICAgdGhpcy5wYXNzVGhyb3VnaEVudiA9IG9wdGlvbnMucGFzc1Rocm91Z2hFbnYgPz8gW107XG4gICAgdGhpcy5vdXRwdXRzID0gb3B0aW9ucy5vdXRwdXRzID8/IFtdO1xuICAgIHRoaXMuY2FjaGUgPSBvcHRpb25zLmNhY2hlID8/IHRydWU7XG4gICAgdGhpcy5pbnB1dHMgPSBbXG4gICAgICAuLi4ob3B0aW9ucy5pbnB1dHMgPz8gW10pLFxuICAgICAgLy8gcmVydW4gaWYgcHJvamVuIGNvbmZpZyBjaGFuZ2VzXG4gICAgICBcIi5wcm9qZW4vKipcIixcbiAgICAgIC8vIGlnbm9yZSBtYWMgZmlsZXNcbiAgICAgIFwiIS5EU19TdG9yZVwiLFxuICAgICAgXCIhKiovLkRTX1N0b3JlXCIsXG4gICAgXTtcbiAgICB0aGlzLm91dHB1dExvZ3MgPSBvcHRpb25zLm91dHB1dExvZ3MgPz8gXCJuZXctb25seVwiO1xuICAgIHRoaXMucGVyc2lzdGVudCA9IG9wdGlvbnMucGVyc2lzdGVudCA/PyBmYWxzZTtcbiAgICB0aGlzLmludGVyYWN0aXZlID0gb3B0aW9ucy5pbnRlcmFjdGl2ZSA/PyBmYWxzZTtcbiAgICB0aGlzLmlzQWN0aXZlID0gdHJ1ZTtcbiAgfVxuXG4gIHB1YmxpYyB0YXNrQ29uZmlnKCk6IFJlY29yZDxzdHJpbmcsIGFueT4ge1xuICAgIHJldHVybiB7XG4gICAgICBkZXBlbmRzT246IHRoaXMuZGVwZW5kc09uLFxuICAgICAgZW52OiB0aGlzLmVudixcbiAgICAgIHBhc3NUaHJvdWdoRW52OiB0aGlzLnBhc3NUaHJvdWdoRW52LFxuICAgICAgb3V0cHV0czogdGhpcy5vdXRwdXRzLFxuICAgICAgY2FjaGU6IHRoaXMuY2FjaGUsXG4gICAgICBpbnB1dHM6IHRoaXMuaW5wdXRzLFxuICAgICAgb3V0cHV0TG9nczogdGhpcy5vdXRwdXRMb2dzLFxuICAgICAgcGVyc2lzdGVudDogdGhpcy5wZXJzaXN0ZW50LFxuICAgICAgaW50ZXJhY3RpdmU6IHRoaXMuaW50ZXJhY3RpdmUsXG4gICAgfTtcbiAgfVxufVxuIl19