@aws-cdk-testing/cli-integ 2.173.4 → 3.0.1

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 (97) hide show
  1. package/.eslintrc.js +9 -0
  2. package/LICENSE +2 -1
  3. package/bin/query-github +1 -1
  4. package/bin/query-github.js +3 -3
  5. package/bin/query-github.ts +56 -0
  6. package/bin/run-suite +1 -1
  7. package/bin/run-suite.js +3 -3
  8. package/bin/run-suite.ts +140 -0
  9. package/bin/stage-distribution +1 -1
  10. package/bin/stage-distribution.js +3 -2
  11. package/bin/stage-distribution.ts +267 -0
  12. package/bin/test-root +1 -1
  13. package/bin/test-root.ts +3 -0
  14. package/lib/aws.js +9 -6
  15. package/lib/aws.ts +263 -0
  16. package/lib/cli/query-github.d.ts +1 -0
  17. package/lib/cli/query-github.js +54 -0
  18. package/lib/cli/query-github.ts +56 -0
  19. package/lib/cli/run-suite.d.ts +1 -0
  20. package/lib/cli/run-suite.js +131 -0
  21. package/lib/cli/run-suite.ts +140 -0
  22. package/lib/cli/stage-distribution.d.ts +1 -0
  23. package/lib/cli/stage-distribution.js +217 -0
  24. package/lib/cli/stage-distribution.ts +267 -0
  25. package/lib/cli/test-root.d.ts +1 -0
  26. package/lib/cli/test-root.js +6 -0
  27. package/lib/cli/test-root.ts +3 -0
  28. package/lib/corking.ts +33 -0
  29. package/lib/eventually.js +3 -3
  30. package/lib/eventually.ts +42 -0
  31. package/lib/files.js +3 -2
  32. package/lib/files.ts +80 -0
  33. package/lib/github.js +6 -5
  34. package/lib/github.ts +43 -0
  35. package/lib/index.ts +13 -0
  36. package/lib/integ-test.ts +81 -0
  37. package/lib/lists.ts +9 -0
  38. package/lib/memoize.ts +14 -0
  39. package/lib/npm.ts +41 -0
  40. package/lib/package-sources/release-source.js +3 -2
  41. package/lib/package-sources/release-source.ts +81 -0
  42. package/lib/package-sources/repo-source.ts +111 -0
  43. package/lib/package-sources/repo-tools/npm.js +5 -4
  44. package/lib/package-sources/repo-tools/npm.ts +48 -0
  45. package/lib/package-sources/source.ts +35 -0
  46. package/lib/package-sources/subprocess.ts +15 -0
  47. package/lib/resource-pool.js +2 -2
  48. package/lib/resource-pool.ts +140 -0
  49. package/lib/resources.ts +4 -0
  50. package/lib/shell.js +8 -5
  51. package/lib/shell.ts +168 -0
  52. package/lib/staging/codeartifact.js +11 -8
  53. package/lib/staging/codeartifact.ts +387 -0
  54. package/lib/staging/maven.js +5 -3
  55. package/lib/staging/maven.ts +95 -0
  56. package/lib/staging/npm.ts +62 -0
  57. package/lib/staging/nuget.ts +75 -0
  58. package/lib/staging/parallel-shell.js +2 -2
  59. package/lib/staging/parallel-shell.ts +51 -0
  60. package/lib/staging/pypi.ts +50 -0
  61. package/lib/staging/usage-dir.ts +99 -0
  62. package/lib/with-aws.js +3 -2
  63. package/lib/with-aws.ts +67 -0
  64. package/lib/with-cdk-app.js +23 -14
  65. package/lib/with-cdk-app.ts +742 -0
  66. package/lib/with-cli-lib.ts +134 -0
  67. package/lib/with-packages.ts +15 -0
  68. package/lib/with-sam.js +7 -4
  69. package/lib/with-sam.ts +288 -0
  70. package/lib/with-temporary-directory.ts +35 -0
  71. package/lib/with-timeout.ts +33 -0
  72. package/lib/xpmutex.js +2 -2
  73. package/lib/xpmutex.ts +218 -0
  74. package/package.json +86 -62
  75. package/resources/cloud-assemblies/0.36.0/cdk.out +1 -0
  76. package/resources/cloud-assemblies/1.10.0-lookup-default-vpc/cdk.out +1 -0
  77. package/resources/cloud-assemblies/1.10.0-request-azs/cdk.out +1 -0
  78. package/tests/cli-integ-tests/bootstrapping.integtest.js +22 -13
  79. package/tests/cli-integ-tests/bootstrapping.integtest.ts +493 -0
  80. package/tests/cli-integ-tests/cli-lib.integtest.js +3 -2
  81. package/tests/cli-integ-tests/cli-lib.integtest.ts +90 -0
  82. package/tests/cli-integ-tests/cli.integtest.js +76 -49
  83. package/tests/cli-integ-tests/cli.integtest.ts +2874 -0
  84. package/tests/cli-integ-tests/garbage-collection.integtest.js +2 -2
  85. package/tests/cli-integ-tests/garbage-collection.integtest.ts +392 -0
  86. package/tests/init-csharp/init-csharp.integtest.ts +15 -0
  87. package/tests/init-fsharp/init-fsharp.integtest.ts +15 -0
  88. package/tests/init-go/init-go.integtest.ts +23 -0
  89. package/tests/init-java/init-java.integtest.ts +14 -0
  90. package/tests/init-javascript/init-javascript.integtest.ts +59 -0
  91. package/tests/init-python/init-python.integtest.ts +20 -0
  92. package/tests/init-typescript-app/init-typescript-app.integtest.ts +66 -0
  93. package/tests/init-typescript-lib/init-typescript-lib.integtest.ts +13 -0
  94. package/tests/tool-integrations/amplify.integtest.ts +43 -0
  95. package/tests/tool-integrations/with-tool-context.ts +14 -0
  96. package/tests/uberpackage/uberpackage.integtest.ts +11 -0
  97. package/resources/cdk-apps/cfn-include-app/.gitignore +0 -1
@@ -26,6 +26,7 @@ class TestRepository {
26
26
  * Garbage collect repositories
27
27
  */
28
28
  static async gc() {
29
+ var _a, _b;
29
30
  if (!(await TestRepository.existing('*dummy*').domainExists())) {
30
31
  return;
31
32
  }
@@ -35,11 +36,11 @@ class TestRepository {
35
36
  const page = await codeArtifact.send(new client_codeartifact_1.ListRepositoriesCommand({
36
37
  nextToken: nextToken,
37
38
  }));
38
- for (const repo of page.repositories ?? []) {
39
+ for (const repo of (_a = page.repositories) !== null && _a !== void 0 ? _a : []) {
39
40
  const tags = await codeArtifact.send(new client_codeartifact_1.ListTagsForResourceCommand({
40
41
  resourceArn: repo.arn,
41
42
  }));
42
- const collectable = tags?.tags?.find((t) => t.key === COLLECT_BY_TAG && Number(t.value) < Date.now());
43
+ const collectable = (_b = tags === null || tags === void 0 ? void 0 : tags.tags) === null || _b === void 0 ? void 0 : _b.find((t) => t.key === COLLECT_BY_TAG && Number(t.value) < Date.now());
43
44
  if (collectable) {
44
45
  // eslint-disable-next-line no-console
45
46
  console.log('Deleting', repo.name);
@@ -171,17 +172,18 @@ class TestRepository {
171
172
  });
172
173
  }
173
174
  async ensureRepository(name, options) {
175
+ var _a;
174
176
  if (await this.repositoryExists(name)) {
175
177
  return;
176
178
  }
177
179
  await this.codeArtifact.send(new client_codeartifact_1.CreateRepositoryCommand({
178
180
  domain: this.domain,
179
181
  repository: name,
180
- description: options?.description,
181
- upstreams: options?.upstreams?.map((repositoryName) => ({ repositoryName })),
182
- tags: options?.tags ? Object.entries(options.tags).map(([key, value]) => ({ key, value })) : undefined,
182
+ description: options === null || options === void 0 ? void 0 : options.description,
183
+ upstreams: (_a = options === null || options === void 0 ? void 0 : options.upstreams) === null || _a === void 0 ? void 0 : _a.map((repositoryName) => ({ repositoryName })),
184
+ tags: (options === null || options === void 0 ? void 0 : options.tags) ? Object.entries(options.tags).map(([key, value]) => ({ key, value })) : undefined,
183
185
  }));
184
- if (options?.external) {
186
+ if (options === null || options === void 0 ? void 0 : options.external) {
185
187
  const externalConnection = options.external;
186
188
  await retry(() => this.codeArtifact.send(new client_codeartifact_1.AssociateExternalConnectionCommand({
187
189
  domain: this.domain,
@@ -215,13 +217,14 @@ class TestRepository {
215
217
  }
216
218
  }
217
219
  async *listPackages(filter = {}) {
220
+ var _a;
218
221
  let response = await retryThrottled(() => this.codeArtifact.send(new client_codeartifact_1.ListPackagesCommand({
219
222
  domain: this.domain,
220
223
  repository: this.repositoryName,
221
224
  ...filter,
222
225
  })));
223
226
  while (true) {
224
- for (const p of response.packages ?? []) {
227
+ for (const p of (_a = response.packages) !== null && _a !== void 0 ? _a : []) {
225
228
  yield p;
226
229
  }
227
230
  if (!response.nextToken) {
@@ -275,4 +278,4 @@ async function retryThrottled(block) {
275
278
  }
276
279
  }
277
280
  }
278
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codeartifact.js","sourceRoot":"","sources":["codeartifact.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AssociateExternalConnectionCommand,\n  CodeartifactClient,\n  CreateDomainCommand,\n  CreateRepositoryCommand,\n  DeleteRepositoryCommand,\n  DescribeDomainCommand,\n  DescribeRepositoryCommand,\n  GetAuthorizationTokenCommand,\n  GetRepositoryEndpointCommand,\n  ListPackagesCommand,\n  ListPackagesRequest,\n  ListRepositoriesCommand,\n  ListTagsForResourceCommand,\n  PutPackageOriginConfigurationCommand,\n} from '@aws-sdk/client-codeartifact';\nimport { sleep } from '../aws';\n\nconst COLLECT_BY_TAG = 'collect-by';\nconst REPO_LIFETIME_MS = 24 * 3600 * 1000; // One day\n\nexport class TestRepository {\n  public static readonly DEFAULT_DOMAIN = 'test-cdk';\n\n  public static async newRandom() {\n    const qualifier = Math.random()\n      .toString(36)\n      .replace(/[^a-z0-9]+/g, '');\n\n    const repo = new TestRepository(`test-${qualifier}`);\n    await repo.prepare();\n    return repo;\n  }\n\n  public static async newWithName(name: string) {\n    const repo = new TestRepository(name);\n    await repo.prepare();\n    return repo;\n  }\n\n  public static existing(repositoryName: string) {\n    return new TestRepository(repositoryName);\n  }\n\n  /**\n   * Garbage collect repositories\n   */\n  public static async gc() {\n    if (!(await TestRepository.existing('*dummy*').domainExists())) {\n      return;\n    }\n\n    const codeArtifact = new CodeartifactClient();\n\n    let nextToken: string | undefined;\n    do {\n      const page = await codeArtifact.send(\n        new ListRepositoriesCommand({\n          nextToken: nextToken,\n        }),\n      );\n\n      for (const repo of page.repositories ?? []) {\n        const tags = await codeArtifact.send(\n          new ListTagsForResourceCommand({\n            resourceArn: repo.arn!,\n          }),\n        );\n        const collectable = tags?.tags?.find((t) => t.key === COLLECT_BY_TAG && Number(t.value) < Date.now());\n        if (collectable) {\n          // eslint-disable-next-line no-console\n          console.log('Deleting', repo.name);\n          await codeArtifact.send(\n            new DeleteRepositoryCommand({\n              domain: repo.domainName!,\n              repository: repo.name!,\n            }),\n          );\n        }\n      }\n\n      nextToken = page.nextToken;\n    } while (nextToken);\n  }\n\n  public readonly npmUpstream = 'npm-upstream';\n  public readonly pypiUpstream = 'pypi-upstream';\n  public readonly nugetUpstream = 'nuget-upstream';\n  public readonly mavenUpstream = 'maven-upstream';\n  public readonly domain = TestRepository.DEFAULT_DOMAIN;\n\n  private readonly codeArtifact = new CodeartifactClient();\n\n  private _loginInformation: LoginInformation | undefined;\n\n  private constructor(public readonly repositoryName: string) {}\n\n  public async prepare() {\n    await this.ensureDomain();\n    await this.ensureUpstreams();\n\n    await this.ensureRepository(this.repositoryName, {\n      description: 'Testing repository',\n      upstreams: [this.npmUpstream, this.pypiUpstream, this.nugetUpstream, this.mavenUpstream],\n      tags: {\n        [COLLECT_BY_TAG]: `${Date.now() + REPO_LIFETIME_MS}`,\n      },\n    });\n  }\n\n  public async loginInformation(): Promise<LoginInformation> {\n    if (this._loginInformation) {\n      return this._loginInformation;\n    }\n\n    this._loginInformation = {\n      authToken: (\n        await this.codeArtifact.send(\n          new GetAuthorizationTokenCommand({\n            domain: this.domain,\n            durationSeconds: 12 * 3600,\n          }),\n        )\n      ).authorizationToken!,\n      repositoryName: this.repositoryName,\n\n      npmEndpoint: (\n        await this.codeArtifact.send(\n          new GetRepositoryEndpointCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            format: 'npm',\n          }),\n        )\n      ).repositoryEndpoint!,\n\n      mavenEndpoint: (\n        await this.codeArtifact.send(\n          new GetRepositoryEndpointCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            format: 'maven',\n          }),\n        )\n      ).repositoryEndpoint!,\n\n      nugetEndpoint: (\n        await this.codeArtifact.send(\n          new GetRepositoryEndpointCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            format: 'nuget',\n          }),\n        )\n      ).repositoryEndpoint!,\n\n      pypiEndpoint: (\n        await this.codeArtifact.send(\n          new GetRepositoryEndpointCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            format: 'pypi',\n          }),\n        )\n      ).repositoryEndpoint!,\n    };\n    return this._loginInformation;\n  }\n\n  public async delete() {\n    try {\n      await this.codeArtifact.send(\n        new DeleteRepositoryCommand({\n          domain: this.domain,\n          repository: this.repositoryName,\n        }),\n      );\n\n      // eslint-disable-next-line no-console\n      console.log('Deleted', this.repositoryName);\n    } catch (e: any) {\n      if (e.name !== 'ResourceNotFoundException') {\n        throw e;\n      }\n      // Okay\n    }\n  }\n\n  /**\n   * List all packages and mark them as \"allow upstream versions\".\n   *\n   * If we don't do this and we publish `foo@2.3.4-rc.0`, then we can't\n   * download `foo@2.3.0` anymore because by default CodeArtifact will\n   * block different versions from the same package.\n   */\n  public async markAllUpstreamAllow() {\n    for await (const pkg of this.listPackages({ upstream: 'BLOCK' })) {\n      await retryThrottled(() =>\n        this.codeArtifact.send(\n          new PutPackageOriginConfigurationCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n\n            format: pkg.format!,\n            package: pkg.package!,\n            namespace: pkg.namespace!,\n            restrictions: {\n              publish: 'ALLOW',\n              upstream: 'ALLOW',\n            },\n          }),\n        ),\n      );\n    }\n  }\n\n  private async ensureDomain() {\n    if (await this.domainExists()) {\n      return;\n    }\n    await this.codeArtifact.send(\n      new CreateDomainCommand({\n        domain: this.domain,\n        tags: [{ key: 'testing', value: 'true' }],\n      }),\n    );\n  }\n\n  private async ensureUpstreams() {\n    await this.ensureRepository(this.npmUpstream, {\n      description: 'The upstream repository for NPM',\n      external: 'public:npmjs',\n    });\n    await this.ensureRepository(this.mavenUpstream, {\n      description: 'The upstream repository for Maven',\n      external: 'public:maven-central',\n    });\n    await this.ensureRepository(this.nugetUpstream, {\n      description: 'The upstream repository for NuGet',\n      external: 'public:nuget-org',\n    });\n    await this.ensureRepository(this.pypiUpstream, {\n      description: 'The upstream repository for PyPI',\n      external: 'public:pypi',\n    });\n  }\n\n  private async ensureRepository(\n    name: string,\n    options?: {\n      readonly description?: string;\n      readonly external?: string;\n      readonly upstreams?: string[];\n      readonly tags?: Record<string, string>;\n    },\n  ) {\n    if (await this.repositoryExists(name)) {\n      return;\n    }\n\n    await this.codeArtifact.send(\n      new CreateRepositoryCommand({\n        domain: this.domain,\n        repository: name,\n        description: options?.description,\n        upstreams: options?.upstreams?.map((repositoryName) => ({ repositoryName })),\n        tags: options?.tags ? Object.entries(options.tags).map(([key, value]) => ({ key, value })) : undefined,\n      }),\n    );\n\n    if (options?.external) {\n      const externalConnection = options.external;\n      await retry(() =>\n        this.codeArtifact.send(\n          new AssociateExternalConnectionCommand({\n            domain: this.domain,\n            repository: name,\n            externalConnection,\n          }),\n        ),\n      );\n    }\n  }\n\n  private async domainExists() {\n    try {\n      await this.codeArtifact.send(new DescribeDomainCommand({ domain: this.domain }));\n      return true;\n    } catch (e: any) {\n      if (e.name !== 'ResourceNotFoundException') {\n        throw e;\n      }\n      return false;\n    }\n  }\n\n  private async repositoryExists(name: string) {\n    try {\n      await this.codeArtifact.send(new DescribeRepositoryCommand({ domain: this.domain, repository: name }));\n      return true;\n    } catch (e: any) {\n      if (e.name !== 'ResourceNotFoundException') {\n        throw e;\n      }\n      return false;\n    }\n  }\n\n  private async *listPackages(filter: Pick<ListPackagesRequest, 'upstream' | 'publish' | 'format'> = {}) {\n    let response = await retryThrottled(() =>\n      this.codeArtifact.send(\n        new ListPackagesCommand({\n          domain: this.domain,\n          repository: this.repositoryName,\n          ...filter,\n        }),\n      ),\n    );\n\n    while (true) {\n      for (const p of response.packages ?? []) {\n        yield p;\n      }\n\n      if (!response.nextToken) {\n        break;\n      }\n\n      response = await retryThrottled(() =>\n        this.codeArtifact.send(\n          new ListPackagesCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            ...filter,\n            nextToken: response.nextToken,\n          }),\n        ),\n      );\n    }\n  }\n}\n\nasync function retry<A>(block: () => Promise<A>) {\n  let attempts = 3;\n  while (true) {\n    try {\n      return await block();\n    } catch (e: any) {\n      if (attempts-- === 0) {\n        throw e;\n      }\n      // eslint-disable-next-line no-console\n      console.debug(e.message);\n      await sleep(500);\n    }\n  }\n}\n\nasync function retryThrottled<A>(block: () => Promise<A>) {\n  let time = 100;\n  let attempts = 15;\n  while (true) {\n    try {\n      return await block();\n    } catch (e: any) {\n      // eslint-disable-next-line no-console\n      console.debug(e.message);\n      if (e.name !== 'ThrottlingException') {\n        throw e;\n      }\n      if (attempts-- === 0) {\n        throw e;\n      }\n      await sleep(Math.floor(Math.random() * time));\n      time *= 2;\n    }\n  }\n}\n\nexport interface LoginInformation {\n  readonly authToken: string;\n  readonly repositoryName: string;\n  readonly npmEndpoint: string;\n  readonly mavenEndpoint: string;\n  readonly nugetEndpoint: string;\n  readonly pypiEndpoint: string;\n}\n"]}
281
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codeartifact.js","sourceRoot":"","sources":["codeartifact.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AssociateExternalConnectionCommand,\n  CodeartifactClient,\n  CreateDomainCommand,\n  CreateRepositoryCommand,\n  DeleteRepositoryCommand,\n  DescribeDomainCommand,\n  DescribeRepositoryCommand,\n  GetAuthorizationTokenCommand,\n  GetRepositoryEndpointCommand,\n  ListPackagesCommand,\n  ListPackagesRequest,\n  ListRepositoriesCommand,\n  ListTagsForResourceCommand,\n  PutPackageOriginConfigurationCommand,\n} from '@aws-sdk/client-codeartifact';\nimport { sleep } from '../aws';\n\nconst COLLECT_BY_TAG = 'collect-by';\nconst REPO_LIFETIME_MS = 24 * 3600 * 1000; // One day\n\nexport class TestRepository {\n  public static readonly DEFAULT_DOMAIN = 'test-cdk';\n\n  public static async newRandom() {\n    const qualifier = Math.random()\n      .toString(36)\n      .replace(/[^a-z0-9]+/g, '');\n\n    const repo = new TestRepository(`test-${qualifier}`);\n    await repo.prepare();\n    return repo;\n  }\n\n  public static async newWithName(name: string) {\n    const repo = new TestRepository(name);\n    await repo.prepare();\n    return repo;\n  }\n\n  public static existing(repositoryName: string) {\n    return new TestRepository(repositoryName);\n  }\n\n  /**\n   * Garbage collect repositories\n   */\n  public static async gc() {\n    if (!(await TestRepository.existing('*dummy*').domainExists())) {\n      return;\n    }\n\n    const codeArtifact = new CodeartifactClient();\n\n    let nextToken: string | undefined;\n    do {\n      const page = await codeArtifact.send(\n        new ListRepositoriesCommand({\n          nextToken: nextToken,\n        }),\n      );\n\n      for (const repo of page.repositories ?? []) {\n        const tags = await codeArtifact.send(\n          new ListTagsForResourceCommand({\n            resourceArn: repo.arn!,\n          }),\n        );\n        const collectable = tags?.tags?.find((t) => t.key === COLLECT_BY_TAG && Number(t.value) < Date.now());\n        if (collectable) {\n          // eslint-disable-next-line no-console\n          console.log('Deleting', repo.name);\n          await codeArtifact.send(\n            new DeleteRepositoryCommand({\n              domain: repo.domainName!,\n              repository: repo.name!,\n            }),\n          );\n        }\n      }\n\n      nextToken = page.nextToken;\n    } while (nextToken);\n  }\n\n  public readonly npmUpstream = 'npm-upstream';\n  public readonly pypiUpstream = 'pypi-upstream';\n  public readonly nugetUpstream = 'nuget-upstream';\n  public readonly mavenUpstream = 'maven-upstream';\n  public readonly domain = TestRepository.DEFAULT_DOMAIN;\n\n  private readonly codeArtifact = new CodeartifactClient();\n\n  private _loginInformation: LoginInformation | undefined;\n\n  private constructor(public readonly repositoryName: string) {}\n\n  public async prepare() {\n    await this.ensureDomain();\n    await this.ensureUpstreams();\n\n    await this.ensureRepository(this.repositoryName, {\n      description: 'Testing repository',\n      upstreams: [this.npmUpstream, this.pypiUpstream, this.nugetUpstream, this.mavenUpstream],\n      tags: {\n        [COLLECT_BY_TAG]: `${Date.now() + REPO_LIFETIME_MS}`,\n      },\n    });\n  }\n\n  public async loginInformation(): Promise<LoginInformation> {\n    if (this._loginInformation) {\n      return this._loginInformation;\n    }\n\n    this._loginInformation = {\n      authToken: (\n        await this.codeArtifact.send(\n          new GetAuthorizationTokenCommand({\n            domain: this.domain,\n            durationSeconds: 12 * 3600,\n          }),\n        )\n      ).authorizationToken!,\n      repositoryName: this.repositoryName,\n\n      npmEndpoint: (\n        await this.codeArtifact.send(\n          new GetRepositoryEndpointCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            format: 'npm',\n          }),\n        )\n      ).repositoryEndpoint!,\n\n      mavenEndpoint: (\n        await this.codeArtifact.send(\n          new GetRepositoryEndpointCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            format: 'maven',\n          }),\n        )\n      ).repositoryEndpoint!,\n\n      nugetEndpoint: (\n        await this.codeArtifact.send(\n          new GetRepositoryEndpointCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            format: 'nuget',\n          }),\n        )\n      ).repositoryEndpoint!,\n\n      pypiEndpoint: (\n        await this.codeArtifact.send(\n          new GetRepositoryEndpointCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            format: 'pypi',\n          }),\n        )\n      ).repositoryEndpoint!,\n    };\n    return this._loginInformation;\n  }\n\n  public async delete() {\n    try {\n      await this.codeArtifact.send(\n        new DeleteRepositoryCommand({\n          domain: this.domain,\n          repository: this.repositoryName,\n        }),\n      );\n\n      // eslint-disable-next-line no-console\n      console.log('Deleted', this.repositoryName);\n    } catch (e: any) {\n      if (e.name !== 'ResourceNotFoundException') {\n        throw e;\n      }\n      // Okay\n    }\n  }\n\n  /**\n   * List all packages and mark them as \"allow upstream versions\".\n   *\n   * If we don't do this and we publish `foo@2.3.4-rc.0`, then we can't\n   * download `foo@2.3.0` anymore because by default CodeArtifact will\n   * block different versions from the same package.\n   */\n  public async markAllUpstreamAllow() {\n    for await (const pkg of this.listPackages({ upstream: 'BLOCK' })) {\n      await retryThrottled(() =>\n        this.codeArtifact.send(\n          new PutPackageOriginConfigurationCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n\n            format: pkg.format!,\n            package: pkg.package!,\n            namespace: pkg.namespace!,\n            restrictions: {\n              publish: 'ALLOW',\n              upstream: 'ALLOW',\n            },\n          }),\n        ),\n      );\n    }\n  }\n\n  private async ensureDomain() {\n    if (await this.domainExists()) {\n      return;\n    }\n    await this.codeArtifact.send(\n      new CreateDomainCommand({\n        domain: this.domain,\n        tags: [{ key: 'testing', value: 'true' }],\n      }),\n    );\n  }\n\n  private async ensureUpstreams() {\n    await this.ensureRepository(this.npmUpstream, {\n      description: 'The upstream repository for NPM',\n      external: 'public:npmjs',\n    });\n    await this.ensureRepository(this.mavenUpstream, {\n      description: 'The upstream repository for Maven',\n      external: 'public:maven-central',\n    });\n    await this.ensureRepository(this.nugetUpstream, {\n      description: 'The upstream repository for NuGet',\n      external: 'public:nuget-org',\n    });\n    await this.ensureRepository(this.pypiUpstream, {\n      description: 'The upstream repository for PyPI',\n      external: 'public:pypi',\n    });\n  }\n\n  private async ensureRepository(\n    name: string,\n    options?: {\n      readonly description?: string;\n      readonly external?: string;\n      readonly upstreams?: string[];\n      readonly tags?: Record<string, string>;\n    },\n  ) {\n    if (await this.repositoryExists(name)) {\n      return;\n    }\n\n    await this.codeArtifact.send(\n      new CreateRepositoryCommand({\n        domain: this.domain,\n        repository: name,\n        description: options?.description,\n        upstreams: options?.upstreams?.map((repositoryName) => ({ repositoryName })),\n        tags: options?.tags ? Object.entries(options.tags).map(([key, value]) => ({ key, value })) : undefined,\n      }),\n    );\n\n    if (options?.external) {\n      const externalConnection = options.external;\n      await retry(() =>\n        this.codeArtifact.send(\n          new AssociateExternalConnectionCommand({\n            domain: this.domain,\n            repository: name,\n            externalConnection,\n          }),\n        ),\n      );\n    }\n  }\n\n  private async domainExists() {\n    try {\n      await this.codeArtifact.send(new DescribeDomainCommand({ domain: this.domain }));\n      return true;\n    } catch (e: any) {\n      if (e.name !== 'ResourceNotFoundException') {\n        throw e;\n      }\n      return false;\n    }\n  }\n\n  private async repositoryExists(name: string) {\n    try {\n      await this.codeArtifact.send(new DescribeRepositoryCommand({ domain: this.domain, repository: name }));\n      return true;\n    } catch (e: any) {\n      if (e.name !== 'ResourceNotFoundException') {\n        throw e;\n      }\n      return false;\n    }\n  }\n\n  private async *listPackages(filter: Pick<ListPackagesRequest, 'upstream' | 'publish' | 'format'> = {}) {\n    let response = await retryThrottled(() =>\n      this.codeArtifact.send(\n        new ListPackagesCommand({\n          domain: this.domain,\n          repository: this.repositoryName,\n          ...filter,\n        }),\n      ),\n    );\n\n    while (true) {\n      for (const p of response.packages ?? []) {\n        yield p;\n      }\n\n      if (!response.nextToken) {\n        break;\n      }\n\n      response = await retryThrottled(() =>\n        this.codeArtifact.send(\n          new ListPackagesCommand({\n            domain: this.domain,\n            repository: this.repositoryName,\n            ...filter,\n            nextToken: response.nextToken,\n          }),\n        ),\n      );\n    }\n  }\n}\n\nasync function retry<A>(block: () => Promise<A>) {\n  let attempts = 3;\n  while (true) {\n    try {\n      return await block();\n    } catch (e: any) {\n      if (attempts-- === 0) {\n        throw e;\n      }\n      // eslint-disable-next-line no-console\n      console.debug(e.message);\n      await sleep(500);\n    }\n  }\n}\n\nasync function retryThrottled<A>(block: () => Promise<A>) {\n  let time = 100;\n  let attempts = 15;\n  while (true) {\n    try {\n      return await block();\n    } catch (e: any) {\n      // eslint-disable-next-line no-console\n      console.debug(e.message);\n      if (e.name !== 'ThrottlingException') {\n        throw e;\n      }\n      if (attempts-- === 0) {\n        throw e;\n      }\n      await sleep(Math.floor(Math.random() * time));\n      time *= 2;\n    }\n  }\n}\n\nexport interface LoginInformation {\n  readonly authToken: string;\n  readonly repositoryName: string;\n  readonly npmEndpoint: string;\n  readonly mavenEndpoint: string;\n  readonly nugetEndpoint: string;\n  readonly pypiEndpoint: string;\n}\n"]}
@@ -0,0 +1,387 @@
1
+ import {
2
+ AssociateExternalConnectionCommand,
3
+ CodeartifactClient,
4
+ CreateDomainCommand,
5
+ CreateRepositoryCommand,
6
+ DeleteRepositoryCommand,
7
+ DescribeDomainCommand,
8
+ DescribeRepositoryCommand,
9
+ GetAuthorizationTokenCommand,
10
+ GetRepositoryEndpointCommand,
11
+ ListPackagesCommand,
12
+ ListPackagesRequest,
13
+ ListRepositoriesCommand,
14
+ ListTagsForResourceCommand,
15
+ PutPackageOriginConfigurationCommand,
16
+ } from '@aws-sdk/client-codeartifact';
17
+ import { sleep } from '../aws';
18
+
19
+ const COLLECT_BY_TAG = 'collect-by';
20
+ const REPO_LIFETIME_MS = 24 * 3600 * 1000; // One day
21
+
22
+ export class TestRepository {
23
+ public static readonly DEFAULT_DOMAIN = 'test-cdk';
24
+
25
+ public static async newRandom() {
26
+ const qualifier = Math.random()
27
+ .toString(36)
28
+ .replace(/[^a-z0-9]+/g, '');
29
+
30
+ const repo = new TestRepository(`test-${qualifier}`);
31
+ await repo.prepare();
32
+ return repo;
33
+ }
34
+
35
+ public static async newWithName(name: string) {
36
+ const repo = new TestRepository(name);
37
+ await repo.prepare();
38
+ return repo;
39
+ }
40
+
41
+ public static existing(repositoryName: string) {
42
+ return new TestRepository(repositoryName);
43
+ }
44
+
45
+ /**
46
+ * Garbage collect repositories
47
+ */
48
+ public static async gc() {
49
+ if (!(await TestRepository.existing('*dummy*').domainExists())) {
50
+ return;
51
+ }
52
+
53
+ const codeArtifact = new CodeartifactClient();
54
+
55
+ let nextToken: string | undefined;
56
+ do {
57
+ const page = await codeArtifact.send(
58
+ new ListRepositoriesCommand({
59
+ nextToken: nextToken,
60
+ }),
61
+ );
62
+
63
+ for (const repo of page.repositories ?? []) {
64
+ const tags = await codeArtifact.send(
65
+ new ListTagsForResourceCommand({
66
+ resourceArn: repo.arn!,
67
+ }),
68
+ );
69
+ const collectable = tags?.tags?.find((t) => t.key === COLLECT_BY_TAG && Number(t.value) < Date.now());
70
+ if (collectable) {
71
+ // eslint-disable-next-line no-console
72
+ console.log('Deleting', repo.name);
73
+ await codeArtifact.send(
74
+ new DeleteRepositoryCommand({
75
+ domain: repo.domainName!,
76
+ repository: repo.name!,
77
+ }),
78
+ );
79
+ }
80
+ }
81
+
82
+ nextToken = page.nextToken;
83
+ } while (nextToken);
84
+ }
85
+
86
+ public readonly npmUpstream = 'npm-upstream';
87
+ public readonly pypiUpstream = 'pypi-upstream';
88
+ public readonly nugetUpstream = 'nuget-upstream';
89
+ public readonly mavenUpstream = 'maven-upstream';
90
+ public readonly domain = TestRepository.DEFAULT_DOMAIN;
91
+
92
+ private readonly codeArtifact = new CodeartifactClient();
93
+
94
+ private _loginInformation: LoginInformation | undefined;
95
+
96
+ private constructor(public readonly repositoryName: string) {}
97
+
98
+ public async prepare() {
99
+ await this.ensureDomain();
100
+ await this.ensureUpstreams();
101
+
102
+ await this.ensureRepository(this.repositoryName, {
103
+ description: 'Testing repository',
104
+ upstreams: [this.npmUpstream, this.pypiUpstream, this.nugetUpstream, this.mavenUpstream],
105
+ tags: {
106
+ [COLLECT_BY_TAG]: `${Date.now() + REPO_LIFETIME_MS}`,
107
+ },
108
+ });
109
+ }
110
+
111
+ public async loginInformation(): Promise<LoginInformation> {
112
+ if (this._loginInformation) {
113
+ return this._loginInformation;
114
+ }
115
+
116
+ this._loginInformation = {
117
+ authToken: (
118
+ await this.codeArtifact.send(
119
+ new GetAuthorizationTokenCommand({
120
+ domain: this.domain,
121
+ durationSeconds: 12 * 3600,
122
+ }),
123
+ )
124
+ ).authorizationToken!,
125
+ repositoryName: this.repositoryName,
126
+
127
+ npmEndpoint: (
128
+ await this.codeArtifact.send(
129
+ new GetRepositoryEndpointCommand({
130
+ domain: this.domain,
131
+ repository: this.repositoryName,
132
+ format: 'npm',
133
+ }),
134
+ )
135
+ ).repositoryEndpoint!,
136
+
137
+ mavenEndpoint: (
138
+ await this.codeArtifact.send(
139
+ new GetRepositoryEndpointCommand({
140
+ domain: this.domain,
141
+ repository: this.repositoryName,
142
+ format: 'maven',
143
+ }),
144
+ )
145
+ ).repositoryEndpoint!,
146
+
147
+ nugetEndpoint: (
148
+ await this.codeArtifact.send(
149
+ new GetRepositoryEndpointCommand({
150
+ domain: this.domain,
151
+ repository: this.repositoryName,
152
+ format: 'nuget',
153
+ }),
154
+ )
155
+ ).repositoryEndpoint!,
156
+
157
+ pypiEndpoint: (
158
+ await this.codeArtifact.send(
159
+ new GetRepositoryEndpointCommand({
160
+ domain: this.domain,
161
+ repository: this.repositoryName,
162
+ format: 'pypi',
163
+ }),
164
+ )
165
+ ).repositoryEndpoint!,
166
+ };
167
+ return this._loginInformation;
168
+ }
169
+
170
+ public async delete() {
171
+ try {
172
+ await this.codeArtifact.send(
173
+ new DeleteRepositoryCommand({
174
+ domain: this.domain,
175
+ repository: this.repositoryName,
176
+ }),
177
+ );
178
+
179
+ // eslint-disable-next-line no-console
180
+ console.log('Deleted', this.repositoryName);
181
+ } catch (e: any) {
182
+ if (e.name !== 'ResourceNotFoundException') {
183
+ throw e;
184
+ }
185
+ // Okay
186
+ }
187
+ }
188
+
189
+ /**
190
+ * List all packages and mark them as "allow upstream versions".
191
+ *
192
+ * If we don't do this and we publish `foo@2.3.4-rc.0`, then we can't
193
+ * download `foo@2.3.0` anymore because by default CodeArtifact will
194
+ * block different versions from the same package.
195
+ */
196
+ public async markAllUpstreamAllow() {
197
+ for await (const pkg of this.listPackages({ upstream: 'BLOCK' })) {
198
+ await retryThrottled(() =>
199
+ this.codeArtifact.send(
200
+ new PutPackageOriginConfigurationCommand({
201
+ domain: this.domain,
202
+ repository: this.repositoryName,
203
+
204
+ format: pkg.format!,
205
+ package: pkg.package!,
206
+ namespace: pkg.namespace!,
207
+ restrictions: {
208
+ publish: 'ALLOW',
209
+ upstream: 'ALLOW',
210
+ },
211
+ }),
212
+ ),
213
+ );
214
+ }
215
+ }
216
+
217
+ private async ensureDomain() {
218
+ if (await this.domainExists()) {
219
+ return;
220
+ }
221
+ await this.codeArtifact.send(
222
+ new CreateDomainCommand({
223
+ domain: this.domain,
224
+ tags: [{ key: 'testing', value: 'true' }],
225
+ }),
226
+ );
227
+ }
228
+
229
+ private async ensureUpstreams() {
230
+ await this.ensureRepository(this.npmUpstream, {
231
+ description: 'The upstream repository for NPM',
232
+ external: 'public:npmjs',
233
+ });
234
+ await this.ensureRepository(this.mavenUpstream, {
235
+ description: 'The upstream repository for Maven',
236
+ external: 'public:maven-central',
237
+ });
238
+ await this.ensureRepository(this.nugetUpstream, {
239
+ description: 'The upstream repository for NuGet',
240
+ external: 'public:nuget-org',
241
+ });
242
+ await this.ensureRepository(this.pypiUpstream, {
243
+ description: 'The upstream repository for PyPI',
244
+ external: 'public:pypi',
245
+ });
246
+ }
247
+
248
+ private async ensureRepository(
249
+ name: string,
250
+ options?: {
251
+ readonly description?: string;
252
+ readonly external?: string;
253
+ readonly upstreams?: string[];
254
+ readonly tags?: Record<string, string>;
255
+ },
256
+ ) {
257
+ if (await this.repositoryExists(name)) {
258
+ return;
259
+ }
260
+
261
+ await this.codeArtifact.send(
262
+ new CreateRepositoryCommand({
263
+ domain: this.domain,
264
+ repository: name,
265
+ description: options?.description,
266
+ upstreams: options?.upstreams?.map((repositoryName) => ({ repositoryName })),
267
+ tags: options?.tags ? Object.entries(options.tags).map(([key, value]) => ({ key, value })) : undefined,
268
+ }),
269
+ );
270
+
271
+ if (options?.external) {
272
+ const externalConnection = options.external;
273
+ await retry(() =>
274
+ this.codeArtifact.send(
275
+ new AssociateExternalConnectionCommand({
276
+ domain: this.domain,
277
+ repository: name,
278
+ externalConnection,
279
+ }),
280
+ ),
281
+ );
282
+ }
283
+ }
284
+
285
+ private async domainExists() {
286
+ try {
287
+ await this.codeArtifact.send(new DescribeDomainCommand({ domain: this.domain }));
288
+ return true;
289
+ } catch (e: any) {
290
+ if (e.name !== 'ResourceNotFoundException') {
291
+ throw e;
292
+ }
293
+ return false;
294
+ }
295
+ }
296
+
297
+ private async repositoryExists(name: string) {
298
+ try {
299
+ await this.codeArtifact.send(new DescribeRepositoryCommand({ domain: this.domain, repository: name }));
300
+ return true;
301
+ } catch (e: any) {
302
+ if (e.name !== 'ResourceNotFoundException') {
303
+ throw e;
304
+ }
305
+ return false;
306
+ }
307
+ }
308
+
309
+ private async *listPackages(filter: Pick<ListPackagesRequest, 'upstream' | 'publish' | 'format'> = {}) {
310
+ let response = await retryThrottled(() =>
311
+ this.codeArtifact.send(
312
+ new ListPackagesCommand({
313
+ domain: this.domain,
314
+ repository: this.repositoryName,
315
+ ...filter,
316
+ }),
317
+ ),
318
+ );
319
+
320
+ while (true) {
321
+ for (const p of response.packages ?? []) {
322
+ yield p;
323
+ }
324
+
325
+ if (!response.nextToken) {
326
+ break;
327
+ }
328
+
329
+ response = await retryThrottled(() =>
330
+ this.codeArtifact.send(
331
+ new ListPackagesCommand({
332
+ domain: this.domain,
333
+ repository: this.repositoryName,
334
+ ...filter,
335
+ nextToken: response.nextToken,
336
+ }),
337
+ ),
338
+ );
339
+ }
340
+ }
341
+ }
342
+
343
+ async function retry<A>(block: () => Promise<A>) {
344
+ let attempts = 3;
345
+ while (true) {
346
+ try {
347
+ return await block();
348
+ } catch (e: any) {
349
+ if (attempts-- === 0) {
350
+ throw e;
351
+ }
352
+ // eslint-disable-next-line no-console
353
+ console.debug(e.message);
354
+ await sleep(500);
355
+ }
356
+ }
357
+ }
358
+
359
+ async function retryThrottled<A>(block: () => Promise<A>) {
360
+ let time = 100;
361
+ let attempts = 15;
362
+ while (true) {
363
+ try {
364
+ return await block();
365
+ } catch (e: any) {
366
+ // eslint-disable-next-line no-console
367
+ console.debug(e.message);
368
+ if (e.name !== 'ThrottlingException') {
369
+ throw e;
370
+ }
371
+ if (attempts-- === 0) {
372
+ throw e;
373
+ }
374
+ await sleep(Math.floor(Math.random() * time));
375
+ time *= 2;
376
+ }
377
+ }
378
+ }
379
+
380
+ export interface LoginInformation {
381
+ readonly authToken: string;
382
+ readonly repositoryName: string;
383
+ readonly npmEndpoint: string;
384
+ readonly mavenEndpoint: string;
385
+ readonly nugetEndpoint: string;
386
+ readonly pypiEndpoint: string;
387
+ }
@@ -12,11 +12,12 @@ const shell_1 = require("../shell");
12
12
  // Do not try to JIT the Maven binary
13
13
  const NO_JIT = '-XX:+TieredCompilation -XX:TieredStopAtLevel=1';
14
14
  async function mavenLogin(login, usageDir) {
15
+ var _a;
15
16
  await writeMavenSettingsFile(settingsFile(usageDir), login);
16
17
  // Write env var
17
18
  // Twiddle JVM settings a bit to make Maven survive running on a CodeBuild box.
18
19
  await usageDir.addToEnv({
19
- MAVEN_OPTS: `-Duser.home=${usageDir.directory} ${NO_JIT} ${process.env.MAVEN_OPTS ?? ''}`.trim(),
20
+ MAVEN_OPTS: `-Duser.home=${usageDir.directory} ${NO_JIT} ${(_a = process.env.MAVEN_OPTS) !== null && _a !== void 0 ? _a : ''}`.trim(),
20
21
  });
21
22
  }
22
23
  function settingsFile(usageDir) {
@@ -26,6 +27,7 @@ function settingsFile(usageDir) {
26
27
  }
27
28
  async function uploadJavaPackages(packages, login, usageDir) {
28
29
  await (0, parallel_shell_1.parallelShell)(packages, async (pkg, output) => {
30
+ var _a;
29
31
  console.log(`⏳ ${pkg}`);
30
32
  const sourcesFile = pkg.replace(/.pom$/, '-sources.jar');
31
33
  const javadocFile = pkg.replace(/.pom$/, '-javadoc.jar');
@@ -41,7 +43,7 @@ async function uploadJavaPackages(packages, login, usageDir) {
41
43
  outputs: [output],
42
44
  modEnv: {
43
45
  // Do not try to JIT the Maven binary
44
- MAVEN_OPTS: `${NO_JIT} ${process.env.MAVEN_OPTS ?? ''}`.trim(),
46
+ MAVEN_OPTS: `${NO_JIT} ${(_a = process.env.MAVEN_OPTS) !== null && _a !== void 0 ? _a : ''}`.trim(),
45
47
  },
46
48
  });
47
49
  console.log(`✅ ${pkg}`);
@@ -86,4 +88,4 @@ async function writeMavenSettingsFile(filename, login) {
86
88
  </activeProfiles>
87
89
  </settings>`);
88
90
  }
89
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF2ZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtYXZlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQVlBLGdDQVFDO0FBUUQsZ0RBb0NDO0FBRUQsd0RBNEJDO0FBOUZELCtCQUErQjtBQUMvQiw2QkFBNkI7QUFDN0IsdUNBQXNDO0FBRXRDLHFEQUFpRDtBQUVqRCxvQ0FBcUM7QUFDckMsb0NBQWlDO0FBRWpDLHFDQUFxQztBQUNyQyxNQUFNLE1BQU0sR0FBRyxnREFBZ0QsQ0FBQztBQUV6RCxLQUFLLFVBQVUsVUFBVSxDQUFDLEtBQXVCLEVBQUUsUUFBa0I7SUFDMUUsTUFBTSxzQkFBc0IsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFFNUQsZ0JBQWdCO0lBQ2hCLCtFQUErRTtJQUMvRSxNQUFNLFFBQVEsQ0FBQyxRQUFRLENBQUM7UUFDdEIsVUFBVSxFQUFFLGVBQWUsUUFBUSxDQUFDLFNBQVMsSUFBSSxNQUFNLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxFQUFFO0tBQ2pHLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxTQUFTLFlBQVksQ0FBQyxRQUFrQjtJQUN0QywrRUFBK0U7SUFDL0UsNEVBQTRFO0lBQzVFLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLEtBQUssRUFBRSxjQUFjLENBQUMsQ0FBQztBQUM5RCxDQUFDO0FBRU0sS0FBSyxVQUFVLGtCQUFrQixDQUFDLFFBQWtCLEVBQUUsS0FBdUIsRUFBRSxRQUFrQjtJQUN0RyxNQUFNLElBQUEsOEJBQWEsRUFBQyxRQUFRLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUNsRCxPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssR0FBRyxFQUFFLENBQUMsQ0FBQztRQUV4QixNQUFNLFdBQVcsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQztRQUN6RCxNQUFNLFdBQVcsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQztRQUV6RCxNQUFNLElBQUEsYUFBSyxFQUFDLENBQUMsS0FBSztZQUNoQixjQUFjLFlBQVksQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUN0QyxnRUFBZ0U7WUFDaEUsU0FBUyxLQUFLLENBQUMsYUFBYSxFQUFFO1lBQzlCLDZCQUE2QjtZQUM3QixhQUFhLEdBQUcsRUFBRTtZQUNsQixVQUFVLEdBQUcsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxFQUFFO1lBQ3hDLEdBQUcsTUFBTSxJQUFBLHFCQUFVLEVBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsYUFBYSxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ3BFLEdBQUcsTUFBTSxJQUFBLHFCQUFVLEVBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsYUFBYSxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRTtZQUN2RSxPQUFPLEVBQUUsQ0FBQyxNQUFNLENBQUM7WUFDakIsTUFBTSxFQUFFO2dCQUNOLHFDQUFxQztnQkFDckMsVUFBVSxFQUFFLEdBQUcsTUFBTSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksRUFBRTthQUMvRDtTQUNGLENBQUMsQ0FBQztRQUVILE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxDQUFDO0lBQzFCLENBQUMsRUFDRCxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUNkLElBQUksTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUMsRUFBRSxDQUFDO1lBQy9DLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxHQUFHLDRCQUE0QixDQUFDLENBQUM7WUFDbEQsT0FBTyxNQUFNLENBQUM7UUFDaEIsQ0FBQztRQUNELElBQUksTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLENBQUM7WUFDcEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxNQUFNLEdBQUcsZ0NBQWdDLENBQUMsQ0FBQztZQUN2RCxPQUFPLE9BQU8sQ0FBQztRQUNqQixDQUFDO1FBQ0QsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRU0sS0FBSyxVQUFVLHNCQUFzQixDQUFDLFFBQWdCLEVBQUUsS0FBdUI7SUFDcEYsTUFBTSxJQUFBLGlCQUFTLEVBQUMsUUFBUSxFQUFFOzs7Ozs7Ozs7b0JBU1IsS0FBSyxDQUFDLFNBQVM7Ozs7Ozs7OzttQkFTaEIsS0FBSyxDQUFDLGFBQWE7Ozs7Ozs7O2NBUXhCLENBQUMsQ0FBQztBQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tY29uc29sZSAqL1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IHBhdGhFeGlzdHMgfSBmcm9tICdmcy1leHRyYSc7XG5pbXBvcnQgeyBMb2dpbkluZm9ybWF0aW9uIH0gZnJvbSAnLi9jb2RlYXJ0aWZhY3QnO1xuaW1wb3J0IHsgcGFyYWxsZWxTaGVsbCB9IGZyb20gJy4vcGFyYWxsZWwtc2hlbGwnO1xuaW1wb3J0IHsgVXNhZ2VEaXIgfSBmcm9tICcuL3VzYWdlLWRpcic7XG5pbXBvcnQgeyB3cml0ZUZpbGUgfSBmcm9tICcuLi9maWxlcyc7XG5pbXBvcnQgeyBzaGVsbCB9IGZyb20gJy4uL3NoZWxsJztcblxuLy8gRG8gbm90IHRyeSB0byBKSVQgdGhlIE1hdmVuIGJpbmFyeVxuY29uc3QgTk9fSklUID0gJy1YWDorVGllcmVkQ29tcGlsYXRpb24gLVhYOlRpZXJlZFN0b3BBdExldmVsPTEnO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbWF2ZW5Mb2dpbihsb2dpbjogTG9naW5JbmZvcm1hdGlvbiwgdXNhZ2VEaXI6IFVzYWdlRGlyKSB7XG4gIGF3YWl0IHdyaXRlTWF2ZW5TZXR0aW5nc0ZpbGUoc2V0dGluZ3NGaWxlKHVzYWdlRGlyKSwgbG9naW4pO1xuXG4gIC8vIFdyaXRlIGVudiB2YXJcbiAgLy8gVHdpZGRsZSBKVk0gc2V0dGluZ3MgYSBiaXQgdG8gbWFrZSBNYXZlbiBzdXJ2aXZlIHJ1bm5pbmcgb24gYSBDb2RlQnVpbGQgYm94LlxuICBhd2FpdCB1c2FnZURpci5hZGRUb0Vudih7XG4gICAgTUFWRU5fT1BUUzogYC1EdXNlci5ob21lPSR7dXNhZ2VEaXIuZGlyZWN0b3J5fSAke05PX0pJVH0gJHtwcm9jZXNzLmVudi5NQVZFTl9PUFRTID8/ICcnfWAudHJpbSgpLFxuICB9KTtcbn1cblxuZnVuY3Rpb24gc2V0dGluZ3NGaWxlKHVzYWdlRGlyOiBVc2FnZURpcikge1xuICAvLyBJZiB3ZSBjb25maWd1cmUgdXNhZ2VEaXIgYXMgYSBmYWtlIGhvbWUgZGlyZWN0b3J5IE1hdmVuIHdpbGwgZmluZCB0aGlzIGZpbGUuXG4gIC8vIChObyBvdGhlciB3YXkgdG8gY29uZmlndXJlIHRoZSBzZXR0aW5ncyBmaWxlIGFzIHBhcnQgb2YgdGhlIGVudmlyb25tZW50KS5cbiAgcmV0dXJuIHBhdGguam9pbih1c2FnZURpci5kaXJlY3RvcnksICcubTInLCAnc2V0dGluZ3MueG1sJyk7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB1cGxvYWRKYXZhUGFja2FnZXMocGFja2FnZXM6IHN0cmluZ1tdLCBsb2dpbjogTG9naW5JbmZvcm1hdGlvbiwgdXNhZ2VEaXI6IFVzYWdlRGlyKSB7XG4gIGF3YWl0IHBhcmFsbGVsU2hlbGwocGFja2FnZXMsIGFzeW5jIChwa2csIG91dHB1dCkgPT4ge1xuICAgIGNvbnNvbGUubG9nKGDij7MgJHtwa2d9YCk7XG5cbiAgICBjb25zdCBzb3VyY2VzRmlsZSA9IHBrZy5yZXBsYWNlKC8ucG9tJC8sICctc291cmNlcy5qYXInKTtcbiAgICBjb25zdCBqYXZhZG9jRmlsZSA9IHBrZy5yZXBsYWNlKC8ucG9tJC8sICctamF2YWRvYy5qYXInKTtcblxuICAgIGF3YWl0IHNoZWxsKFsnbXZuJyxcbiAgICAgIGAtLXNldHRpbmdzPSR7c2V0dGluZ3NGaWxlKHVzYWdlRGlyKX1gLFxuICAgICAgJ29yZy5hcGFjaGUubWF2ZW4ucGx1Z2luczptYXZlbi1kZXBsb3ktcGx1Z2luOjMuMC4wOmRlcGxveS1maWxlJyxcbiAgICAgIGAtRHVybD0ke2xvZ2luLm1hdmVuRW5kcG9pbnR9YCxcbiAgICAgICctRHJlcG9zaXRvcnlJZD1jb2RlYXJ0aWZhY3QnLFxuICAgICAgYC1EcG9tRmlsZT0ke3BrZ31gLFxuICAgICAgYC1EZmlsZT0ke3BrZy5yZXBsYWNlKC8ucG9tJC8sICcuamFyJyl9YCxcbiAgICAgIC4uLmF3YWl0IHBhdGhFeGlzdHMoc291cmNlc0ZpbGUpID8gW2AtRHNvdXJjZXM9JHtzb3VyY2VzRmlsZX1gXSA6IFtdLFxuICAgICAgLi4uYXdhaXQgcGF0aEV4aXN0cyhqYXZhZG9jRmlsZSkgPyBbYC1EamF2YWRvYz0ke2phdmFkb2NGaWxlfWBdIDogW11dLCB7XG4gICAgICBvdXRwdXRzOiBbb3V0cHV0XSxcbiAgICAgIG1vZEVudjoge1xuICAgICAgICAvLyBEbyBub3QgdHJ5IHRvIEpJVCB0aGUgTWF2ZW4gYmluYXJ5XG4gICAgICAgIE1BVkVOX09QVFM6IGAke05PX0pJVH0gJHtwcm9jZXNzLmVudi5NQVZFTl9PUFRTID8/ICcnfWAudHJpbSgpLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIGNvbnNvbGUubG9nKGDinIUgJHtwa2d9YCk7XG4gIH0sXG4gIChwa2csIG91dHB1dCkgPT4ge1xuICAgIGlmIChvdXRwdXQudG9TdHJpbmcoKS5pbmNsdWRlcygnNDA5IENvbmZsaWN0JykpIHtcbiAgICAgIGNvbnNvbGUubG9nKGDinYwgJHtwa2d9OiBhbHJlYWR5IGV4aXN0cy4gU2tpcHBlZC5gKTtcbiAgICAgIHJldHVybiAnc2tpcCc7XG4gICAgfVxuICAgIGlmIChvdXRwdXQudG9TdHJpbmcoKS5pbmNsdWRlcygnVG9vIE1hbnkgUmVxdWVzdHMnKSkge1xuICAgICAgY29uc29sZS5sb2coYOKZu++4jyAke3BrZ306IFRvbyBtYW55IHJlcXVlc3RzLiBSZXRyeWluZy5gKTtcbiAgICAgIHJldHVybiAncmV0cnknO1xuICAgIH1cbiAgICByZXR1cm4gJ2ZhaWwnO1xuICB9KTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHdyaXRlTWF2ZW5TZXR0aW5nc0ZpbGUoZmlsZW5hbWU6IHN0cmluZywgbG9naW46IExvZ2luSW5mb3JtYXRpb24pIHtcbiAgYXdhaXQgd3JpdGVGaWxlKGZpbGVuYW1lLCBgPD94bWwgdmVyc2lvbj1cIjEuMFwiIGVuY29kaW5nPVwiVVRGLThcIiA/PlxuICA8c2V0dGluZ3MgeG1sbnM9XCJodHRwOi8vbWF2ZW4uYXBhY2hlLm9yZy9TRVRUSU5HUy8xLjAuMFwiXG4gICAgICAgICAgICB4bWxuczp4c2k9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZVwiXG4gICAgICAgICAgICB4c2k6c2NoZW1hTG9jYXRpb249XCJodHRwOi8vbWF2ZW4uYXBhY2hlLm9yZy9TRVRUSU5HUy8xLjAuMFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBodHRwOi8vbWF2ZW4uYXBhY2hlLm9yZy94c2Qvc2V0dGluZ3MtMS4wLjAueHNkXCI+XG4gICAgPHNlcnZlcnM+XG4gICAgICA8c2VydmVyPlxuICAgICAgICA8aWQ+Y29kZWFydGlmYWN0PC9pZD5cbiAgICAgICAgPHVzZXJuYW1lPmF3czwvdXNlcm5hbWU+XG4gICAgICAgIDxwYXNzd29yZD4ke2xvZ2luLmF1dGhUb2tlbn08L3Bhc3N3b3JkPlxuICAgICAgPC9zZXJ2ZXI+XG4gICAgPC9zZXJ2ZXJzPlxuICAgIDxwcm9maWxlcz5cbiAgICAgIDxwcm9maWxlPlxuICAgICAgICA8aWQ+ZGVmYXVsdDwvaWQ+XG4gICAgICAgIDxyZXBvc2l0b3JpZXM+XG4gICAgICAgICAgPHJlcG9zaXRvcnk+XG4gICAgICAgICAgICA8aWQ+Y29kZWFydGlmYWN0PC9pZD5cbiAgICAgICAgICAgIDx1cmw+JHtsb2dpbi5tYXZlbkVuZHBvaW50fTwvdXJsPlxuICAgICAgICAgIDwvcmVwb3NpdG9yeT5cbiAgICAgICAgPC9yZXBvc2l0b3JpZXM+XG4gICAgICA8L3Byb2ZpbGU+XG4gICAgPC9wcm9maWxlcz5cbiAgICA8YWN0aXZlUHJvZmlsZXM+XG4gICAgICA8YWN0aXZlUHJvZmlsZT5kZWZhdWx0PC9hY3RpdmVQcm9maWxlPlxuICAgIDwvYWN0aXZlUHJvZmlsZXM+XG4gIDwvc2V0dGluZ3M+YCk7XG59XG4iXX0=
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF2ZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtYXZlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQVlBLGdDQVFDO0FBUUQsZ0RBb0NDO0FBRUQsd0RBNEJDO0FBOUZELCtCQUErQjtBQUMvQiw2QkFBNkI7QUFDN0IsdUNBQXNDO0FBRXRDLHFEQUFpRDtBQUVqRCxvQ0FBcUM7QUFDckMsb0NBQWlDO0FBRWpDLHFDQUFxQztBQUNyQyxNQUFNLE1BQU0sR0FBRyxnREFBZ0QsQ0FBQztBQUV6RCxLQUFLLFVBQVUsVUFBVSxDQUFDLEtBQXVCLEVBQUUsUUFBa0I7O0lBQzFFLE1BQU0sc0JBQXNCLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBRTVELGdCQUFnQjtJQUNoQiwrRUFBK0U7SUFDL0UsTUFBTSxRQUFRLENBQUMsUUFBUSxDQUFDO1FBQ3RCLFVBQVUsRUFBRSxlQUFlLFFBQVEsQ0FBQyxTQUFTLElBQUksTUFBTSxJQUFJLE1BQUEsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLG1DQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksRUFBRTtLQUNqRyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsU0FBUyxZQUFZLENBQUMsUUFBa0I7SUFDdEMsK0VBQStFO0lBQy9FLDRFQUE0RTtJQUM1RSxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLFNBQVMsRUFBRSxLQUFLLEVBQUUsY0FBYyxDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUVNLEtBQUssVUFBVSxrQkFBa0IsQ0FBQyxRQUFrQixFQUFFLEtBQXVCLEVBQUUsUUFBa0I7SUFDdEcsTUFBTSxJQUFBLDhCQUFhLEVBQUMsUUFBUSxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsTUFBTSxFQUFFLEVBQUU7O1FBQ2xELE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBRXhCLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLGNBQWMsQ0FBQyxDQUFDO1FBQ3pELE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLGNBQWMsQ0FBQyxDQUFDO1FBRXpELE1BQU0sSUFBQSxhQUFLLEVBQUMsQ0FBQyxLQUFLO1lBQ2hCLGNBQWMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxFQUFFO1lBQ3RDLGdFQUFnRTtZQUNoRSxTQUFTLEtBQUssQ0FBQyxhQUFhLEVBQUU7WUFDOUIsNkJBQTZCO1lBQzdCLGFBQWEsR0FBRyxFQUFFO1lBQ2xCLFVBQVUsR0FBRyxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLEVBQUU7WUFDeEMsR0FBRyxNQUFNLElBQUEscUJBQVUsRUFBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxhQUFhLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDcEUsR0FBRyxNQUFNLElBQUEscUJBQVUsRUFBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxhQUFhLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFO1lBQ3ZFLE9BQU8sRUFBRSxDQUFDLE1BQU0sQ0FBQztZQUNqQixNQUFNLEVBQUU7Z0JBQ04scUNBQXFDO2dCQUNyQyxVQUFVLEVBQUUsR0FBRyxNQUFNLElBQUksTUFBQSxPQUFPLENBQUMsR0FBRyxDQUFDLFVBQVUsbUNBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxFQUFFO2FBQy9EO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDMUIsQ0FBQyxFQUNELENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxFQUFFO1FBQ2QsSUFBSSxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUM7WUFDL0MsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEdBQUcsNEJBQTRCLENBQUMsQ0FBQztZQUNsRCxPQUFPLE1BQU0sQ0FBQztRQUNoQixDQUFDO1FBQ0QsSUFBSSxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxDQUFDLG1CQUFtQixDQUFDLEVBQUUsQ0FBQztZQUNwRCxPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sR0FBRyxnQ0FBZ0MsQ0FBQyxDQUFDO1lBQ3ZELE9BQU8sT0FBTyxDQUFDO1FBQ2pCLENBQUM7UUFDRCxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFTSxLQUFLLFVBQVUsc0JBQXNCLENBQUMsUUFBZ0IsRUFBRSxLQUF1QjtJQUNwRixNQUFNLElBQUEsaUJBQVMsRUFBQyxRQUFRLEVBQUU7Ozs7Ozs7OztvQkFTUixLQUFLLENBQUMsU0FBUzs7Ozs7Ozs7O21CQVNoQixLQUFLLENBQUMsYUFBYTs7Ozs7Ozs7Y0FReEIsQ0FBQyxDQUFDO0FBQ2hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1jb25zb2xlICovXG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IHsgcGF0aEV4aXN0cyB9IGZyb20gJ2ZzLWV4dHJhJztcbmltcG9ydCB7IExvZ2luSW5mb3JtYXRpb24gfSBmcm9tICcuL2NvZGVhcnRpZmFjdCc7XG5pbXBvcnQgeyBwYXJhbGxlbFNoZWxsIH0gZnJvbSAnLi9wYXJhbGxlbC1zaGVsbCc7XG5pbXBvcnQgeyBVc2FnZURpciB9IGZyb20gJy4vdXNhZ2UtZGlyJztcbmltcG9ydCB7IHdyaXRlRmlsZSB9IGZyb20gJy4uL2ZpbGVzJztcbmltcG9ydCB7IHNoZWxsIH0gZnJvbSAnLi4vc2hlbGwnO1xuXG4vLyBEbyBub3QgdHJ5IHRvIEpJVCB0aGUgTWF2ZW4gYmluYXJ5XG5jb25zdCBOT19KSVQgPSAnLVhYOitUaWVyZWRDb21waWxhdGlvbiAtWFg6VGllcmVkU3RvcEF0TGV2ZWw9MSc7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBtYXZlbkxvZ2luKGxvZ2luOiBMb2dpbkluZm9ybWF0aW9uLCB1c2FnZURpcjogVXNhZ2VEaXIpIHtcbiAgYXdhaXQgd3JpdGVNYXZlblNldHRpbmdzRmlsZShzZXR0aW5nc0ZpbGUodXNhZ2VEaXIpLCBsb2dpbik7XG5cbiAgLy8gV3JpdGUgZW52IHZhclxuICAvLyBUd2lkZGxlIEpWTSBzZXR0aW5ncyBhIGJpdCB0byBtYWtlIE1hdmVuIHN1cnZpdmUgcnVubmluZyBvbiBhIENvZGVCdWlsZCBib3guXG4gIGF3YWl0IHVzYWdlRGlyLmFkZFRvRW52KHtcbiAgICBNQVZFTl9PUFRTOiBgLUR1c2VyLmhvbWU9JHt1c2FnZURpci5kaXJlY3Rvcnl9ICR7Tk9fSklUfSAke3Byb2Nlc3MuZW52Lk1BVkVOX09QVFMgPz8gJyd9YC50cmltKCksXG4gIH0pO1xufVxuXG5mdW5jdGlvbiBzZXR0aW5nc0ZpbGUodXNhZ2VEaXI6IFVzYWdlRGlyKSB7XG4gIC8vIElmIHdlIGNvbmZpZ3VyZSB1c2FnZURpciBhcyBhIGZha2UgaG9tZSBkaXJlY3RvcnkgTWF2ZW4gd2lsbCBmaW5kIHRoaXMgZmlsZS5cbiAgLy8gKE5vIG90aGVyIHdheSB0byBjb25maWd1cmUgdGhlIHNldHRpbmdzIGZpbGUgYXMgcGFydCBvZiB0aGUgZW52aXJvbm1lbnQpLlxuICByZXR1cm4gcGF0aC5qb2luKHVzYWdlRGlyLmRpcmVjdG9yeSwgJy5tMicsICdzZXR0aW5ncy54bWwnKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHVwbG9hZEphdmFQYWNrYWdlcyhwYWNrYWdlczogc3RyaW5nW10sIGxvZ2luOiBMb2dpbkluZm9ybWF0aW9uLCB1c2FnZURpcjogVXNhZ2VEaXIpIHtcbiAgYXdhaXQgcGFyYWxsZWxTaGVsbChwYWNrYWdlcywgYXN5bmMgKHBrZywgb3V0cHV0KSA9PiB7XG4gICAgY29uc29sZS5sb2coYOKPsyAke3BrZ31gKTtcblxuICAgIGNvbnN0IHNvdXJjZXNGaWxlID0gcGtnLnJlcGxhY2UoLy5wb20kLywgJy1zb3VyY2VzLmphcicpO1xuICAgIGNvbnN0IGphdmFkb2NGaWxlID0gcGtnLnJlcGxhY2UoLy5wb20kLywgJy1qYXZhZG9jLmphcicpO1xuXG4gICAgYXdhaXQgc2hlbGwoWydtdm4nLFxuICAgICAgYC0tc2V0dGluZ3M9JHtzZXR0aW5nc0ZpbGUodXNhZ2VEaXIpfWAsXG4gICAgICAnb3JnLmFwYWNoZS5tYXZlbi5wbHVnaW5zOm1hdmVuLWRlcGxveS1wbHVnaW46My4wLjA6ZGVwbG95LWZpbGUnLFxuICAgICAgYC1EdXJsPSR7bG9naW4ubWF2ZW5FbmRwb2ludH1gLFxuICAgICAgJy1EcmVwb3NpdG9yeUlkPWNvZGVhcnRpZmFjdCcsXG4gICAgICBgLURwb21GaWxlPSR7cGtnfWAsXG4gICAgICBgLURmaWxlPSR7cGtnLnJlcGxhY2UoLy5wb20kLywgJy5qYXInKX1gLFxuICAgICAgLi4uYXdhaXQgcGF0aEV4aXN0cyhzb3VyY2VzRmlsZSkgPyBbYC1Ec291cmNlcz0ke3NvdXJjZXNGaWxlfWBdIDogW10sXG4gICAgICAuLi5hd2FpdCBwYXRoRXhpc3RzKGphdmFkb2NGaWxlKSA/IFtgLURqYXZhZG9jPSR7amF2YWRvY0ZpbGV9YF0gOiBbXV0sIHtcbiAgICAgIG91dHB1dHM6IFtvdXRwdXRdLFxuICAgICAgbW9kRW52OiB7XG4gICAgICAgIC8vIERvIG5vdCB0cnkgdG8gSklUIHRoZSBNYXZlbiBiaW5hcnlcbiAgICAgICAgTUFWRU5fT1BUUzogYCR7Tk9fSklUfSAke3Byb2Nlc3MuZW52Lk1BVkVOX09QVFMgPz8gJyd9YC50cmltKCksXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgY29uc29sZS5sb2coYOKchSAke3BrZ31gKTtcbiAgfSxcbiAgKHBrZywgb3V0cHV0KSA9PiB7XG4gICAgaWYgKG91dHB1dC50b1N0cmluZygpLmluY2x1ZGVzKCc0MDkgQ29uZmxpY3QnKSkge1xuICAgICAgY29uc29sZS5sb2coYOKdjCAke3BrZ306IGFscmVhZHkgZXhpc3RzLiBTa2lwcGVkLmApO1xuICAgICAgcmV0dXJuICdza2lwJztcbiAgICB9XG4gICAgaWYgKG91dHB1dC50b1N0cmluZygpLmluY2x1ZGVzKCdUb28gTWFueSBSZXF1ZXN0cycpKSB7XG4gICAgICBjb25zb2xlLmxvZyhg4pm777iPICR7cGtnfTogVG9vIG1hbnkgcmVxdWVzdHMuIFJldHJ5aW5nLmApO1xuICAgICAgcmV0dXJuICdyZXRyeSc7XG4gICAgfVxuICAgIHJldHVybiAnZmFpbCc7XG4gIH0pO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gd3JpdGVNYXZlblNldHRpbmdzRmlsZShmaWxlbmFtZTogc3RyaW5nLCBsb2dpbjogTG9naW5JbmZvcm1hdGlvbikge1xuICBhd2FpdCB3cml0ZUZpbGUoZmlsZW5hbWUsIGA8P3htbCB2ZXJzaW9uPVwiMS4wXCIgZW5jb2Rpbmc9XCJVVEYtOFwiID8+XG4gIDxzZXR0aW5ncyB4bWxucz1cImh0dHA6Ly9tYXZlbi5hcGFjaGUub3JnL1NFVFRJTkdTLzEuMC4wXCJcbiAgICAgICAgICAgIHhtbG5zOnhzaT1cImh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlXCJcbiAgICAgICAgICAgIHhzaTpzY2hlbWFMb2NhdGlvbj1cImh0dHA6Ly9tYXZlbi5hcGFjaGUub3JnL1NFVFRJTkdTLzEuMC4wXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGh0dHA6Ly9tYXZlbi5hcGFjaGUub3JnL3hzZC9zZXR0aW5ncy0xLjAuMC54c2RcIj5cbiAgICA8c2VydmVycz5cbiAgICAgIDxzZXJ2ZXI+XG4gICAgICAgIDxpZD5jb2RlYXJ0aWZhY3Q8L2lkPlxuICAgICAgICA8dXNlcm5hbWU+YXdzPC91c2VybmFtZT5cbiAgICAgICAgPHBhc3N3b3JkPiR7bG9naW4uYXV0aFRva2VufTwvcGFzc3dvcmQ+XG4gICAgICA8L3NlcnZlcj5cbiAgICA8L3NlcnZlcnM+XG4gICAgPHByb2ZpbGVzPlxuICAgICAgPHByb2ZpbGU+XG4gICAgICAgIDxpZD5kZWZhdWx0PC9pZD5cbiAgICAgICAgPHJlcG9zaXRvcmllcz5cbiAgICAgICAgICA8cmVwb3NpdG9yeT5cbiAgICAgICAgICAgIDxpZD5jb2RlYXJ0aWZhY3Q8L2lkPlxuICAgICAgICAgICAgPHVybD4ke2xvZ2luLm1hdmVuRW5kcG9pbnR9PC91cmw+XG4gICAgICAgICAgPC9yZXBvc2l0b3J5PlxuICAgICAgICA8L3JlcG9zaXRvcmllcz5cbiAgICAgIDwvcHJvZmlsZT5cbiAgICA8L3Byb2ZpbGVzPlxuICAgIDxhY3RpdmVQcm9maWxlcz5cbiAgICAgIDxhY3RpdmVQcm9maWxlPmRlZmF1bHQ8L2FjdGl2ZVByb2ZpbGU+XG4gICAgPC9hY3RpdmVQcm9maWxlcz5cbiAgPC9zZXR0aW5ncz5gKTtcbn1cbiJdfQ==