dcdx 1.3.0-next.36 → 1.3.0-next.37

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.
@@ -5,12 +5,13 @@ import { glob } from 'glob';
5
5
  import { join, resolve, dirname } from 'path';
6
6
  import { cwd } from 'process';
7
7
  import { input, confirm, password, select } from '@inquirer/prompts';
8
- import { existsSync, readFileSync, createReadStream, rmSync, writeFileSync, mkdirSync, createWriteStream, realpathSync } from 'fs';
9
- import axios from 'axios';
8
+ import { existsSync, readFileSync, createReadStream, mkdirSync, createWriteStream, rmSync, writeFileSync, realpathSync } from 'fs';
10
9
  import { SingleBar, Presets } from 'cli-progress';
10
+ import axios from 'axios';
11
+ import FormData from 'form-data';
11
12
  import { parse } from 'content-disposition';
12
13
  import { homedir } from 'os';
13
- import FormData from 'form-data';
14
+ import { finished } from 'stream/promises';
14
15
  import simpleGit from 'simple-git';
15
16
  import { spawn, execSync } from 'child_process';
16
17
  import inquirer from 'inquirer';
@@ -171,6 +172,28 @@ const registerLicense = async (appKey, license, baseUrl, username, password, ver
171
172
  return true;
172
173
  };
173
174
 
175
+ const downloadApp = async (addonKey) => {
176
+ const tmpDir = join(homedir(), '.dcdx', 'tmp');
177
+ mkdirSync(tmpDir, { recursive: true });
178
+ let downloadUrl = `https://marketplace.atlassian.com/download/plugins/${addonKey}`;
179
+ const { data: listing } = await axios.get(`https://marketplace.atlassian.com/rest/2/addons/${addonKey}?hosting=datacenter&withVersion=true`).catch(() => ({ data: null }));
180
+ if (listing) {
181
+ downloadUrl = listing._embedded?.version?._embedded?.artifact?._links?.binary?.href || downloadUrl;
182
+ }
183
+ const response = await axios({
184
+ method: 'get',
185
+ url: downloadUrl,
186
+ responseType: 'stream'
187
+ });
188
+ const disposition = parse(response.headers['content-disposition']);
189
+ const filename = disposition?.parameters?.filename || addonKey;
190
+ const tmpFile = join(tmpDir, filename);
191
+ const writer = createWriteStream(tmpFile);
192
+ response.data.pipe(writer);
193
+ await finished(writer);
194
+ return tmpFile;
195
+ };
196
+
174
197
  const getAptDictory = async (cwd$1, mustUseDefaultConfiguration, force) => {
175
198
  // Translate common relative paths to absolute paths
176
199
  let result = cwd$1 ?
@@ -420,27 +443,6 @@ const round = (value, step = 1.0) => {
420
443
  const inv = 1.0 / step;
421
444
  return Math.floor(value * inv) / inv;
422
445
  };
423
- const download = async (addonKey) => {
424
- const tmpDir = join(homedir(), '.dcdx', 'tmp');
425
- let tmpFile = join(tmpDir, addonKey);
426
- mkdirSync(tmpDir, { recursive: true });
427
- let downloadUrl = `https://marketplace.atlassian.com/download/plugins/${addonKey}`;
428
- const { data: listing } = await axios.get(`https://marketplace.atlassian.com/rest/2/addons/${addonKey}?hosting=datacenter&withVersion=true`).catch(() => ({ data: null }));
429
- if (listing) {
430
- downloadUrl = listing._embedded?.version?._embedded?.artifact?._links?.binary?.href || downloadUrl;
431
- }
432
- await axios({
433
- method: 'get',
434
- url: downloadUrl,
435
- responseType: 'stream'
436
- }).then(response => {
437
- const disposition = parse(response.headers['content-disposition']);
438
- const filename = disposition?.parameters?.filename || addonKey;
439
- tmpFile = filename;
440
- response.data.pipe(createWriteStream(tmpFile));
441
- }).catch(() => null);
442
- return tmpFile;
443
- };
444
446
  const installApp = async (options) => {
445
447
  // Set default value for username/password
446
448
  const username = options.username || 'admin';
@@ -454,7 +456,7 @@ const installApp = async (options) => {
454
456
  // Get the app license
455
457
  const appLicense = await getAppLicense(options.license, options.force);
456
458
  // Download the file from MPAC
457
- const file = await download(options.appKey);
459
+ const file = await downloadApp(options.appKey);
458
460
  let count = 0;
459
461
  let timerId = null;
460
462
  let isInstalledSuccesfully = false;
@@ -585,7 +587,7 @@ const installApp = async (options) => {
585
587
  progressBar.start(180, 0);
586
588
  const timerId = setInterval(() => progressBar.increment(), 1000);
587
589
  // Download the file from MPAC
588
- const file = await download(addonKey);
590
+ const file = await downloadApp(addonKey);
589
591
  // Upload it into the cluster using the UPM REST API
590
592
  const isInstalled = await uploadToUPM(options.baseUrl, file, adminUsername, adminPassword, false);
591
593
  if (!isInstalled) {
@@ -10199,4 +10201,4 @@ process.on('SIGINT', () => {
10199
10201
  console.log(`Received term signal, trying to stop gracefully 💪`);
10200
10202
  gracefulExit(1);
10201
10203
  });
10202
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"install.js","sources":["../../dist/src/helpers/licences.js","../../dist/src/helpers/capitalize.js","../../dist/src/apt/messages.js","../../dist/src/apt/helpers/getAppLicense.js","../../dist/src/helpers/upm.js","../../dist/src/apt/helpers/getAptDirectory.js","../../dist/src/apt/helpers/getAWSCredentials.js","../../dist/src/apt/helpers/getEnvironmentName.js","../../dist/src/apt/helpers/getProduct.js","../../dist/src/apt/helpers/dcapt.js","../../dist/src/apt/helpers/persistsAWSCredentials.js","../../dist/src/apt/helpers/waitForUserInput.js","../../dist/src/apt/helpers/restartCluster.js","../../dist/src/apt/helpers/installApp.js","../../dist/src/helpers/ActionHandler.js","../../dist/src/types/Database.js","../../dist/src/types/Application.js","../../dist/src/helpers/amps.js","../../dist/src/helpers/isRecursiveBuild.js","../../dist/src/helpers/showRecursiveBuildWarning.js","../../dist/src/helpers/CustomBuilder.js","../../dist/src/helpers/docker.js","../../dist/src/helpers/Installer.js","../../dist/src/helpers/FileWatcher.js","../../dist/src/helpers/toAbsolutePath.js","../../dist/src/helpers/getVersions.js","../../dist/src/commands/install.js"],"sourcesContent":["export const timebomb = {\n    'jira': 'AAACBA0ODAoPeNp9kl1v2jAUhu/zK460OyQHSLuVIkUaTbwNVBKUhEnbugsTDuA2sSPbgbFfPxOC1i+4yEXO5+vnPR+yGiGSW/CuoXc7vBoMvT4ENAOv5/WctUIUG1lVqNx7nqPQSJfccCl8GmU0mSXjlDpRXS5Qxau5RqV90ncCKQzLTcRK9Eu944Ip/cQ/M1MwrTkTbi5LZ1arfMM0hsyg7/X6A9LvE89z2j3ZvsJmQBBPpzQJxqP7U4r+qbjaN32zG+/baR2dMl6c35ei2qIah/4dvaHkOvzpkU/x5IZ8vbodOI9cMbdSclnnxj38EC1XZscUunYy36JvVI3OxGZmbZXdzwIU5lVJWi90rnjVQGoi70B873GNhPOQO51OFGfkS5yQWRKH8yAbxxGZp9Qm/EChpbGExR7MBqGdAlTkcokK7MMeMTfwa2NM9TDsdtfSfQGnWxw7CB47frsQShDSwJJro/iiNmgncw1GQl5rI0trtetY4sKgYCJ/Y4qVFSR0lNGQ3P04aDxrTKvWOjMXT0LuxCU33txaSiPffuRjr3fsO/mC6og/VmsmuGYN0Ij93TFYcVXunQaaDb4+wJbFd7vg0OI5If53NENtoK2AlVQwGScjSFt5lrjdWymu8WEIgSwtppyzAsLgxRk8P5hG9PMA3bKiPspdsULjJRwX7ukf5/NX7TAtAhUAhQSHz9DgycOX7wcwERMJb3TLGb4CFGkB/xUWSRK3BZLrPF9Rn6ZmrUqJX02oc',\n    'confluence': 'AAACzg0ODAoPeNp9VO9v2jAQ/Z6/wtK+IYWGsEKHFGmQmJau/GgIm9iYJhMOYprYke1A4a+fSchGKtqPPvvevXv3zp/6gqLHLEb2HbKsTvNzp9lC98MA2ZbdNKYgdiAGntPDQ2z688HcdH/aM7P5o2kZTzQEJiE4pDAiCTgBngaD0b0RCr5f1S9uHfcUWXSQBzuIeQrCCDlb10mo6A4cJTLQSVlIlzFUggpI8ickMbAVEbI+ypIliPG6R5Il5z4kXEF3A0xJp1Gywa8pFQePKHAmDdt6+A9cJVQEK5yWmhMV8HGZLRWkwrF8PZMgpGPfGh7IUNBUUc6cAKRCcVEYrblAaZxtKEOrsqj8V/US85zxXd+fUGwD70ickRwyf7ARACziqUYo+8Irmt/jUYD9iT+YYmNIKFPACAuvyHIaQEUSHYgz0G8rorgC8rp5qvaEZVp3pt0u8sve3TiTCsSIr0A6llGr1VwfdwPsmb25PjjbVwq2EcZcm6nS6DKX+I3iT1yP/Cy42TBe4FAK0WhZVtu6azYbZeZlB0U2wrpnkQoqq40Uyst67RqB9zU8k64olYeqKnGmNCzWiseOUoKwhLLoK1ExkZISVg95cr3ZN/YqdueSYW649/mdrfJAZOQM3b3b96DRuhVk3261kkFvexwe41UQtJN12u5Gz6GcPT7Pn71H70t69CPcbx/a9rcj3rDuwlk4xprKCA5VN+oJjsaB2R/75sQfezM3GIxH5myKT6PN/QErtDwgFQE6E9VDCLUZtN8F30Ko0K9IqXTRubnZ8HpFlZtzAyYUGb/ryOOIcYVWVCpBl5kCjUwlUhyF2mY80WaoXxdzEhOWe2YsNoRRWWxMt6xX/hH6P5uxF8b3rLJIlz1LpQW95pQPvqfLq0kmwohIeLs2l9PMzfQ48LvvWTbfMY1AXDg9KJDLCV2C9HUMH+CaJfOfudi/v0kIGVswLAIUEMQ9X77gqGBdfH0HIzBaV8NadPUCFBn+RiUA4D+IqVQpTTouLVY66aCGX02121',\n    'bitbucket': 'AAABmg0ODAoPeNp9Ul1v0zAUfc+vsMRbJadJtjGpUiS2JJRONOlaB4SAB9e9W0xTu7JvCv33eImDOoR4vefe4/PhN59hR5bckPiWRNezKJ5FCZkvGUmiJA4yrZALLPkBUrHXotEnu5eBRW6b8KMUoCyw8xH6BVZs2KKce3TJpUJQXAkofh2lOeccIV1dfRhJC7fRXrJuwJzALPL0/qF+pI9XGaPz+uGGspvbkdRx8Awcr0nRdOCnlXnmSlqOUqv0DltureTKg6vOiIZb6J9PoviaRm9pHHs0M9Cf/Rv1Dv/SP5lMyorR99WartZVXmdsUZW03hQOSHtCF+n2TLAB4hlIoYTegSFHo3+AQPK1QTx+m02nzzrko+JQ6MO0HS4oDBffQ5JrojSSnbRo5LZDcMzSEtREdBb1AYwNRzsXff0JgjCwLjG/4mB5giE+JzhbF3esyOn9lxf1F2145a6OWu2V/qmC/2dVdoctmOqptk5PGid+XJx42w3NPPHWQuD9fXJbL8PktfLhU2Av+N2rYMY6uUEFpncY/AYCgfFAMCwCFHzkBlkGH/vRdTeeBSfUMzUDb4W2AhQyM893WPg2Q8oQAYRdBSyKeVUdog==X02jr',\n    'bamboo': 'AAAB3w0ODAoPeNp9Ultr2zAYffevEOwtoMR10qYLGJbYWsno7GA7g90eZPlrotWWjCSnzX79FF8IYWkfDPJ3Oedwzvch2zdoWSvkzpF7v5jdLrwpCkiaIc/1POeRMxAasmMNEa3Az2xnHT04gQJquBQhNeB77vQGuzPs3jk5rXIpx5QZfgDfqAaGUtRUOaj4adX+PkpGy+UOhNE+vnGG5laDags9L3mtuToOJF5Pkja5ZorXJwEXHG+pJQdaNvS/cYtLAysBVFfu19ehvxXPQr4IJwV1AGULKzIneBb+8PBd/GWOH6Yf751No9ieaujleYMHKYl8++Fb13VGo1EUZ/hznOBNEofbIFvHEd6mxDb81kQoUH5EZg+op0dEMFmAQrWSf4AZ9HNvTP1rMZnsrLGmpFpzKsZMVpOy28DQbfweo1AiIQ0quDaK540Bi8w1MhKxRhtZWXvHTghn+zLQBvU46Ela1rLZcYEKOEApazvvfKXceiSoYG/kcTXhTUlFG+XVbgKVNHA+gF7BN8t3UuU5sdpRwXUXGnmlVV0CCmRVU3G8Evf5MKUw9vqIFV36tX7moNjfo7CPTxfenZIJErLMSIhX309pvDd8SUgK3smKMpJsknVKBtr26t4D+gd3AC5qMCwCFHOaTWfFvLCLJPft3qktVo3FafmZAhRojb9IAxj8KEqPDQy0stos394SQQ==X02mq'\n};\nexport const app3hour = 'AAABCA0ODAoPeNpdj01PwkAURffzKyZxZ1IyUzARkllQ24gRaQMtGnaP8VEmtjPNfFT59yJVFyzfubkn796Ux0Bz6SmbUM5nbDzj97RISxozHpMUnbSq88poUaLztFEStUN6MJZ2TaiVpu/YY2M6tI6sQrtHmx8qd74EZ+TBIvyUU/AoYs7jiE0jzknWQxMuifA2IBlUbnQ7AulVjwN9AaU9atASs69O2dNFU4wXJLc1aOUGw9w34JwCTTZoe7RPqUgep2X0Vm0n0fNut4gSxl/Jcnj9nFb6Q5tP/Ueu3L+0PHW4ghZFmm2zZV5k6/95CbR7Y9bYGo/zGrV3Ir4jRbDyCA6vt34DO8p3SDAsAhQnJjLD5k9Fr3uaIzkXKf83o5vDdQIUe4XequNCC3D+9ht9ZYhNZFKmnhc=X02dh';\n","export const capitalize = (value) => value.charAt(0).toUpperCase() + value.slice(1);\n","import { join } from 'path';\nimport { capitalize } from '../helpers/capitalize';\nimport { getRunForStage } from './helpers/getRunForStage';\nconst toNumber = (stage) => {\n    switch (stage) {\n        case 'one-node': return 'third';\n        case 'two-node': return 'fourth';\n        case 'four-node': return 'fifth';\n    }\n};\nexport const emptyLine = () => console.log('​');\nexport const generic = {\n    header: `\n                          ____      _          _____         _                                  \n                          |    \\\\ ___| |_ ___   |     |___ ___| |_ ___ ___                        \n                          |  |  | .'|  _| .'|  |   --| -_|   |  _| -_|  _|                       \n                          |____/|__,|_| |__,|  |_____|___|_|_|_| |___|_|                         \n                                                                                                \n                                                                                                \n  _____            _____         ___                                  _____         _ _   _ _   \n  |  _  |___ ___   |  _  |___ ___|  _|___ ___ _____ ___ ___ ___ ___   |_   _|___ ___| | |_|_| |_ \n  |     | . | . |  |   __| -_|  _|  _| . |  _|     | .'|   |  _| -_|    | | | . | . | | '_| |  _|\n  |__|__|  _|  _|  |__|  |___|_| |_| |___|_| |_|_|_|__,|_|_|___|___|    |_| |___|___|_|_,_|_|_|  \n        |_| |_|                                                                                        \n\n  Welcome to the automated Data Center App Performance Toolkit (DCAPT).\n  This will guide you through all the steps to produce the required performance testing results\n  for your (annual) Data Center approval.\n`\n};\nexport const init = {\n    header: (product) => `\n  We will now follow all the steps as documented in the Data Center App Performance Toolkit User Guide For ${capitalize(product)}.\n  Please consult the documentation prior to starting the test run:\n\n  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-${product}/\n\n  Once you start the test run we will provision the environment on AWS. \n  IMPORTANT: This can incur costs.\n  \n  You can stop this process at any time by exiting this program. Be sure to run the following command to reset \n  the AWS environment and prevent unexpected costs.\n\n  $ dcdx apt teardown\n\n  You can also resume/restart every part of the test run using one of the following commands:\n\n  $ dcdx apt init --product ${product}\n  $ dcdx apt provision --product ${product}\n  $ dcdx apt run1 --product ${product}\n  $ dcdx apt run2 --product ${product}\n  $ dcdx apt run3 --product ${product}\n  $ dcdx apt run4 --product ${product}\n  $ dcdx apt run5 --product ${product}\n\n  We will continue with the following steps:\n${product === 'jira' ? `\n  1.  Provision the environment\n  2.  Performance regression without app installed (run 1)\n  3.  Lucene Index timing test with app installed (run 2)\n  4.  Performance regression with app installed (run 2)\n  5.  Scalability testing on one-node cluster with app-specific actions (run 3)\n  6.  Scalability testing on two-node cluster with app-specific actions (run 4)\n  7.  Scalability testing on four-node cluster with app-specific actions (run 5)\n  8.  Generate reports\n  9.  Teardown of environment\n  10. Security Scanner for Data Center apps\n` : `\n  1. Provision the environment\n  2. Performance regression without app installed (run 1)\n  3. Performance regression with app installed (run 2)\n  4. Scalability testing on one-node cluster with app-specific actions (run 3)\n  5. Scalability testing on two-node cluster with app-specific actions (run 4)\n  6. Scalability testing on four-node cluster with app-specific actions (run 5)\n  7. Generate reports\n  8. Teardown of environment\n  9. Security Scanner for Data Center apps\n`}`,\n};\nexport const provisioning = {\n    header: `\n  _____ _____ _____ _____ _____ _____ _____ _____ _____ _____ _____ _____ \n  |  _  | __  |     |  |  |     |   __|     |     |   | |     |   | |   __|\n  |   __|    -|  |  |  |  |-   -|__   |-   -|  |  | | | |-   -| | | |  |  |\n  |__|  |__|__|_____|\\\\___/|_____|_____|_____|_____|_|___|_____|_|___|_____|\n                                                                               \n  We will now start provisioning AWS using the Atlassian Data Center App Performace Toolkit (DCAPT) Terraform configuration.\n\n  In order to do this, we need the following information:\n\n  1. The location of the Data Center App Performance Toolkit on your disk\n  2. AWS credentials\n  3. Product license\n`,\n    askForAWSCredentials: (product) => `\n  In order to provision the ${capitalize(product)} cluster, we need Administrator credentials for AWS.\n  Please refer to the DCAPT documentation to find more information on how to create the AWS access keys:\n\n  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-${product}/#setup-${product}-data-center-development-environment-on-k8s-\n`,\n    askForEnvironment: `\n  When provisioning the cluster, we need a unique environment name.\n  This will allow you to create multiple clusters (i.e. for different host products) and to identify which cluster to use during testing & teardown.\n`,\n    askForHostLicense: `\n  The host product requires a valid license.\n\n  By default we use the 72h developer license provided by Atlassian. If you need a more extensive license,\n  you can generate an evaluation license from my.atlassian.com or ask Atlassian Marketplace Developer Support for a test license.\n`,\n    askForAppLicense: `\nThe app requires a valid license.\n\nBy default we use the 3 hour timebomb license provided by Atlassian. If you need a more extensive license,\nyou can generate an evaluation license from my.atlassian.com or ask Atlassian Marketplace Developer Support for a test license.\n`,\n    ready: `\n  We have now gathered all the information required to provision the cluster.\n\n  !! IMPORTANT !!\n  \n  We will be writing the configuration to disk. This will overwrite existing configuration.\n  Please note that provisioning the environment will incur AWS usage costs.\n`,\n    awsCredentialsPersisted: '✔ AWS credentials written to app/util/k8s/aws_envs',\n    terraformConfigurationPersisted: `✔ Terraform configuration written to app/util/k8s/dcapt.tfvars`\n};\nexport const Run1 = {\n    header: () => `\n  _____ _____ _____    ___   \n  | __  |  |  |   | |  |_  |  \n  |    -|  |  | | | |   _| |_ \n  |__|__|_____|_|___|  |_____|\n\n  We will now start the performance regression testing without app installed (run 1)\n  This will produce the performance baseline results.\n\n  It is important that you are running the baseline test on the default configuration.\n  You can get the default configuration from the APT sources:\n\n  https://github.com/atlassian/dc-app-performance-toolkit\n`,\n    readyForProvisioning: `\nIn order to be able to start the performance regression test, we will now configure the DC cluster on AWS\n\n!! IMPORTANT !!\n\nWe will be writing the configuration to disk. This will overwrite existing configuration.\nPlease note that provisioning the environment will incur AWS usage costs.\n`,\n    startTest: `\nWe will now start the Performance Regression test\n`,\n    success: `\n✔ Finished the performance regression testing without app installed (run 1)\n`,\n    failure: (stage, cwd, product, environment, resultsBaseDir, results) => {\n        let output = `\n  ✔ Finished the performance ${stage} testing without app installed (run 1)\n\n  Unfortunately, the test run was finished unsuccesful. \n  Please review the test results and adjust the configuration if required.\n`;\n        Object.entries(results).forEach(([key, value]) => output += `  ${key}: ${value}\\n`);\n        output += `\n  Full report can be found here:\n  ${join(resultsBaseDir, 'results_summary.log')}\n\n  You can restart the performance testing using the following command:\n  \n  $ dcdx apt run1 --product ${product} --cwd ${cwd} --environment ${environment}\n`;\n        return output;\n    }\n};\nexport const Run2 = {\n    header: (product) => `\n  _____ _____ _____    ___ \n  | __  |  |  |   | |  |_  |\n  |    -|  |  | | | |  |  _|\n  |__|__|_____|_|___|  |___|\n                          \n  We will now start the performance regression testing with app installed (run 2)\n  This will allow the generation of a performance regression report.\n${product === 'jira' ? `\n  In addition, a Lucene Index Timing Test is also part of the performance regression tests.` : ''}\n  The second run consists of the following steps:\n${product === 'jira' ? `\n  1. Install the app into the cluster\n  2. Benchmark the re-index time with your app installed\n  3. Performance results generation with the app installed\n` : `\n  1. Install the app into the cluster\n  2. Performance results generation with the app installed\n`}\n  It is important that you are running the performance regression test on the default configuration.\n  You can get the default configuration from the APT sources:\n\n  https://github.com/atlassian/dc-app-performance-toolkit\n`,\n    readyForProvisioning: `\nIn order to be able to start the performance regression test, we will now configure the DC cluster on AWS\n\n!! IMPORTANT !!\n\nWe will be writing the configuration to disk. This will overwrite existing configuration.\nPlease note that provisioning the environment will incur AWS usage costs.\n`,\n    startTest: `\n  We will now start the Performance Regression test\n`,\n    success: `\n✔ Finished the performance regression testing with app installed (run 2)\n`,\n    failure: (stage, cwd, product, environment, resultsBaseDir, results) => {\n        let output = `\n  ✔ Finished the performance ${stage} testing with app installed (run 2)\n\n  Unfortunately, the test run was finished unsuccesful. \n  Please review the test results and adjust the configuration if required.\n`;\n        Object.entries(results).forEach(([key, value]) => output += `  ${key}: ${value}\\n`);\n        output += `\n  Full report can be found here:\n  ${join(resultsBaseDir, 'results_summary.log')}\n\n  You can restart the performance testing using the following command:\n  \n  $ dcdx apt run2 --product ${product} --cwd ${cwd} --environment ${environment}\n`;\n        return output;\n    }\n};\nexport const LuceneTimingTest = {\n    header: (_product, stage) => `\n  __    _____ _____ _____ _____ _____ \n  |  |  |  |  |     |   __|   | |   __|\n  |  |__|  |  |   --|   __| | | |   __|\n  |_____|_____|_____|_____|_|___|_____|\n  _____ _____ _____ _____ _____ _____ \n  |_   _|     |     |     |   | |   __|\n    | | |-   -| | | |-   -| | | |  |  |\n    |_| |_____|_|_|_|_____|_|___|_____|\n      _____ _____ _____ _____         \n      |_   _|   __|   __|_   _|        \n        | | |   __|__   | | |          \n        |_| |_____|_____| |_|          \n                                                               \n  We will now start the Lucene Index Timing test with app installed\n  This is part of the Performance ${stage} test (run 2)\n\n  After the re-index is completed a screenshot is created which is part of the required test results\n\n  It is important that you are running the Lucene index timing test on the default configuration.\n  You can get the default configuration from the APT sources:\n\n  https://github.com/atlassian/dc-app-performance-toolkit\n`,\n    readyForProvisioning: `\nIn order to be able to start the Lucene index timing test, we will now configure the DC cluster on AWS\n\n!! IMPORTANT !!\n\nWe will be writing the configuration to disk. This will overwrite existing configuration.\nPlease note that provisioning the environment will incur AWS usage costs.\n`,\n    startTest: `\n  We are ready to start the Lucene Index timing test\n  Once the test is finished, a browser window is opened to capture the test results.\n\n  !! IMPORTANT !!\n\n  This may take ~50 minutes. Please do not terminate the program\n  Do not close the browser window, or else the test will fail\n`,\n    success: `\n✔ Finished the Lucene Index Timinig test with app installed (run 2)\n`,\n    failure: (_stage, cwd, product, environment) => `\n  ✔ Finished the Lucene Index Timing test with app installed (run 2)\n\n  Unfortunately, the test run was finished unsuccesful. \n  Please review the test results and adjust the configuration if required.\n\n  You can restart the Lucene Index Timing test using the following command:\n  \n  $ dcdx apt reindex --product ${product} --cwd ${cwd} --environment ${environment}\n`\n};\nexport const PerformanceReportMessages = {\n    header: `\n  _____ _____ _____ _____ _____ _____ _____ _____ _____ _____ _____   \n  |  _  |   __| __  |   __|     | __  |     |  _  |   | |     |   __|  \n  |   __|   __|    -|   __|  |  |    -| | | |     | | | |   --|   __|  \n  |__|  |_____|__|__|__|  |_____|__|__|_|_|_|__|__|_|___|_____|_____|  \n                                                                      \n      _____ _____ _____ _____ _____ _____ _____ _____ _____ _____     \n      | __  |   __|   __| __  |   __|   __|   __|     |     |   | |    \n      |    -|   __|  |  |    -|   __|__   |__   |-   -|  |  | | | |    \n      |__|__|_____|_____|__|__|_____|_____|_____|_____|_____|_|___|    \n                                                                      \n              _____ _____ _____ _____ _____ _____                     \n              | __  |   __|  _  |     | __  |_   _|                    \n              |    -|   __|   __|  |  |    -| | |                      \n              |__|__|_____|__|  |_____|__|__| |_|                      \n\n\n  We are going to generate the performance regression report\n  The report constists of a CSV and PNG file that are required for \n  the (annual) Data Center app review\n`\n};\nexport const ScalabilityTestMessages = {\n    header: (product, stage) => `\n${stage === 'one-node' ? `\n  _____ _____ _____    ___ \n  | __  |  |  |   | |  |_  |\n  |    -|  |  | | | |  |_  |\n  |__|__|_____|_|___|  |___|\n` : stage === 'two-node' ? `\n  _____ _____ _____    ___ \n  | __  |  |  |   | |  | | |\n  |    -|  |  | | | |  |_  |\n  |__|__|_____|_|___|    |_|                          \n` : `\n  _____ _____ _____    ___ \n  | __  |  |  |   | |  |  _|\n  |    -|  |  | | | |  |_  |\n  |__|__|_____|_|___|  |___|                          \n`}\n\n  We will now start the scalability benchmark for ${stage} ${capitalize(product)} DC cluster with app-specific actions: (run ${getRunForStage(stage)})\n\n  The ${toNumber(stage)} run consists of the following steps:\n  1. Adjust the environment to a ${stage} cluster\n  1. Install the app into the cluster\n  3. Scalability benchmark testing with the app installed\n\n  It is important that you are running the scalability benchmark test on a DCAPT version that has app-specific actions\n  More information on developing app-specific actions can be found here:\n\n${product === 'jira' ?\n        `  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-jira/#3--develop-and-test-app-specific-action-locally`\n        : product === 'confluence' ?\n            `  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-confluence/#3--develop-and-test-app-specific-actions-locally`\n            : product === 'bamboo' ?\n                '  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-bamboo/#2--app-specific-actions-development'\n                // product === 'bitbucket'\n                : '  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-bitbucket/#3--develop-and-test-app-specific-action-locally'}\n`,\n    readyForProvisioning: `\n  In order to be able to start the scalability benchmark, we will now reconfigure the DC cluster on AWS\n\n  !! IMPORTANT !!\n  \n  We will be writing the configuration to disk. This will overwrite existing configuration.\n  Please note that provisioning the environment will incur AWS usage costs.\n`,\n    startTest: `\n  Ready to start the scalability benchmark test with app-specific actions\n`,\n    success: `\n✔ Finished the scalability benchmark test with app-specific actions\n`,\n    failure: (stage, cwd, product, environment, resultsBaseDir, results) => {\n        let output = `\n✔ Finished the scalability benchmark test with app-specific actions\n\n  Unfortunately, the test run was finished unsuccesful. \n  Please review the test results and adjust the configuration if required.\n`;\n        Object.entries(results).forEach(([key, value]) => output += `  ${key}: ${value}\\n`);\n        output += `\n  Full report can be found here:\n  ${join(resultsBaseDir, 'results_summary.log')}\n\n  You can restart the scalability benchmark test using the following command:\n  \n  $ dcdx apt run${getRunForStage(stage)} --product ${product} --cwd ${cwd} --environment ${environment}\n`;\n        return output;\n    }\n};\nexport const ScalabilityReportMessages = {\n    header: `\n  _____ _____ _____ __    _____ _____ _____ __    _____ _____ __ __ \n  |   __|     |  _  |  |  |  _  | __  |     |  |  |     |_   _|  |  |\n  |__   |   --|     |  |__|     | __ -|-   -|  |__|-   -| | | |_   _|\n  |_____|_____|__|__|_____|__|__|_____|_____|_____|_____| |_|   |_|  \n                                                                    \n              _____ _____ _____ _____ _____ _____                   \n              | __  |   __|  _  |     | __  |_   _|                  \n              |    -|   __|   __|  |  |    -| | |                    \n              |__|__|_____|__|  |_____|__|__| |_|                    \n`\n};\nexport const Restart = {\n    header: `                                           \n  _____ _____ _____ _____ _____ _____ _____ \n  | __  |   __|   __|_   _|  _  | __  |_   _|\n  |    -|   __|__   | | | |     |    -| | |  \n  |__|__|_____|_____| |_| |__|__|__|__| |_|  \n                                           \n  We will now restart the cluster used in the Data Center Application Performance testing.\n`\n};\nexport const Teardown = {\n    header: `\n  _____ _____ _____ _____ ____  _____ _ _ _ _____ \n  |_   _|   __|  _  | __  |    \\\\|     | | | |   | |\n    | | |   __|     |    -|  |  |  |  | | | | | | |\n    |_| |_____|__|__|__|__|____/|_____|_____|_|___|\n\n  We will now terminate the cluster used in the Data Center Application Performance testing.\n`\n};\n","import { input } from '@inquirer/prompts';\nimport { existsSync, readFileSync } from 'fs';\nimport { app3hour } from '../../helpers/licences';\nimport { provisioning } from '../messages';\nexport const getAppLicense = (license, force) => {\n    const appLicense = license && existsSync(license) ? readFileSync(license, 'utf8') : license;\n    if (force) {\n        return appLicense || app3hour;\n    }\n    console.log(provisioning.askForAppLicense);\n    return input({\n        message: `License`,\n        default: appLicense || app3hour,\n        required: true\n    });\n};\n","import axios from 'axios';\nimport FormData from 'form-data';\nimport { createReadStream } from 'fs';\nexport const uploadToUPM = async (baseUrl, path, username, password, verbose = true) => {\n    const credentials = username && password ? Buffer.from(`${username}:${password}`).toString('base64') : null;\n    const response = await axios.get(`${baseUrl}/rest/plugins/1.0/?os_authType=basic`, credentials ? {\n        headers: { 'Authorization': `Basic ${credentials}` }\n    } : undefined).catch(err => {\n        verbose && console.log('Failed to upload plugin archive file to UPM, unable to retrieve token', err);\n        return null;\n    });\n    if (response) {\n        const token = response.headers['upm-token'];\n        if (token) {\n            const formData = new FormData();\n            formData.append('plugin', createReadStream(path));\n            return axios.post(`${baseUrl}/rest/plugins/1.0/?token=${token}`, formData, { headers: {\n                    ...formData.getHeaders(),\n                    ...credentials ? { 'Authorization': `Basic ${credentials}` } : {}\n                } }).then(() => {\n                verbose && console.log('Finished uploading plugin archive to UPM');\n                return true;\n            });\n        }\n        else {\n            verbose && console.log('Failed to upload plugin archive file to UPM, unable to retrieve token from headers:', JSON.stringify(response.headers, null, 2));\n            return false;\n        }\n    }\n    return false;\n};\nexport const waitForPluginToBeEnabled = async (appKey, baseUrl, username, password, verbose = true) => {\n    const credentials = username && password ? Buffer.from(`${username}:${password}`).toString('base64') : null;\n    verbose && console.log('Waiting for plugin to become enabled');\n    let isEnabled = false;\n    let count = 0;\n    while (!isEnabled && count < 120) {\n        await new Promise(resolve => setTimeout(resolve, 1000));\n        verbose && console.log(`Waiting for plugin to become enabled... ${count}s`);\n        const { data } = await axios.get(`${baseUrl}/rest/plugins/1.0/${appKey}-key`, credentials ? {\n            headers: { 'Authorization': `Basic ${credentials}` }\n        } : undefined).catch(() => ({ data: { enabled: false } }));\n        isEnabled = data?.enabled;\n        count++;\n    }\n    return isEnabled;\n};\nexport const registerLicense = async (appKey, license, baseUrl, username, password, verbose = true) => {\n    const credentials = username && password ? Buffer.from(`${username}:${password}`).toString('base64') : null;\n    const { data } = await axios.get(`${baseUrl}/rest/plugins/1.0/${appKey}-key/license`, {\n        headers: {\n            'X-Atlassian-Token': 'no-check',\n            'Content-Type': 'application/vnd.atl.plugins+json',\n            ...credentials ? { 'Authorization': `Basic ${credentials}` } : {}\n        }\n    }).catch(() => ({ data: {} }));\n    const { rawLicense } = data;\n    if (!rawLicense || rawLicense !== license) {\n        return axios.put(`${baseUrl}/rest/plugins/1.0/${appKey}-key/license`, `{ \"rawLicense\": \"${license}\" }`, {\n            headers: {\n                'X-Atlassian-Token': 'no-check',\n                'Content-Type': 'application/vnd.atl.plugins+json',\n                ...credentials ? { 'Authorization': `Basic ${credentials}` } : {}\n            }\n        }).then(() => {\n            verbose && console.log('Finished uploading license to UPM');\n            return true;\n        }).catch(err => {\n            verbose && console.log('Failed to upload license to UPM', err);\n            return false;\n        });\n    }\n    return true;\n};\n","import { confirm, input } from '@inquirer/prompts';\nimport { existsSync, rmSync } from 'fs';\nimport { homedir } from 'os';\nimport { join, resolve } from 'path';\nimport { cwd as pwd } from 'process';\nimport simpleGit from 'simple-git';\nimport { emptyLine } from '../messages';\nexport const getAptDictory = async (cwd, mustUseDefaultConfiguration, force) => {\n    // Translate common relative paths to absolute paths\n    let result = cwd ?\n        cwd.startsWith('~/')\n            ? cwd.replace('~/', homedir())\n            : cwd.startsWith('./')\n                ? cwd.replace('./', pwd() + '/')\n                : cwd === '.'\n                    ? pwd()\n                    : cwd\n        : pwd();\n    // If we are in interactive mode, we should ask questions first\n    if (!force) {\n        // Check if we are currently in the APT directory\n        const isCurrentDirectoryEligable = existsSync(join(result, 'app/util/k8s/dcapt.tfvars'));\n        // If this is the APT directory, we will be using the current directory...\n        let useCurrentDirectory = isCurrentDirectoryEligable;\n        // ...unless told otherwise\n        if (isCurrentDirectoryEligable) {\n            console.log(`  We've found the App Performance Toolkit in the specified directory:\n  ${result}\n`);\n            useCurrentDirectory = await confirm({\n                message: `Do you wish to use this directory?`,\n                default: true,\n            });\n        }\n        // If we are not going to use the current directory, ask for the alternative\n        let directory = result;\n        if (!useCurrentDirectory) {\n            directory = await input({\n                message: 'Please specify the location where the App Peformance Toolkit is located',\n                default: result,\n                required: true\n            });\n        }\n        // Translate common relative paths to absolute paths\n        directory = directory.startsWith('~/')\n            ? directory.replace('~/', homedir() + '/')\n            : directory.startsWith('./')\n                ? directory.replace('./', pwd() + '/')\n                : directory === '.'\n                    ? pwd()\n                    : directory;\n        // Check if the provided alternative is a DCAPT directory\n        const isDirectoryEligable = existsSync(resolve(join(directory, 'app/util/k8s/dcapt.tfvars')));\n        if (!isDirectoryEligable) {\n            // If it is not a DCAPT directory, ask if we need to clone it from Github\n            const mustCloneAPT = await confirm({\n                message: `The directory either doesn't exist, or it doesn't contain the App Peformance Toolkit. Do you want to clone DCAPT from source?`,\n            });\n            // If we must clone it from Github, we should clone it from Github\n            if (mustCloneAPT) {\n                await simpleGit().clone('https://github.com/atlassian/dc-app-performance-toolkit.git', directory);\n            }\n        }\n        // Check if this needs to be a default configuration (for performance regression testing)\n        if (mustUseDefaultConfiguration) {\n            // Ask nicely...\n            const isDefaultConfiguration = await confirm({\n                message: 'Please confirm that the chosen directory is using the default configuration for DCAPT (master branch)'\n            });\n            // ...but also, No is not an option\n            if (!isDefaultConfiguration) {\n                throw new Error('It is required to use the default configuration from master to continue');\n            }\n        }\n        else {\n            // Ask nicely...\n            const isAppSpecificConfiguration = await confirm({\n                message: 'Please confirm that the chosen directory has a DCAPT installation with app-specific actions'\n            });\n            // ...but also, No is not an option\n            if (!isAppSpecificConfiguration) {\n                throw new Error('It is required to have app-specific actions in order to continue');\n            }\n        }\n        // Set the result to the provided directory\n        result = directory;\n        // If we are in non-interactive mode and we need to use the default configuration, we will clone it from Github\n    }\n    else if (mustUseDefaultConfiguration) {\n        // If the provided directory does not exists we can use it\n        // Otherwise use a temporary directory to ensure a fresh non-persistent checkout\n        result = !existsSync(result)\n            ? result\n            : join(homedir(), '.dcdx', 'dcapt');\n        // Inform the user of the chosen directory\n        console.log('  Installing default configuration of DCAPT from source (non-interactive mode)');\n        console.log(`  ${result}`);\n        // Make sure the directory is empty\n        rmSync(result, { force: true, recursive: true });\n        // Retrieve DCAPT from github\n        await simpleGit().clone('https://github.com/atlassian/dc-app-performance-toolkit.git', result);\n        console.log('✔ Finished installing default configuration of DCAPT from source (non-interactive mode)');\n        // If we are in non-interactive mode and we need to use app specific configuration, make sure that it exists\n    }\n    else {\n        // Check if we are currently in the APT directory\n        const isCurrentDirectoryEligable = existsSync(join(result, 'app/util/k8s/dcapt.tfvars'));\n        // If this is not a DCAPT directory, we cannot continue\n        if (!isCurrentDirectoryEligable) {\n            throw new Error(`Could not find App Performance Toolkit in the current directory ${result}`);\n        }\n        console.log('  Using DCAPT from current directory (non-interactive mode)');\n        console.log(`  ${result}`);\n        emptyLine();\n    }\n    // This should not occur, because either we have established the current directory has DCAPT\n    // or we have cloned it into a (new) directory. This is merely a check for if the latter failed.\n    if (!existsSync(join(result, 'app/util/k8s/dcapt.tfvars'))) {\n        throw new Error(`Could not find the App Performance Toolkit in the provided directory ${result}`);\n    }\n    // Some additional checks to ensure that we are in a valid DCAPT directory\n    const hasEnvFile = existsSync(join(result, 'app/util/k8s/aws_envs'));\n    const hasSnapshotJSON = existsSync(join(result, 'app/util/k8s/dcapt-snapshots.json'));\n    const hasTerraformVariables = existsSync(join(result, 'app/util/k8s/dcapt.tfvars'));\n    if (!hasEnvFile) {\n        throw new Error(`Could not find the required 'aws_ens' file. Expected to find it in ${join(result, 'app/util/k8s/aws_envs')}`);\n    }\n    else if (!hasSnapshotJSON) {\n        throw new Error(`Could not find the required 'dcapt-snapshots.json' file. Expected to find it in ${join(result, 'app/util/k8s/dcapt-snapshots.json')}`);\n    }\n    else if (!hasTerraformVariables) {\n        throw new Error(`Could not find the required 'dcapt.tfvars' file. Expected to find it in ${join(result, 'app/util/k8s/dcapt.tfvars')}`);\n    }\n    return result;\n};\n","import { password } from '@inquirer/prompts';\nimport { provisioning } from '../messages';\nexport const getAWSCredentials = async (product, force) => {\n    // Try getting the AWS credentials from environment variables\n    const { AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY } = process.env;\n    // If they exists as environment variables, return them immediately\n    if (AWS_ACCESS_KEY_ID && AWS_SECRET_ACCESS_KEY) {\n        return [AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY];\n    }\n    // If we are not in non-interactive mode, we should ask for them\n    if (!force) {\n        // Show a message asking nicely\n        console.log(provisioning.askForAWSCredentials(product));\n        const aws_access_key_id = await password({\n            message: `AWS Access Key ID`,\n            validate: (input) => typeof input === 'string' && input.length > 0\n        });\n        const aws_secret_access_key = await password({\n            message: `AWS Secret Access Key`,\n            validate: (input) => typeof input === 'string' && input.length > 0\n        });\n        return [aws_access_key_id, aws_secret_access_key];\n    }\n    // If we are in non-interactive mode, and the credentials have not been found, we should throw an error\n    throw new Error(`The AWS credentials could not be found. Please provide the 'AWS_ACCESS_KEY_ID' and 'AWS_SECRET_ACCESS_KEY' environment variables`);\n};\n","import { input } from '@inquirer/prompts';\nimport { provisioning } from '../messages';\nexport const getEnvironmentName = async () => {\n    console.log(provisioning.askForEnvironment);\n    return input({\n        message: `Environment name`,\n        required: true\n    });\n};\n","import { select } from '@inquirer/prompts';\nexport const getProduct = async () => {\n    return select({\n        message: `Please choose the product for which you wish to run DCAPT`,\n        choices: [\n            { name: 'Jira', value: 'jira' },\n            { name: 'Confluence', value: 'confluence' },\n            { name: 'Bamboo', value: 'bamboo' },\n            { name: 'Bitbucket', value: 'bitbucket' }\n        ]\n    });\n};\n","import { spawn } from 'child_process';\nimport { writeFileSync } from 'fs';\nimport { join, resolve } from 'path';\nexport const install = async (cwd) => {\n    console.log(`\n  Start provisioning AWS using the Atlassian Data Center App Performace Toolkit (DCAPT) Terraform configuration\n  Using DCAPT configuration from ${cwd}\n`);\n    const baseDir = join(cwd, 'app/util/k8s');\n    writeFileSync(join(baseDir, 'outputs.json'), '# terraform output', 'utf-8');\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--env-file', 'aws_envs',\n            '-v', `${baseDir}/dcapt.tfvars:/data-center-terraform/conf.tfvars`,\n            '-v', `${baseDir}/dcapt-snapshots.json:/data-center-terraform/dcapt-snapshots.json`,\n            '-v', `${baseDir}/logs:/data-center-terraform/logs`,\n            '-v', `${baseDir}/outputs.json:/data-center-terraform/outputs.json`,\n            'atlassianlabs/terraform:latest',\n            './install.sh', '-c', 'conf.tfvars'\n        ], { cwd: baseDir, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n    console.log(`\n✔ Finished provisioning AWS using the Atlassian Data Center App Performace Toolkit (DCAPT) Terraform configuration\n  Cluster details can be found in ${baseDir}/outputs.json\n`);\n};\nexport const runTest = async (cwd, environment, product) => {\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--env-file', './app/util/k8s/aws_envs',\n            '-e', `REGION=us-east-2`,\n            '-e', `ENVIRONMENT_NAME=${environment}`,\n            '-v', `${cwd}:/data-center-terraform/dc-app-performance-toolkit`,\n            '-v', `${cwd}/app/util/k8s/bzt_on_pod.sh:/data-center-terraform/bzt_on_pod.sh`,\n            'atlassianlabs/terraform:latest',\n            'bash', 'bzt_on_pod.sh', `${product}.yml`\n        ], { cwd, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n};\nexport const regressionReport = async (cwd, run1Dir, run2Dir) => {\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--workdir', '//dc-app-performance-toolkit/app/reports_generation',\n            '--entrypoint', 'python',\n            '-v', `${cwd}:/dc-app-performance-toolkit`,\n            '-v', `${run1Dir}:/results/run1`,\n            '-v', `${run2Dir}:/results/run2`,\n            'atlassian/dcapt',\n            'csv_chart_generator.py', 'performance_profile.yml'\n        ], { cwd, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n    console.log(`✔ Finished generating the Performance Regression Report`);\n};\nexport const scalabilityReport = async (cwd, resultsDir1, resultsDir2, resultsDir3) => {\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--workdir', '//dc-app-performance-toolkit/app/reports_generation',\n            '--entrypoint', 'python',\n            '-v', `${cwd}:/dc-app-performance-toolkit`,\n            '-v', `${resultsDir1}:/dcapt/scale_results_1`,\n            '-v', `${resultsDir2}:/dcapt/scale_results_2`,\n            '-v', `${resultsDir3}:/dcapt/scale_results_3`,\n            'atlassian/dcapt',\n            'csv_chart_generator.py', 'scale_profile.yml'\n        ], { cwd, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n    console.log(`✔ Finished generating the Scalability Benchmark Report`);\n};\nexport const restart = async (cwd, environment, product) => {\n    writeFileSync(join(cwd, './app/util/k8s/delete_pod.sh'), `\naws eks update-kubeconfig --name atlas-$ENVIRONMENT_NAME-cluster --region $REGION\nkubectl rollout restart sts/$PRODUCT -n atlassian\nkubectl rollout status sts $PRODUCT -n atlassian`, 'utf8');\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--env-file', './app/util/k8s/aws_envs',\n            '-e', `REGION=us-east-2`,\n            '-e', `ENVIRONMENT_NAME=${environment}`,\n            '-e', `PRODUCT=${product}`,\n            '-v', `${cwd}:/data-center-terraform/dc-app-performance-toolkit`,\n            '-v', `${cwd}/app/util/k8s/delete_pod.sh:/data-center-terraform/delete_pod.sh`,\n            'atlassianlabs/terraform:latest',\n            'bash', 'delete_pod.sh'\n        ], { cwd, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n};\nexport const terminate = async (cwd, environment) => {\n    const baseDir = resolve(join(cwd, 'app/util/k8s'));\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            `--pull=always`,\n            '--env-file', 'aws_envs',\n            '--workdir', '//data-center-terraform',\n            '--entrypoint', 'python',\n            '-v', `${baseDir}/terminate_cluster.py:/data-center-terraform/terminate_cluster.py`,\n            'atlassian/dcapt',\n            'terminate_cluster.py', '--cluster_name', `atlas-${environment}-cluster`, '--aws_region', 'us-east-2'\n        ], { cwd: join(cwd, 'app/util/k8s'), stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n    console.log(`✔ Finished terminating the DC cluster on AWS using the Atlassian Data Center App Performace Toolkit (DCAPT) Terraform configuration`);\n};\n","import { writeFileSync } from 'fs';\nimport { join } from 'path';\nimport { provisioning } from '../messages';\nexport const persistAWSCredentials = (cwd, aws_access_key_id, aws_secret_access_key) => {\n    writeFileSync(join(cwd, 'app/util/k8s/aws_envs'), `\n# aws_envs file should contain AWS variables needed for authorization (without quotes)\nAWS_ACCESS_KEY_ID=${aws_access_key_id}\nAWS_SECRET_ACCESS_KEY=${aws_secret_access_key}\n`.trim(), 'utf-8');\n    console.log(provisioning.awsCredentialsPersisted);\n};\n","import inquirer from 'inquirer';\nimport PressToContinuePrompt from 'inquirer-press-to-continue';\ninquirer.registerPrompt('press-to-continue', PressToContinuePrompt);\nexport const waitForUserInput = async (message, force) => {\n    const { key } = await inquirer.prompt({\n        name: 'key',\n        type: 'press-to-continue',\n        anyKey: true,\n        pressToContinueMessage: message,\n        when: !force\n    });\n    return key || { value: undefined };\n};\n","import { emptyLine, Restart } from '../messages';\nimport { restart } from './dcapt';\nimport { getAptDictory } from './getAptDirectory';\nimport { getAWSCredentials } from './getAWSCredentials';\nimport { persistAWSCredentials } from './persistsAWSCredentials';\nimport { waitForUserInput } from './waitForUserInput';\nexport const restartCluster = async (options) => {\n    // Show nice little welcome message\n    console.log(Restart.header);\n    // Ask for the proper directory of APT\n    const directory = await getAptDictory(options.cwd, true, options.force);\n    // Ask for the AWS credentials\n    const [aws_access_key_id, aws_secret_access_key] = await getAWSCredentials(options.product, options.force);\n    // Write AWS credentials to disk\n    persistAWSCredentials(directory, aws_access_key_id, aws_secret_access_key);\n    // Ask the user if they are ready to say goodbye to their cluster\n    await waitForUserInput('Press a key to continue...', options.force);\n    emptyLine();\n    // Terminate it!\n    await restart(directory, options.environment, options.product);\n    // Ask the user to quit the program\n    await waitForUserInput('Press a key to exit...', options.force);\n};\n","import { confirm, input, password as passwordPrompt, select } from '@inquirer/prompts';\nimport axios from 'axios';\nimport { Presets, SingleBar } from 'cli-progress';\nimport { parse } from 'content-disposition';\nimport { createWriteStream, mkdirSync, rmSync } from 'fs';\nimport { homedir } from 'os';\nimport { join } from 'path';\nimport { registerLicense, uploadToUPM, waitForPluginToBeEnabled } from '../../helpers/upm';\nimport { getAppLicense } from './getAppLicense';\nimport { getAptDictory } from './getAptDirectory';\nimport { getAWSCredentials } from './getAWSCredentials';\nimport { getEnvironmentName } from './getEnvironmentName';\nimport { getProduct } from './getProduct';\nimport { restartCluster } from './restartCluster';\nconst progressBar = new SingleBar({\n    format: '  [{bar}] {percentage}% | ETA: {eta_formatted}m',\n    formatTime: (value) => {\n        const total = progressBar.getTotal() / 60;\n        const timePassed = round((progressBar.getTotal() - value) / 60, 0.5);\n        return timePassed === total ? `${total}` : `${total - timePassed}`;\n    },\n    hideCursor: true\n}, Presets.legacy);\nconst round = (value, step = 1.0) => {\n    const inv = 1.0 / step;\n    return Math.floor(value * inv) / inv;\n};\nconst download = async (addonKey) => {\n    const tmpDir = join(homedir(), '.dcdx', 'tmp');\n    let tmpFile = join(tmpDir, addonKey);\n    mkdirSync(tmpDir, { recursive: true });\n    let downloadUrl = `https://marketplace.atlassian.com/download/plugins/${addonKey}`;\n    const { data: listing } = await axios.get(`https://marketplace.atlassian.com/rest/2/addons/${addonKey}?hosting=datacenter&withVersion=true`).catch(() => ({ data: null }));\n    if (listing) {\n        downloadUrl = listing._embedded?.version?._embedded?.artifact?._links?.binary?.href || downloadUrl;\n    }\n    await axios({\n        method: 'get',\n        url: downloadUrl,\n        responseType: 'stream'\n    }).then(response => {\n        const disposition = parse(response.headers['content-disposition']);\n        const filename = disposition?.parameters?.filename || addonKey;\n        tmpFile = filename;\n        response.data.pipe(createWriteStream(tmpFile));\n    }).catch(() => null);\n    return tmpFile;\n};\nexport const installApp = async (options) => {\n    // Set default value for username/password\n    const username = options.username || 'admin';\n    const password = options.password || 'admin';\n    // If we are in non-interactive mode, we will download it from MPAC\n    if (options.force) {\n        // In order to do so, we need an appkey. If this is not provided, throw a hissy fit\n        if (!options.appKey) {\n            throw new Error('Failed to automatically install app into cluster, `appKey` was not provided');\n        }\n        // Get the app license\n        const appLicense = await getAppLicense(options.license, options.force);\n        // Download the file from MPAC\n        const file = await download(options.appKey);\n        let count = 0;\n        let timerId = null;\n        let isInstalledSuccesfully = false;\n        while (!isInstalledSuccesfully && count <= 4) {\n            try {\n                if (count === 0) {\n                    console.log(`\n  Installing the app (${options.appKey}) into the cluster using the Universal Plugin Manager REST API`);\n                }\n                else {\n                    console.log(`\n  Retrying installation of the app (${options.appKey}) into the cluster using the Universal Plugin Manager REST API (attempt ${count + 1})`);\n                }\n                // Show a progress bar\n                progressBar.start(180, 0);\n                timerId = setInterval(() => progressBar.increment(), 1000);\n                // Upload it into the cluster using the UPM REST API\n                const isInstalled = await uploadToUPM(options.baseUrl, file, username, password, false);\n                if (!isInstalled) {\n                    throw new Error('Failed to install app into the cluster using the Universal Plugin Manager REST API');\n                }\n                // Check if we need to restart the application container\n                if (options.restartAfterInstall) {\n                    // For restarts, the product option is required\n                    if (!options.product) {\n                        console.log('  Failed to restart application, required option `product` is missing');\n                        // For restarts, the environment option is required\n                    }\n                    else if (!options.environment) {\n                        console.log('  Failed to restart application, required option `product` is missing');\n                        // Ok, good to go!\n                    }\n                    else {\n                        // Oh right, we also need DCAPT in order to be able to restart the cluster\n                        const cwd = await getAptDictory(options.cwd, false, options.force);\n                        // We are now going to restart the cluster and hope for the best\n                        console.log(`  Restarting ${options.product} to ensure app installation`);\n                        await restartCluster({\n                            cwd,\n                            product: options.product,\n                            environment: options.environment,\n                            aws_access_key_id: options.aws_access_key_id,\n                            aws_secret_access_key: options.aws_secret_access_key,\n                            force: options.force\n                        });\n                    }\n                }\n                // Wait for the plugin to be enabled\n                const isEnabled = await waitForPluginToBeEnabled(options.appKey, options.baseUrl, username, password, false);\n                if (!isEnabled) {\n                    throw new Error('The app could not be enabled on the cluster, please refer to the application log files for more information');\n                }\n                // Register the license (use the 3 hour timebomb in non-interactive mode)\n                const isLicensed = await registerLicense(options.appKey, appLicense, options.baseUrl, username, password, false);\n                if (!isLicensed) {\n                    throw new Error('The license could not be applied for the app on the cluster, please refer to the application log files for more information');\n                }\n                isInstalledSuccesfully = isInstalled && isEnabled && isLicensed;\n            }\n            catch (err) {\n                if (count <= 3) {\n                    // Wait a minute (cooldown period) before retrying\n                    await new Promise(resolve => setTimeout(resolve, 1000));\n                }\n                else {\n                    throw err;\n                }\n            }\n            finally {\n                count++;\n                // Stop the progress bar\n                progressBar.stop();\n                if (timerId) {\n                    clearInterval(timerId);\n                }\n            }\n        }\n        // Remove the temporary file\n        rmSync(file, { force: true });\n        // Tell them we succeeded\n        console.log(`✔ Finished installing the app (${options.appKey})`);\n        // If we're in interactive mode, let's be nice\n    }\n    else {\n        // Tell the user they have options\n        console.log(`\n  It is now required to install the app into the Jira cluster.\n  We can install it from the Atlassian Marketplace or you can install it manually.\n`);\n        // Ask them if they prefer automation or tedious manual tasks\n        const method = await select({\n            message: `How do you want to install the app?`,\n            default: 'mpac',\n            choices: [\n                { name: 'Marketplace', value: 'mpac' },\n                { name: 'Manual', value: 'manual' }\n            ]\n        });\n        // If they chose automation, let's automate!\n        if (method === 'mpac') {\n            // Ask them nicely for the app key\n            const addonKey = await input({\n                message: 'Please provide the key of the app to be installed',\n                default: options.appKey,\n                required: true\n            });\n            // Ask them nicely for the app license to be used\n            const appLicense = await getAppLicense(options.license, options.force);\n            // Ask them nicely for the username\n            const adminUsername = await input({\n                message: 'Please provide the username of a system administrator',\n                default: username,\n                required: true\n            });\n            // Ask them nicely for the username\n            const adminPassword = await passwordPrompt({\n                message: 'Please provide the username of a system administrator',\n                validate: item => typeof item === 'string' && item.length > 0\n            });\n            // Ask them nicely if we need to restart the application\n            const restartAfterInstall = await confirm({\n                message: 'Restart the host application after installation?',\n            });\n            // Tell them we are starting\n            console.log(`\n  Installing the app (${addonKey}) into the cluster using the Universal Plugin Manager REST API`);\n            // Show a progress bar\n            progressBar.start(180, 0);\n            const timerId = setInterval(() => progressBar.increment(), 1000);\n            // Download the file from MPAC\n            const file = await download(addonKey);\n            // Upload it into the cluster using the UPM REST API\n            const isInstalled = await uploadToUPM(options.baseUrl, file, adminUsername, adminPassword, false);\n            if (!isInstalled) {\n                throw new Error('Failed to install app into the cluster using the Universal Plugin Manager REST API');\n            }\n            // Check if we need to restart the application container\n            if (restartAfterInstall) {\n                // Ask them nicely for the host product\n                const product = options.product || await getProduct();\n                // Ask for the AWS credentials\n                const [aws_access_key_id, aws_secret_access_key] = await getAWSCredentials(product, options.force);\n                // Ask for the environment name\n                const environment = options.environment || await getEnvironmentName();\n                // Oh right, we also need DCAPT in order to be able to restart the cluster\n                const cwd = await getAptDictory(options.cwd, false, options.force);\n                // We are now going to restart the cluster and hope for the best\n                console.log(`  Restarting ${options.product} to ensure app installation`);\n                await restartCluster({\n                    cwd,\n                    product: product,\n                    environment: environment,\n                    aws_access_key_id: aws_access_key_id,\n                    aws_secret_access_key: aws_secret_access_key,\n                    force: options.force\n                });\n            }\n            // Wait for the plugin to be enabled\n            const isEnabled = await waitForPluginToBeEnabled(addonKey, options.baseUrl, adminUsername, adminPassword, false);\n            if (!isEnabled) {\n                throw new Error('The app could not be enabled on the cluster, please refer to the application log files for more information');\n            }\n            // Register the provided license\n            const isLicensed = await registerLicense(addonKey, appLicense, options.baseUrl, adminUsername, adminPassword, false);\n            if (!isLicensed) {\n                throw new Error('The license could not be applied for the app on the cluster, please refer to the application log files for more information');\n            }\n            // Remove the temporary file\n            rmSync(file, { force: true });\n            // Stop the progress bar\n            progressBar.stop();\n            clearInterval(timerId);\n            // Tell them we succeeded\n            console.log(`✔ Finished installing the app (${addonKey})`);\n            // They chose violence\n        }\n        else {\n            // Rub it in their face\n            console.log(`\n  You can now install the app manually into the cluster.\n  Please go to the following page:\n    \n  ${options.baseUrl}/plugins/servlet/upm?source=side_nav_manage_addons\n`);\n            // Make them grovel\n            const isInstalledManually = await confirm({\n                message: `Please confirm that you have installed the app manually`\n            });\n            // If the app ain't installed, we ain't doing nothin'. So we better throw a hissy fit\n            if (!isInstalledManually) {\n                throw new Error('It is required to install the app to run the second performance regression test');\n            }\n        }\n    }\n};\n","import { asyncExitHook, gracefulExit } from 'exit-hook';\nimport { z } from 'zod';\nexport const ActionHandler = async (program, { action, errorHandler }, options) => {\n    const ops = options || program.opts();\n    await new Promise((_, reject) => {\n        let errorMessage = '';\n        asyncExitHook(async (code) => {\n            try {\n                if (code !== 0) {\n                    await errorHandler(ops).catch(() => null);\n                }\n                if (errorMessage) {\n                    throw new Error(errorMessage.trim());\n                }\n                else {\n                    // We are rejecting the promise to avoid the\n                    // \"Calling process.exit\" log message from exit-hook\n                    reject(null);\n                }\n            }\n            catch (err) {\n                const message = err instanceof Error ? err.message : err;\n                reject(message);\n            }\n        }, {\n            wait: 60 * 1 * 1000\n        });\n        action(ops).then(() => {\n            gracefulExit(0);\n        }).catch(err => {\n            if (err instanceof z.ZodError) {\n                err.issues.forEach(issue => {\n                    errorMessage += `Unable to parse option ${issue.path.join(',')}: ${issue.message}\\n`;\n                });\n            }\n            else if (err instanceof Error || typeof err === 'string') {\n                errorMessage = err.toString();\n            }\n            gracefulExit(1);\n        });\n    }).catch(message => {\n        if (message !== null) {\n            program.error(message);\n            // If there is no error message,\n            // we can assume a clean exit\n        }\n        else {\n            process.exit(0);\n        }\n    });\n};\n","import { z } from 'zod';\nimport versions from '../../assets/versions.json';\nexport const SupportedDatabaseEngines = z.enum([\n    'postgresql',\n    'mysql',\n    'mssql'\n]);\nexport const SupportedMSSQLEditions = z.enum([\n    'Developer',\n    'Express',\n    'Standard',\n    'Enterprise',\n    'EnterpriseCore'\n]);\nexport const DatabaseOptions = z.object({\n    name: SupportedDatabaseEngines,\n    port: z.number().or(z.string().transform(Number).refine(item => !isNaN(item))),\n    database: z.string().default('dcdx'),\n    username: z.string().default('dcdx'),\n    password: z.string().default('dcdx'),\n    clean: z.boolean().default(false),\n    prune: z.boolean().default(false),\n    verbose: z.boolean().default(false),\n    driver: z.string()\n});\nexport const PostgreSQLOptions = DatabaseOptions.extend({\n    name: SupportedDatabaseEngines.refine(item => item === SupportedDatabaseEngines.Values.postgresql).default(SupportedDatabaseEngines.Values.postgresql),\n    tag: z.string().refine(item => versions[SupportedDatabaseEngines.Values.postgresql].includes(item)).default('latest'),\n    port: z.number().or(z.string().transform(Number).refine(item => !isNaN(item))).default(5432),\n    driver: z.string().refine(item => item === 'org.postgresql.Driver').default('org.postgresql.Driver')\n});\nexport const MySQLOptions = DatabaseOptions.extend({\n    name: SupportedDatabaseEngines.refine(item => item === SupportedDatabaseEngines.Values.mysql).default(SupportedDatabaseEngines.Values.mysql),\n    tag: z.string().refine(item => versions[SupportedDatabaseEngines.Values.mysql].includes(item)).default('latest'),\n    port: z.number().or(z.string().transform(Number).refine(item => !isNaN(item))).default(3306),\n    driver: z.string().refine(item => item === 'com.mysql.jdbc.Driver').default('com.mysql.jdbc.Driver')\n});\nexport const MSSQLOptions = DatabaseOptions.extend({\n    name: SupportedDatabaseEngines.refine(item => item === SupportedDatabaseEngines.Values.mssql).default(SupportedDatabaseEngines.Values.mssql),\n    tag: z.string().refine(item => versions[SupportedDatabaseEngines.Values.mssql].includes(item)).default('latest'),\n    edition: SupportedMSSQLEditions.default('Developer'),\n    port: z.number().or(z.string().transform(Number).refine(item => !isNaN(item))).default(1433),\n    username: z.string().refine(item => item === 'sa').default('sa'),\n    password: z.string().default('DataCenterDX!'),\n    driver: z.string().refine(item => item === 'com.microsoft.sqlserver.jdbc.SQLServerDriver').default('com.microsoft.sqlserver.jdbc.SQLServerDriver')\n});\n","import { z } from 'zod';\nimport { SupportedDatabaseEngines } from './Database';\nexport const SupportedApplications = z.enum([\n    'jira',\n    'confluence',\n    'bitbucket',\n    'bamboo'\n]);\nexport const ApplicationOptions = z.object({\n    name: SupportedApplications,\n    tag: z.string().default('latest'),\n    database: SupportedDatabaseEngines.default('postgresql'),\n    databaseTag: z.string().default('latest'),\n    port: z.string().transform(Number).refine(item => !isNaN(item)).default('80'),\n    contextPath: z.string(),\n    xms: z.string().default('1024m'),\n    xmx: z.string().default('1024m'),\n    watch: z.boolean().default(false),\n    ext: z.array(z.string()),\n    install: z.boolean(),\n    outputDirectory: z.string(),\n    activateProfiles: z.string(),\n    clean: z.boolean().default(false),\n    prune: z.boolean().default(false),\n    debug: z.boolean().default(true),\n    cwd: z.string()\n}).partial({\n    contextPath: true,\n    ext: true,\n    install: true,\n    outputDirectory: true,\n    activateProfiles: true,\n    cwd: true\n});\n","import { DOMParser, XMLSerializer } from '@xmldom/xmldom';\nimport { spawn } from 'child_process';\nimport { XMLParser } from 'fast-xml-parser';\nimport { existsSync, readFileSync } from 'fs';\nimport { join } from 'path';\nimport { cwd } from 'process';\nimport xpath from 'xpath';\nimport { SupportedApplications } from '../types/Application';\nexport class AMPS {\n    options;\n    maven = null;\n    // ------------------------------------------------------------------------------------------ Constructor\n    constructor(options = {\n        profiles: []\n    }) {\n        this.options = options;\n    }\n    // ------------------------------------------------------------------------------------------ Public Methods\n    stop() {\n        if (this.maven) {\n            const killed = this.maven.kill(0);\n            if (!killed) {\n                throw new Error('Failed to terminate existing Maven process');\n            }\n        }\n    }\n    async build(args) {\n        return new Promise((resolve, reject) => {\n            if (this.maven) {\n                const killed = this.maven.kill(0);\n                if (!killed) {\n                    reject(new Error('Failed to terminate existing Maven process'));\n                }\n            }\n            this.maven = spawn('mvn', ['package', ...args], { cwd: this.options?.cwd || cwd(), stdio: 'inherit' });\n            this.maven.on('exit', (code) => {\n                this.maven = null;\n                if (code === 0 || code === 130) {\n                    resolve();\n                }\n                else {\n                    reject(new Error(`Maven exited with code ${code}`));\n                }\n            });\n        });\n    }\n    isAtlassianPlugin = () => {\n        try {\n            const nodes = this.getNodes('//*[local-name()=\\'packaging\\']');\n            return nodes.some(item => item.textContent === 'atlassian-plugin');\n        }\n        catch (err) {\n            return false;\n        }\n    };\n    getApplicationVersion() {\n        const applications = this.getApplications();\n        if (applications.size === 1) {\n            const [, version] = Array.from(applications)[0];\n            return version;\n        }\n        else if (applications.size > 1) {\n            throw new Error('The Atlassian Plugin project contains multiple AMPS configuration, unable to decide which product to use 😰');\n        }\n        return undefined;\n    }\n    getApplication() {\n        const applications = this.getApplications();\n        if (applications.size === 1) {\n            const [name] = Array.from(applications)[0];\n            return name;\n        }\n        else if (applications.size > 1) {\n            throw new Error('The Atlassian Plugin project contains multiple AMPS configuration, unable to decide which product to use 😰');\n        }\n        return null;\n    }\n    getApplications() {\n        const result = new Map();\n        const nodes = this.getNodes('//*[local-name()=\\'groupId\\' and text()=\\'com.atlassian.maven.plugins\\']');\n        const nodesWithActiveProfile = nodes.filter(node => this.isActivatedProfile(node));\n        nodesWithActiveProfile.forEach(node => {\n            const parentNode = node.parentNode;\n            if (parentNode) {\n                const { plugin } = this.toObject(parentNode);\n                if ('amps-maven-plugin' === plugin?.artifactId) {\n                    const { configuration } = plugin || {};\n                    if (configuration?.products) {\n                        if (Array.isArray(configuration?.products)) {\n                            configuration.products.forEach((product) => {\n                                const supportedApplication = this.getSupportedApplication(product.id) || this.getSupportedApplication(product.instanceId);\n                                if (supportedApplication) {\n                                    const version = this.doPropertyReplacement(product.version);\n                                    if (version) {\n                                        result.set(supportedApplication, version);\n                                    }\n                                }\n                            });\n                        }\n                        else {\n                            const { product } = configuration?.products || {};\n                            if (product) {\n                                const supportedApplication = this.getSupportedApplication(product.id) || this.getSupportedApplication(product.instanceId);\n                                if (supportedApplication) {\n                                    const version = this.doPropertyReplacement(product.version);\n                                    if (version) {\n                                        result.set(supportedApplication, version);\n                                    }\n                                }\n                            }\n                        }\n                    }\n                }\n                else {\n                    const supportedApplication = this.getSupportedApplication(plugin?.artifactId);\n                    const version = this.getVersion(node);\n                    if (supportedApplication) {\n                        result.set(supportedApplication, version);\n                    }\n                }\n            }\n        });\n        return result;\n    }\n    // ------------------------------------------------------------------------------------------ Private Methods\n    getSupportedApplication(value) {\n        if (value?.includes(SupportedApplications.Values.jira)) {\n            return SupportedApplications.Values.jira;\n        }\n        else if (value?.includes(SupportedApplications.Values.confluence)) {\n            return SupportedApplications.Values.confluence;\n        }\n        else if (value?.includes(SupportedApplications.Values.bamboo)) {\n            return SupportedApplications.Values.bamboo;\n        }\n        else if (value?.includes(SupportedApplications.Values.bitbucket)) {\n            return SupportedApplications.Values.bitbucket;\n        }\n        return null;\n    }\n    getVersion(node) {\n        const parentNode = node.parentNode;\n        if (parentNode) {\n            const { plugin } = this.toObject(parentNode);\n            const { configuration } = plugin || {};\n            if (configuration?.productVersion) {\n                return this.doPropertyReplacement(plugin.configuration.productVersion);\n            }\n            else if (configuration?.products) {\n                const product = Array.isArray(configuration?.products) ? configuration?.products[0] : configuration.products.product;\n                if (product && product.version) {\n                    return this.doPropertyReplacement(product.version);\n                }\n            }\n        }\n        return undefined;\n    }\n    doPropertyReplacement(value) {\n        let result = value;\n        // If there is a profile, replace profile properties first as they take precedence\n        const profileProperties = this.getProperties();\n        Object.entries(profileProperties).forEach(([propertyKey, propertyValue]) => {\n            result = result.replaceAll(`$\\{${propertyKey}}`, propertyValue);\n        });\n        const properties = this.getProperties();\n        Object.entries(properties).forEach(([propertyKey, propertyValue]) => {\n            result = result.replaceAll(`$\\{${propertyKey}}`, propertyValue);\n        });\n        return result;\n    }\n    getProperties() {\n        const result = {};\n        const nodes = this.getNodes('//*[local-name()=\\'properties\\']');\n        const nodesWithActiveProfile = nodes.filter(node => this.isActivatedProfile(node));\n        nodesWithActiveProfile.forEach(node => {\n            const { properties } = this.toObject(node);\n            Object.entries(properties).forEach(([key, value]) => result[key] = value);\n        });\n        return result;\n    }\n    getNodes(expression, single) {\n        const pomFilePath = join(this.options?.cwd || cwd(), './pom.xml');\n        const hasPomFile = existsSync(pomFilePath);\n        if (hasPomFile) {\n            const xml = readFileSync(pomFilePath, 'utf8');\n            const doc = new DOMParser().parseFromString(xml, 'text/xml');\n            const nodes = single ? xpath.select(expression, doc, true) : xpath.select(expression, doc, false);\n            if (Array.isArray(nodes)) {\n                return nodes;\n            }\n            else if (single) {\n                return nodes;\n            }\n            else {\n                return [];\n            }\n        }\n        return [];\n    }\n    toObject(node) {\n        try {\n            const parser = new XMLParser();\n            return parser.parse(new XMLSerializer().serializeToString(node));\n        }\n        catch (err) {\n            return null;\n        }\n    }\n    findParentNodeByTagName(tagName, node) {\n        const { parentNode } = node;\n        if (parentNode) {\n            if (parentNode.nodeName.toLowerCase() === tagName.toLowerCase()) {\n                return parentNode;\n            }\n            return this.findParentNodeByTagName(tagName, parentNode);\n        }\n        return null;\n    }\n    isActivatedProfile(node) {\n        const profileParentNode = this.findParentNodeByTagName('profile', node);\n        const profileNode = profileParentNode ? this.toObject(profileParentNode) : null;\n        if (!profileNode) {\n            return true;\n        }\n        else if (profileNode && (profileNode.activeByDefault === 'true' || this.options.profiles.includes(profileNode.profile.id))) {\n            return true;\n        }\n        else {\n            return false;\n        }\n    }\n}\n","export const isRecursiveBuild = (lastBuildCompleted) => lastBuildCompleted > (new Date().getTime() - 5 * 1000);\n","export const showRecursiveBuildWarning = (outputDirectory) => {\n    console.log(`\n===============================================================================================================\nRecursive build trigger detected. The last build completed last than 5 seconds ago\nThis may indicate that the build changes files outside of the output directory\nAlternatively, Maven is using a different output directory than configured:\n'${outputDirectory}'\n\nPlease make sure to check your build process and/or specify a different output directory using the '-o' option\n===============================================================================================================`);\n};\n","import { execSync } from 'child_process';\nimport { cwd } from 'process';\nexport class CustomBuilder {\n    options;\n    proc = null;\n    // ------------------------------------------------------------------------------------------ Constructor\n    constructor(options) {\n        this.options = options;\n    }\n    // ------------------------------------------------------------------------------------------ Public Methods\n    stop() {\n        if (this.proc) {\n            const killed = this.proc.kill(0);\n            if (!killed) {\n                throw new Error('Failed to terminate existing build process');\n            }\n        }\n    }\n    async build() {\n        return new Promise((resolve, reject) => {\n            if (this.proc) {\n                const killed = this.proc.kill(0);\n                if (!killed) {\n                    reject(new Error('Failed to terminate existing build process'));\n                }\n            }\n            try {\n                execSync(this.options.cmd, { cwd: this.options?.cwd || cwd(), stdio: 'inherit' });\n                resolve();\n            }\n            catch (err) {\n                const { status } = err;\n                reject(new Error(`Build exited with code ${status}`));\n            }\n        });\n    }\n}\n","import { spawn } from 'child_process';\nimport Dockerode from 'dockerode';\nimport { cwd } from 'process';\nconst docker = new Dockerode();\nexport const getRunningContainerIds = async (application) => {\n    const containers = await docker.listContainers({ filters: {\n            status: ['running'],\n            label: [`com.docker.compose.service=${application}`]\n        } });\n    return containers.map(item => item.Id);\n};\nexport const copy = async (sourcePath, destinationPath) => {\n    return new Promise((resolve, reject) => {\n        const docker = spawn('docker', ['cp', sourcePath, destinationPath], { cwd: cwd(), stdio: 'inherit' });\n        docker.on('error', reject);\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n};\n","import { resolve as resolvePath } from 'path';\nimport { cwd } from 'process';\nimport * as Docker from './docker';\nimport { uploadToUPM } from './upm';\nexport const Installer = async (name, path, options) => {\n    const containerIds = await Docker.getRunningContainerIds(name);\n    if (!containerIds || containerIds.length <= 0) {\n        console.log(`There are no running instance of ${name}, unable to install plugin 🤔`);\n        return;\n    }\n    else if (containerIds.length > 1) {\n        console.log(`There are multple running instance of ${name}, unable to determine which one to use 🤔`);\n        return;\n    }\n    const containerId = containerIds[0];\n    if (containerId) {\n        if (options.obr) {\n            console.log(`Found updated plugin, uploading it to UPM on running instances of ${name}`);\n            const hostUrl = options.port ? `localhost:${options.port}` : `localhost`;\n            const baseUrl = options.username && options.password ? `http://${options.username}:${options.password}@${hostUrl}` : `http://${hostUrl}`;\n            await uploadToUPM(resolvePath(options.cwd || cwd(), path), baseUrl).catch(err => {\n                console.log('Failed to upload plugin archive file to UPM', err);\n            });\n        }\n        else {\n            console.log(`Found updated plugin, uploading it to QuickReload on running instances of ${name}`);\n            await Docker.copy(resolvePath(options.cwd || cwd(), path), `${containerId}:/opt/quickreload/`)\n                .then(() => console.log('Finished uploading plugin archive to QuickReload'))\n                .catch(err => console.log('Failed to upload plugin archive file to QuickReload', err));\n        }\n    }\n};\n","import { watch } from 'chokidar';\nimport { cwd } from 'process';\nimport { isRecursiveBuild } from '../helpers/isRecursiveBuild';\nimport { showRecursiveBuildWarning } from '../helpers/showRecursiveBuildWarning';\nimport { AMPS } from './amps';\nimport { CustomBuilder } from './CustomBuilder';\nimport { Installer } from './Installer';\nexport const FileWatcher = (name, options, mavenOpts, installOnly = false) => {\n    let lastBuildCompleted = new Date().getTime();\n    const outputDirectory = options.outputDirectory || 'target';\n    const patterns = options.ext || ['**/*'];\n    console.log(`Watching filesystem for changes to source files (${patterns.join(', ')})`);\n    const amps = new AMPS({\n        cwd: options.cwd,\n        profiles: options.activateProfiles?.split(',') || []\n    });\n    const deliverableExtension = options.obr ? '.obr' : '.jar';\n    return watch(patterns, {\n        cwd: options.cwd || cwd(),\n        usePolling: true,\n        interval: 2 * 1000,\n        binaryInterval: 2 * 1000,\n        awaitWriteFinish: true,\n        persistent: true,\n        atomic: true\n    }).on('change', async (path) => {\n        if (options.install && path.startsWith(outputDirectory) && path.toLowerCase().endsWith(deliverableExtension)) {\n            await Installer(name, path, options);\n        }\n        else if (!path.startsWith(outputDirectory) && !installOnly) {\n            if (isRecursiveBuild(lastBuildCompleted)) {\n                showRecursiveBuildWarning(outputDirectory);\n            }\n            else {\n                console.log('Detected file change, rebuilding Atlasian Data Center plugin');\n                if (!options.exec) {\n                    await amps.build(mavenOpts).then(() => {\n                        console.log(`Finished building Atlassian Data Center plugin for ${name}... 💪`);\n                    }).catch(() => {\n                        console.log(`Failed to build Atlassian Data Center plugin for ${name}... 😰`);\n                    });\n                }\n                else {\n                    const builder = new CustomBuilder({ cmd: options.exec, cwd: options.cwd || cwd() });\n                    await builder.build().then(() => {\n                        console.log(`Finished building Atlassian Data Center plugin for ${name}... 💪`);\n                    }).catch(() => {\n                        console.log(`Failed to build Atlassian Data Center plugin for ${name}... 😰`);\n                    });\n                }\n                lastBuildCompleted = new Date().getTime();\n            }\n        }\n    });\n};\n","import { realpathSync } from 'fs';\nimport { dirname, join } from 'path';\nexport const toAbsolutePath = (relativePath) => {\n    const [, filePath] = process.argv;\n    const executableFileDir = dirname(realpathSync(filePath));\n    const basedir = executableFileDir.substring(0, executableFileDir.indexOf('dcdx') + 4);\n    return join(basedir, relativePath.replaceAll('../', ''));\n};\n","import { readFileSync } from 'fs';\nimport { toAbsolutePath } from './toAbsolutePath';\nexport const getVersions = () => {\n    const content = readFileSync(toAbsolutePath('../../assets/versions.json'), 'utf-8');\n    const versions = JSON.parse(content);\n    return versions;\n};\n","#!/usr/bin/env node\nimport { Command as Commander, InvalidOptionArgumentError, Option } from 'commander';\nimport { gracefulExit } from 'exit-hook';\nimport { glob } from 'glob';\nimport { resolve } from 'path';\nimport { cwd } from 'process';\nimport { getAppLicense } from '../apt/helpers/getAppLicense';\nimport { installApp } from '../apt/helpers/installApp';\nimport { ActionHandler } from '../helpers/ActionHandler';\nimport { AMPS } from '../helpers/amps';\nimport { FileWatcher } from '../helpers/FileWatcher';\nimport { getVersions } from '../helpers/getVersions';\nimport { Installer } from '../helpers/Installer';\nconst program = new Commander();\nconst versions = getVersions();\nconst Command = () => {\n    let quickReload = null;\n    return {\n        action: async (options) => {\n            const amps = new AMPS({\n                cwd: options.cwd,\n                profiles: options.activateProfiles?.split(',') || []\n            });\n            if (options.mpac) {\n                if (!options.baseUrl) {\n                    throw new InvalidOptionArgumentError('Missing argument \"--baseUrl\", required for installing from the Atlassian Marketplace');\n                }\n                else if (!options.appKey) {\n                    throw new InvalidOptionArgumentError('Missing argument \"--appKey\", required for installing from the Atlassian Marketplace');\n                }\n                await installApp({\n                    baseUrl: options.baseUrl,\n                    appKey: options.appKey,\n                    license: await getAppLicense(options.license, true),\n                    username: options.username,\n                    password: options.password,\n                    restartAfterInstall: false,\n                    force: true\n                });\n            }\n            else {\n                if (!amps.isAtlassianPlugin()) {\n                    throw new Error('Unable to find an Atlassian Plugin project in the current directory 🤔');\n                }\n                const name = amps.getApplication();\n                if (!name) {\n                    throw new Error('The Atlassian Plugin project does not contain an AMPS configuration, unable to detect product 😰');\n                }\n                const version = amps.getApplicationVersion();\n                if (!version) {\n                    throw new Error('Failed to determine version from AMPS and no product version provided (--tag)');\n                }\n                else if (!versions[name].includes(version)) {\n                    throw new Error(`Product version '${version}' is invalid. Allowed choices are ${versions[name].join(', ')}.`);\n                }\n                if (options.obr && !options.username) {\n                    throw new InvalidOptionArgumentError('Missing argument \"--username\", required for installing OBR artifacts');\n                }\n                else if (options.obr && !options.password) {\n                    throw new InvalidOptionArgumentError('Missing argument \"--password\", required for installing OBR artifacts');\n                }\n                if (options.watch) {\n                    quickReload = FileWatcher(name, options, [], true);\n                }\n                const outputDirectory = options.outputDirectory || 'target';\n                const deliverableExtension = options.obr ? 'obr' : 'jar';\n                const files = await glob(`${outputDirectory}/*.${deliverableExtension}`, { cwd: resolve(options.cwd || cwd()) });\n                await Promise.all(files.map(path => Installer(name, path, options)));\n            }\n        },\n        errorHandler: async () => {\n            if (quickReload) {\n                console.log(`Stopping filesystem watcher... ⏳`);\n                await quickReload.close().catch(() => null);\n            }\n            console.log(`Successfully stopped all running processes 💪`);\n        }\n    };\n};\nprogram\n    .name('dcdx install')\n    .description(`Install the Atlassian Data Center plugin using the Atlassian Maven Plugin Suite (AMPS) configuration.\nIf there is a running instance, it will try to install the plugin using QuickReload or the UPM (for OBR).`)\n    .showHelpAfterError(true)\n    .addOption(new Option('-w, --watch', 'Watch for filesystem changes to JAR or OBR files in the current working directory').default(false))\n    .addOption(new Option('-o, --outputDirectory <directory>', 'Output directory where to look for generated JAR or OBR files (defaults to `target`)'))\n    .addOption(new Option('-P, --activate-profiles <arg>', 'Comma-delimited list of profiles to activate'))\n    .addOption(new Option('--obr', 'Upload generated OBR file instead of JAR file when installing the app').default(false))\n    .addOption(new Option('--username <username>', 'The username of the administrator (required with --obr, optional for --mpac)'))\n    .addOption(new Option('--password <password>', 'The password of the administrator (required with --obr, optional for --mpac)'))\n    .addOption(new Option('--mpac', 'Install the app from the Atlassian Marketplace'))\n    .addOption(new Option('--baseUrl <url>', 'URL of the instance (required with --mpac)'))\n    .addOption(new Option('--appKey <key>', 'The key of the app to be installed (required with --mpac)'))\n    .addOption(new Option('--license <path_or_license>', 'The app license, either as a path to a file or the license itself'))\n    .addOption(new Option('--cwd <directory>', 'Specify the working directory where to find the AMPS configuration'))\n    .action(options => ActionHandler(program, Command(), { ...options, install: true }));\nprogram.parseAsync(process.argv).catch(() => gracefulExit(1));\nprocess.on('SIGINT', () => {\n    console.log(`Received term signal, trying to stop gracefully 💪`);\n    gracefulExit(1);\n});\n"],"names":["cwd","pwd","password","passwordPrompt","versions","Docker.getRunningContainerIds","resolvePath","Docker.copy","Commander"],"mappings":"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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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"}
10204
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"install.js","sources":["../../dist/src/helpers/licences.js","../../dist/src/helpers/capitalize.js","../../dist/src/apt/messages.js","../../dist/src/apt/helpers/getAppLicense.js","../../dist/src/helpers/upm.js","../../dist/src/apt/helpers/downloadApp.js","../../dist/src/apt/helpers/getAptDirectory.js","../../dist/src/apt/helpers/getAWSCredentials.js","../../dist/src/apt/helpers/getEnvironmentName.js","../../dist/src/apt/helpers/getProduct.js","../../dist/src/apt/helpers/dcapt.js","../../dist/src/apt/helpers/persistsAWSCredentials.js","../../dist/src/apt/helpers/waitForUserInput.js","../../dist/src/apt/helpers/restartCluster.js","../../dist/src/apt/helpers/installApp.js","../../dist/src/helpers/ActionHandler.js","../../dist/src/types/Database.js","../../dist/src/types/Application.js","../../dist/src/helpers/amps.js","../../dist/src/helpers/isRecursiveBuild.js","../../dist/src/helpers/showRecursiveBuildWarning.js","../../dist/src/helpers/CustomBuilder.js","../../dist/src/helpers/docker.js","../../dist/src/helpers/Installer.js","../../dist/src/helpers/FileWatcher.js","../../dist/src/helpers/toAbsolutePath.js","../../dist/src/helpers/getVersions.js","../../dist/src/commands/install.js"],"sourcesContent":["export const timebomb = {\n    'jira': 'AAACBA0ODAoPeNp9kl1v2jAUhu/zK460OyQHSLuVIkUaTbwNVBKUhEnbugsTDuA2sSPbgbFfPxOC1i+4yEXO5+vnPR+yGiGSW/CuoXc7vBoMvT4ENAOv5/WctUIUG1lVqNx7nqPQSJfccCl8GmU0mSXjlDpRXS5Qxau5RqV90ncCKQzLTcRK9Eu944Ip/cQ/M1MwrTkTbi5LZ1arfMM0hsyg7/X6A9LvE89z2j3ZvsJmQBBPpzQJxqP7U4r+qbjaN32zG+/baR2dMl6c35ei2qIah/4dvaHkOvzpkU/x5IZ8vbodOI9cMbdSclnnxj38EC1XZscUunYy36JvVI3OxGZmbZXdzwIU5lVJWi90rnjVQGoi70B873GNhPOQO51OFGfkS5yQWRKH8yAbxxGZp9Qm/EChpbGExR7MBqGdAlTkcokK7MMeMTfwa2NM9TDsdtfSfQGnWxw7CB47frsQShDSwJJro/iiNmgncw1GQl5rI0trtetY4sKgYCJ/Y4qVFSR0lNGQ3P04aDxrTKvWOjMXT0LuxCU33txaSiPffuRjr3fsO/mC6og/VmsmuGYN0Ij93TFYcVXunQaaDb4+wJbFd7vg0OI5If53NENtoK2AlVQwGScjSFt5lrjdWymu8WEIgSwtppyzAsLgxRk8P5hG9PMA3bKiPspdsULjJRwX7ukf5/NX7TAtAhUAhQSHz9DgycOX7wcwERMJb3TLGb4CFGkB/xUWSRK3BZLrPF9Rn6ZmrUqJX02oc',\n    'confluence': 'AAACzg0ODAoPeNp9VO9v2jAQ/Z6/wtK+IYWGsEKHFGmQmJau/GgIm9iYJhMOYprYke1A4a+fSchGKtqPPvvevXv3zp/6gqLHLEb2HbKsTvNzp9lC98MA2ZbdNKYgdiAGntPDQ2z688HcdH/aM7P5o2kZTzQEJiE4pDAiCTgBngaD0b0RCr5f1S9uHfcUWXSQBzuIeQrCCDlb10mo6A4cJTLQSVlIlzFUggpI8ickMbAVEbI+ypIliPG6R5Il5z4kXEF3A0xJp1Gywa8pFQePKHAmDdt6+A9cJVQEK5yWmhMV8HGZLRWkwrF8PZMgpGPfGh7IUNBUUc6cAKRCcVEYrblAaZxtKEOrsqj8V/US85zxXd+fUGwD70ickRwyf7ARACziqUYo+8Irmt/jUYD9iT+YYmNIKFPACAuvyHIaQEUSHYgz0G8rorgC8rp5qvaEZVp3pt0u8sve3TiTCsSIr0A6llGr1VwfdwPsmb25PjjbVwq2EcZcm6nS6DKX+I3iT1yP/Cy42TBe4FAK0WhZVtu6azYbZeZlB0U2wrpnkQoqq40Uyst67RqB9zU8k64olYeqKnGmNCzWiseOUoKwhLLoK1ExkZISVg95cr3ZN/YqdueSYW649/mdrfJAZOQM3b3b96DRuhVk3261kkFvexwe41UQtJN12u5Gz6GcPT7Pn71H70t69CPcbx/a9rcj3rDuwlk4xprKCA5VN+oJjsaB2R/75sQfezM3GIxH5myKT6PN/QErtDwgFQE6E9VDCLUZtN8F30Ko0K9IqXTRubnZ8HpFlZtzAyYUGb/ryOOIcYVWVCpBl5kCjUwlUhyF2mY80WaoXxdzEhOWe2YsNoRRWWxMt6xX/hH6P5uxF8b3rLJIlz1LpQW95pQPvqfLq0kmwohIeLs2l9PMzfQ48LvvWTbfMY1AXDg9KJDLCV2C9HUMH+CaJfOfudi/v0kIGVswLAIUEMQ9X77gqGBdfH0HIzBaV8NadPUCFBn+RiUA4D+IqVQpTTouLVY66aCGX02121',\n    'bitbucket': 'AAABmg0ODAoPeNp9Ul1v0zAUfc+vsMRbJadJtjGpUiS2JJRONOlaB4SAB9e9W0xTu7JvCv33eImDOoR4vefe4/PhN59hR5bckPiWRNezKJ5FCZkvGUmiJA4yrZALLPkBUrHXotEnu5eBRW6b8KMUoCyw8xH6BVZs2KKce3TJpUJQXAkofh2lOeccIV1dfRhJC7fRXrJuwJzALPL0/qF+pI9XGaPz+uGGspvbkdRx8Awcr0nRdOCnlXnmSlqOUqv0DltureTKg6vOiIZb6J9PoviaRm9pHHs0M9Cf/Rv1Dv/SP5lMyorR99WartZVXmdsUZW03hQOSHtCF+n2TLAB4hlIoYTegSFHo3+AQPK1QTx+m02nzzrko+JQ6MO0HS4oDBffQ5JrojSSnbRo5LZDcMzSEtREdBb1AYwNRzsXff0JgjCwLjG/4mB5giE+JzhbF3esyOn9lxf1F2145a6OWu2V/qmC/2dVdoctmOqptk5PGid+XJx42w3NPPHWQuD9fXJbL8PktfLhU2Av+N2rYMY6uUEFpncY/AYCgfFAMCwCFHzkBlkGH/vRdTeeBSfUMzUDb4W2AhQyM893WPg2Q8oQAYRdBSyKeVUdog==X02jr',\n    'bamboo': 'AAAB3w0ODAoPeNp9Ultr2zAYffevEOwtoMR10qYLGJbYWsno7GA7g90eZPlrotWWjCSnzX79FF8IYWkfDPJ3Oedwzvch2zdoWSvkzpF7v5jdLrwpCkiaIc/1POeRMxAasmMNEa3Az2xnHT04gQJquBQhNeB77vQGuzPs3jk5rXIpx5QZfgDfqAaGUtRUOaj4adX+PkpGy+UOhNE+vnGG5laDags9L3mtuToOJF5Pkja5ZorXJwEXHG+pJQdaNvS/cYtLAysBVFfu19ehvxXPQr4IJwV1AGULKzIneBb+8PBd/GWOH6Yf751No9ieaujleYMHKYl8++Fb13VGo1EUZ/hznOBNEofbIFvHEd6mxDb81kQoUH5EZg+op0dEMFmAQrWSf4AZ9HNvTP1rMZnsrLGmpFpzKsZMVpOy28DQbfweo1AiIQ0quDaK540Bi8w1MhKxRhtZWXvHTghn+zLQBvU46Ela1rLZcYEKOEApazvvfKXceiSoYG/kcTXhTUlFG+XVbgKVNHA+gF7BN8t3UuU5sdpRwXUXGnmlVV0CCmRVU3G8Evf5MKUw9vqIFV36tX7moNjfo7CPTxfenZIJErLMSIhX309pvDd8SUgK3smKMpJsknVKBtr26t4D+gd3AC5qMCwCFHOaTWfFvLCLJPft3qktVo3FafmZAhRojb9IAxj8KEqPDQy0stos394SQQ==X02mq'\n};\nexport const app3hour = 'AAABCA0ODAoPeNpdj01PwkAURffzKyZxZ1IyUzARkllQ24gRaQMtGnaP8VEmtjPNfFT59yJVFyzfubkn796Ux0Bz6SmbUM5nbDzj97RISxozHpMUnbSq88poUaLztFEStUN6MJZ2TaiVpu/YY2M6tI6sQrtHmx8qd74EZ+TBIvyUU/AoYs7jiE0jzknWQxMuifA2IBlUbnQ7AulVjwN9AaU9atASs69O2dNFU4wXJLc1aOUGw9w34JwCTTZoe7RPqUgep2X0Vm0n0fNut4gSxl/Jcnj9nFb6Q5tP/Ueu3L+0PHW4ghZFmm2zZV5k6/95CbR7Y9bYGo/zGrV3Ir4jRbDyCA6vt34DO8p3SDAsAhQnJjLD5k9Fr3uaIzkXKf83o5vDdQIUe4XequNCC3D+9ht9ZYhNZFKmnhc=X02dh';\n","export const capitalize = (value) => value.charAt(0).toUpperCase() + value.slice(1);\n","import { join } from 'path';\nimport { capitalize } from '../helpers/capitalize';\nimport { getRunForStage } from './helpers/getRunForStage';\nconst toNumber = (stage) => {\n    switch (stage) {\n        case 'one-node': return 'third';\n        case 'two-node': return 'fourth';\n        case 'four-node': return 'fifth';\n    }\n};\nexport const emptyLine = () => console.log('​');\nexport const generic = {\n    header: `\n                          ____      _          _____         _                                  \n                          |    \\\\ ___| |_ ___   |     |___ ___| |_ ___ ___                        \n                          |  |  | .'|  _| .'|  |   --| -_|   |  _| -_|  _|                       \n                          |____/|__,|_| |__,|  |_____|___|_|_|_| |___|_|                         \n                                                                                                \n                                                                                                \n  _____            _____         ___                                  _____         _ _   _ _   \n  |  _  |___ ___   |  _  |___ ___|  _|___ ___ _____ ___ ___ ___ ___   |_   _|___ ___| | |_|_| |_ \n  |     | . | . |  |   __| -_|  _|  _| . |  _|     | .'|   |  _| -_|    | | | . | . | | '_| |  _|\n  |__|__|  _|  _|  |__|  |___|_| |_| |___|_| |_|_|_|__,|_|_|___|___|    |_| |___|___|_|_,_|_|_|  \n        |_| |_|                                                                                        \n\n  Welcome to the automated Data Center App Performance Toolkit (DCAPT).\n  This will guide you through all the steps to produce the required performance testing results\n  for your (annual) Data Center approval.\n`\n};\nexport const init = {\n    header: (product) => `\n  We will now follow all the steps as documented in the Data Center App Performance Toolkit User Guide For ${capitalize(product)}.\n  Please consult the documentation prior to starting the test run:\n\n  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-${product}/\n\n  Once you start the test run we will provision the environment on AWS. \n  IMPORTANT: This can incur costs.\n  \n  You can stop this process at any time by exiting this program. Be sure to run the following command to reset \n  the AWS environment and prevent unexpected costs.\n\n  $ dcdx apt teardown\n\n  You can also resume/restart every part of the test run using one of the following commands:\n\n  $ dcdx apt init --product ${product}\n  $ dcdx apt provision --product ${product}\n  $ dcdx apt run1 --product ${product}\n  $ dcdx apt run2 --product ${product}\n  $ dcdx apt run3 --product ${product}\n  $ dcdx apt run4 --product ${product}\n  $ dcdx apt run5 --product ${product}\n\n  We will continue with the following steps:\n${product === 'jira' ? `\n  1.  Provision the environment\n  2.  Performance regression without app installed (run 1)\n  3.  Lucene Index timing test with app installed (run 2)\n  4.  Performance regression with app installed (run 2)\n  5.  Scalability testing on one-node cluster with app-specific actions (run 3)\n  6.  Scalability testing on two-node cluster with app-specific actions (run 4)\n  7.  Scalability testing on four-node cluster with app-specific actions (run 5)\n  8.  Generate reports\n  9.  Teardown of environment\n  10. Security Scanner for Data Center apps\n` : `\n  1. Provision the environment\n  2. Performance regression without app installed (run 1)\n  3. Performance regression with app installed (run 2)\n  4. Scalability testing on one-node cluster with app-specific actions (run 3)\n  5. Scalability testing on two-node cluster with app-specific actions (run 4)\n  6. Scalability testing on four-node cluster with app-specific actions (run 5)\n  7. Generate reports\n  8. Teardown of environment\n  9. Security Scanner for Data Center apps\n`}`,\n};\nexport const provisioning = {\n    header: `\n  _____ _____ _____ _____ _____ _____ _____ _____ _____ _____ _____ _____ \n  |  _  | __  |     |  |  |     |   __|     |     |   | |     |   | |   __|\n  |   __|    -|  |  |  |  |-   -|__   |-   -|  |  | | | |-   -| | | |  |  |\n  |__|  |__|__|_____|\\\\___/|_____|_____|_____|_____|_|___|_____|_|___|_____|\n                                                                               \n  We will now start provisioning AWS using the Atlassian Data Center App Performace Toolkit (DCAPT) Terraform configuration.\n\n  In order to do this, we need the following information:\n\n  1. The location of the Data Center App Performance Toolkit on your disk\n  2. AWS credentials\n  3. Product license\n`,\n    askForAWSCredentials: (product) => `\n  In order to provision the ${capitalize(product)} cluster, we need Administrator credentials for AWS.\n  Please refer to the DCAPT documentation to find more information on how to create the AWS access keys:\n\n  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-${product}/#setup-${product}-data-center-development-environment-on-k8s-\n`,\n    askForEnvironment: `\n  When provisioning the cluster, we need a unique environment name.\n  This will allow you to create multiple clusters (i.e. for different host products) and to identify which cluster to use during testing & teardown.\n`,\n    askForHostLicense: `\n  The host product requires a valid license.\n\n  By default we use the 72h developer license provided by Atlassian. If you need a more extensive license,\n  you can generate an evaluation license from my.atlassian.com or ask Atlassian Marketplace Developer Support for a test license.\n`,\n    askForAppLicense: `\nThe app requires a valid license.\n\nBy default we use the 3 hour timebomb license provided by Atlassian. If you need a more extensive license,\nyou can generate an evaluation license from my.atlassian.com or ask Atlassian Marketplace Developer Support for a test license.\n`,\n    ready: `\n  We have now gathered all the information required to provision the cluster.\n\n  !! IMPORTANT !!\n  \n  We will be writing the configuration to disk. This will overwrite existing configuration.\n  Please note that provisioning the environment will incur AWS usage costs.\n`,\n    awsCredentialsPersisted: '✔ AWS credentials written to app/util/k8s/aws_envs',\n    terraformConfigurationPersisted: `✔ Terraform configuration written to app/util/k8s/dcapt.tfvars`\n};\nexport const Run1 = {\n    header: () => `\n  _____ _____ _____    ___   \n  | __  |  |  |   | |  |_  |  \n  |    -|  |  | | | |   _| |_ \n  |__|__|_____|_|___|  |_____|\n\n  We will now start the performance regression testing without app installed (run 1)\n  This will produce the performance baseline results.\n\n  It is important that you are running the baseline test on the default configuration.\n  You can get the default configuration from the APT sources:\n\n  https://github.com/atlassian/dc-app-performance-toolkit\n`,\n    readyForProvisioning: `\nIn order to be able to start the performance regression test, we will now configure the DC cluster on AWS\n\n!! IMPORTANT !!\n\nWe will be writing the configuration to disk. This will overwrite existing configuration.\nPlease note that provisioning the environment will incur AWS usage costs.\n`,\n    startTest: `\nWe will now start the Performance Regression test\n`,\n    success: `\n✔ Finished the performance regression testing without app installed (run 1)\n`,\n    failure: (stage, cwd, product, environment, resultsBaseDir, results) => {\n        let output = `\n  ✔ Finished the performance ${stage} testing without app installed (run 1)\n\n  Unfortunately, the test run was finished unsuccesful. \n  Please review the test results and adjust the configuration if required.\n`;\n        Object.entries(results).forEach(([key, value]) => output += `  ${key}: ${value}\\n`);\n        output += `\n  Full report can be found here:\n  ${join(resultsBaseDir, 'results_summary.log')}\n\n  You can restart the performance testing using the following command:\n  \n  $ dcdx apt run1 --product ${product} --cwd ${cwd} --environment ${environment}\n`;\n        return output;\n    }\n};\nexport const Run2 = {\n    header: (product) => `\n  _____ _____ _____    ___ \n  | __  |  |  |   | |  |_  |\n  |    -|  |  | | | |  |  _|\n  |__|__|_____|_|___|  |___|\n                          \n  We will now start the performance regression testing with app installed (run 2)\n  This will allow the generation of a performance regression report.\n${product === 'jira' ? `\n  In addition, a Lucene Index Timing Test is also part of the performance regression tests.` : ''}\n  The second run consists of the following steps:\n${product === 'jira' ? `\n  1. Install the app into the cluster\n  2. Benchmark the re-index time with your app installed\n  3. Performance results generation with the app installed\n` : `\n  1. Install the app into the cluster\n  2. Performance results generation with the app installed\n`}\n  It is important that you are running the performance regression test on the default configuration.\n  You can get the default configuration from the APT sources:\n\n  https://github.com/atlassian/dc-app-performance-toolkit\n`,\n    readyForProvisioning: `\nIn order to be able to start the performance regression test, we will now configure the DC cluster on AWS\n\n!! IMPORTANT !!\n\nWe will be writing the configuration to disk. This will overwrite existing configuration.\nPlease note that provisioning the environment will incur AWS usage costs.\n`,\n    startTest: `\n  We will now start the Performance Regression test\n`,\n    success: `\n✔ Finished the performance regression testing with app installed (run 2)\n`,\n    failure: (stage, cwd, product, environment, resultsBaseDir, results) => {\n        let output = `\n  ✔ Finished the performance ${stage} testing with app installed (run 2)\n\n  Unfortunately, the test run was finished unsuccesful. \n  Please review the test results and adjust the configuration if required.\n`;\n        Object.entries(results).forEach(([key, value]) => output += `  ${key}: ${value}\\n`);\n        output += `\n  Full report can be found here:\n  ${join(resultsBaseDir, 'results_summary.log')}\n\n  You can restart the performance testing using the following command:\n  \n  $ dcdx apt run2 --product ${product} --cwd ${cwd} --environment ${environment}\n`;\n        return output;\n    }\n};\nexport const LuceneTimingTest = {\n    header: (_product, stage) => `\n  __    _____ _____ _____ _____ _____ \n  |  |  |  |  |     |   __|   | |   __|\n  |  |__|  |  |   --|   __| | | |   __|\n  |_____|_____|_____|_____|_|___|_____|\n  _____ _____ _____ _____ _____ _____ \n  |_   _|     |     |     |   | |   __|\n    | | |-   -| | | |-   -| | | |  |  |\n    |_| |_____|_|_|_|_____|_|___|_____|\n      _____ _____ _____ _____         \n      |_   _|   __|   __|_   _|        \n        | | |   __|__   | | |          \n        |_| |_____|_____| |_|          \n                                                               \n  We will now start the Lucene Index Timing test with app installed\n  This is part of the Performance ${stage} test (run 2)\n\n  After the re-index is completed a screenshot is created which is part of the required test results\n\n  It is important that you are running the Lucene index timing test on the default configuration.\n  You can get the default configuration from the APT sources:\n\n  https://github.com/atlassian/dc-app-performance-toolkit\n`,\n    readyForProvisioning: `\nIn order to be able to start the Lucene index timing test, we will now configure the DC cluster on AWS\n\n!! IMPORTANT !!\n\nWe will be writing the configuration to disk. This will overwrite existing configuration.\nPlease note that provisioning the environment will incur AWS usage costs.\n`,\n    startTest: `\n  We are ready to start the Lucene Index timing test\n  Once the test is finished, a browser window is opened to capture the test results.\n\n  !! IMPORTANT !!\n\n  This may take ~50 minutes. Please do not terminate the program\n  Do not close the browser window, or else the test will fail\n`,\n    success: `\n✔ Finished the Lucene Index Timinig test with app installed (run 2)\n`,\n    failure: (_stage, cwd, product, environment) => `\n  ✔ Finished the Lucene Index Timing test with app installed (run 2)\n\n  Unfortunately, the test run was finished unsuccesful. \n  Please review the test results and adjust the configuration if required.\n\n  You can restart the Lucene Index Timing test using the following command:\n  \n  $ dcdx apt reindex --product ${product} --cwd ${cwd} --environment ${environment}\n`\n};\nexport const PerformanceReportMessages = {\n    header: `\n  _____ _____ _____ _____ _____ _____ _____ _____ _____ _____ _____   \n  |  _  |   __| __  |   __|     | __  |     |  _  |   | |     |   __|  \n  |   __|   __|    -|   __|  |  |    -| | | |     | | | |   --|   __|  \n  |__|  |_____|__|__|__|  |_____|__|__|_|_|_|__|__|_|___|_____|_____|  \n                                                                      \n      _____ _____ _____ _____ _____ _____ _____ _____ _____ _____     \n      | __  |   __|   __| __  |   __|   __|   __|     |     |   | |    \n      |    -|   __|  |  |    -|   __|__   |__   |-   -|  |  | | | |    \n      |__|__|_____|_____|__|__|_____|_____|_____|_____|_____|_|___|    \n                                                                      \n              _____ _____ _____ _____ _____ _____                     \n              | __  |   __|  _  |     | __  |_   _|                    \n              |    -|   __|   __|  |  |    -| | |                      \n              |__|__|_____|__|  |_____|__|__| |_|                      \n\n\n  We are going to generate the performance regression report\n  The report constists of a CSV and PNG file that are required for \n  the (annual) Data Center app review\n`\n};\nexport const ScalabilityTestMessages = {\n    header: (product, stage) => `\n${stage === 'one-node' ? `\n  _____ _____ _____    ___ \n  | __  |  |  |   | |  |_  |\n  |    -|  |  | | | |  |_  |\n  |__|__|_____|_|___|  |___|\n` : stage === 'two-node' ? `\n  _____ _____ _____    ___ \n  | __  |  |  |   | |  | | |\n  |    -|  |  | | | |  |_  |\n  |__|__|_____|_|___|    |_|                          \n` : `\n  _____ _____ _____    ___ \n  | __  |  |  |   | |  |  _|\n  |    -|  |  | | | |  |_  |\n  |__|__|_____|_|___|  |___|                          \n`}\n\n  We will now start the scalability benchmark for ${stage} ${capitalize(product)} DC cluster with app-specific actions: (run ${getRunForStage(stage)})\n\n  The ${toNumber(stage)} run consists of the following steps:\n  1. Adjust the environment to a ${stage} cluster\n  1. Install the app into the cluster\n  3. Scalability benchmark testing with the app installed\n\n  It is important that you are running the scalability benchmark test on a DCAPT version that has app-specific actions\n  More information on developing app-specific actions can be found here:\n\n${product === 'jira' ?\n        `  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-jira/#3--develop-and-test-app-specific-action-locally`\n        : product === 'confluence' ?\n            `  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-confluence/#3--develop-and-test-app-specific-actions-locally`\n            : product === 'bamboo' ?\n                '  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-bamboo/#2--app-specific-actions-development'\n                // product === 'bitbucket'\n                : '  https://developer.atlassian.com/platform/marketplace/dc-apps-performance-toolkit-user-guide-bitbucket/#3--develop-and-test-app-specific-action-locally'}\n`,\n    readyForProvisioning: `\n  In order to be able to start the scalability benchmark, we will now reconfigure the DC cluster on AWS\n\n  !! IMPORTANT !!\n  \n  We will be writing the configuration to disk. This will overwrite existing configuration.\n  Please note that provisioning the environment will incur AWS usage costs.\n`,\n    startTest: `\n  Ready to start the scalability benchmark test with app-specific actions\n`,\n    success: `\n✔ Finished the scalability benchmark test with app-specific actions\n`,\n    failure: (stage, cwd, product, environment, resultsBaseDir, results) => {\n        let output = `\n✔ Finished the scalability benchmark test with app-specific actions\n\n  Unfortunately, the test run was finished unsuccesful. \n  Please review the test results and adjust the configuration if required.\n`;\n        Object.entries(results).forEach(([key, value]) => output += `  ${key}: ${value}\\n`);\n        output += `\n  Full report can be found here:\n  ${join(resultsBaseDir, 'results_summary.log')}\n\n  You can restart the scalability benchmark test using the following command:\n  \n  $ dcdx apt run${getRunForStage(stage)} --product ${product} --cwd ${cwd} --environment ${environment}\n`;\n        return output;\n    }\n};\nexport const ScalabilityReportMessages = {\n    header: `\n  _____ _____ _____ __    _____ _____ _____ __    _____ _____ __ __ \n  |   __|     |  _  |  |  |  _  | __  |     |  |  |     |_   _|  |  |\n  |__   |   --|     |  |__|     | __ -|-   -|  |__|-   -| | | |_   _|\n  |_____|_____|__|__|_____|__|__|_____|_____|_____|_____| |_|   |_|  \n                                                                    \n              _____ _____ _____ _____ _____ _____                   \n              | __  |   __|  _  |     | __  |_   _|                  \n              |    -|   __|   __|  |  |    -| | |                    \n              |__|__|_____|__|  |_____|__|__| |_|                    \n`\n};\nexport const Restart = {\n    header: `                                           \n  _____ _____ _____ _____ _____ _____ _____ \n  | __  |   __|   __|_   _|  _  | __  |_   _|\n  |    -|   __|__   | | | |     |    -| | |  \n  |__|__|_____|_____| |_| |__|__|__|__| |_|  \n                                           \n  We will now restart the cluster used in the Data Center Application Performance testing.\n`\n};\nexport const Teardown = {\n    header: `\n  _____ _____ _____ _____ ____  _____ _ _ _ _____ \n  |_   _|   __|  _  | __  |    \\\\|     | | | |   | |\n    | | |   __|     |    -|  |  |  |  | | | | | | |\n    |_| |_____|__|__|__|__|____/|_____|_____|_|___|\n\n  We will now terminate the cluster used in the Data Center Application Performance testing.\n`\n};\n","import { input } from '@inquirer/prompts';\nimport { existsSync, readFileSync } from 'fs';\nimport { app3hour } from '../../helpers/licences';\nimport { provisioning } from '../messages';\nexport const getAppLicense = (license, force) => {\n    const appLicense = license && existsSync(license) ? readFileSync(license, 'utf8') : license;\n    if (force) {\n        return appLicense || app3hour;\n    }\n    console.log(provisioning.askForAppLicense);\n    return input({\n        message: `License`,\n        default: appLicense || app3hour,\n        required: true\n    });\n};\n","import axios from 'axios';\nimport FormData from 'form-data';\nimport { createReadStream } from 'fs';\nexport const uploadToUPM = async (baseUrl, path, username, password, verbose = true) => {\n    const credentials = username && password ? Buffer.from(`${username}:${password}`).toString('base64') : null;\n    const response = await axios.get(`${baseUrl}/rest/plugins/1.0/?os_authType=basic`, credentials ? {\n        headers: { 'Authorization': `Basic ${credentials}` }\n    } : undefined).catch(err => {\n        verbose && console.log('Failed to upload plugin archive file to UPM, unable to retrieve token', err);\n        return null;\n    });\n    if (response) {\n        const token = response.headers['upm-token'];\n        if (token) {\n            const formData = new FormData();\n            formData.append('plugin', createReadStream(path));\n            return axios.post(`${baseUrl}/rest/plugins/1.0/?token=${token}`, formData, { headers: {\n                    ...formData.getHeaders(),\n                    ...credentials ? { 'Authorization': `Basic ${credentials}` } : {}\n                } }).then(() => {\n                verbose && console.log('Finished uploading plugin archive to UPM');\n                return true;\n            });\n        }\n        else {\n            verbose && console.log('Failed to upload plugin archive file to UPM, unable to retrieve token from headers:', JSON.stringify(response.headers, null, 2));\n            return false;\n        }\n    }\n    return false;\n};\nexport const waitForPluginToBeEnabled = async (appKey, baseUrl, username, password, verbose = true) => {\n    const credentials = username && password ? Buffer.from(`${username}:${password}`).toString('base64') : null;\n    verbose && console.log('Waiting for plugin to become enabled');\n    let isEnabled = false;\n    let count = 0;\n    while (!isEnabled && count < 120) {\n        await new Promise(resolve => setTimeout(resolve, 1000));\n        verbose && console.log(`Waiting for plugin to become enabled... ${count}s`);\n        const { data } = await axios.get(`${baseUrl}/rest/plugins/1.0/${appKey}-key`, credentials ? {\n            headers: { 'Authorization': `Basic ${credentials}` }\n        } : undefined).catch(() => ({ data: { enabled: false } }));\n        isEnabled = data?.enabled;\n        count++;\n    }\n    return isEnabled;\n};\nexport const registerLicense = async (appKey, license, baseUrl, username, password, verbose = true) => {\n    const credentials = username && password ? Buffer.from(`${username}:${password}`).toString('base64') : null;\n    const { data } = await axios.get(`${baseUrl}/rest/plugins/1.0/${appKey}-key/license`, {\n        headers: {\n            'X-Atlassian-Token': 'no-check',\n            'Content-Type': 'application/vnd.atl.plugins+json',\n            ...credentials ? { 'Authorization': `Basic ${credentials}` } : {}\n        }\n    }).catch(() => ({ data: {} }));\n    const { rawLicense } = data;\n    if (!rawLicense || rawLicense !== license) {\n        return axios.put(`${baseUrl}/rest/plugins/1.0/${appKey}-key/license`, `{ \"rawLicense\": \"${license}\" }`, {\n            headers: {\n                'X-Atlassian-Token': 'no-check',\n                'Content-Type': 'application/vnd.atl.plugins+json',\n                ...credentials ? { 'Authorization': `Basic ${credentials}` } : {}\n            }\n        }).then(() => {\n            verbose && console.log('Finished uploading license to UPM');\n            return true;\n        }).catch(err => {\n            verbose && console.log('Failed to upload license to UPM', err);\n            return false;\n        });\n    }\n    return true;\n};\n","import axios from 'axios';\nimport { parse } from 'content-disposition';\nimport { createWriteStream, mkdirSync } from 'fs';\nimport { homedir } from 'os';\nimport { join } from 'path';\nimport { finished } from 'stream/promises';\nexport const downloadApp = async (addonKey) => {\n    const tmpDir = join(homedir(), '.dcdx', 'tmp');\n    mkdirSync(tmpDir, { recursive: true });\n    let downloadUrl = `https://marketplace.atlassian.com/download/plugins/${addonKey}`;\n    const { data: listing } = await axios.get(`https://marketplace.atlassian.com/rest/2/addons/${addonKey}?hosting=datacenter&withVersion=true`).catch(() => ({ data: null }));\n    if (listing) {\n        downloadUrl = listing._embedded?.version?._embedded?.artifact?._links?.binary?.href || downloadUrl;\n    }\n    const response = await axios({\n        method: 'get',\n        url: downloadUrl,\n        responseType: 'stream'\n    });\n    const disposition = parse(response.headers['content-disposition']);\n    const filename = disposition?.parameters?.filename || addonKey;\n    const tmpFile = join(tmpDir, filename);\n    const writer = createWriteStream(tmpFile);\n    response.data.pipe(writer);\n    await finished(writer);\n    return tmpFile;\n};\n","import { confirm, input } from '@inquirer/prompts';\nimport { existsSync, rmSync } from 'fs';\nimport { homedir } from 'os';\nimport { join, resolve } from 'path';\nimport { cwd as pwd } from 'process';\nimport simpleGit from 'simple-git';\nimport { emptyLine } from '../messages';\nexport const getAptDictory = async (cwd, mustUseDefaultConfiguration, force) => {\n    // Translate common relative paths to absolute paths\n    let result = cwd ?\n        cwd.startsWith('~/')\n            ? cwd.replace('~/', homedir())\n            : cwd.startsWith('./')\n                ? cwd.replace('./', pwd() + '/')\n                : cwd === '.'\n                    ? pwd()\n                    : cwd\n        : pwd();\n    // If we are in interactive mode, we should ask questions first\n    if (!force) {\n        // Check if we are currently in the APT directory\n        const isCurrentDirectoryEligable = existsSync(join(result, 'app/util/k8s/dcapt.tfvars'));\n        // If this is the APT directory, we will be using the current directory...\n        let useCurrentDirectory = isCurrentDirectoryEligable;\n        // ...unless told otherwise\n        if (isCurrentDirectoryEligable) {\n            console.log(`  We've found the App Performance Toolkit in the specified directory:\n  ${result}\n`);\n            useCurrentDirectory = await confirm({\n                message: `Do you wish to use this directory?`,\n                default: true,\n            });\n        }\n        // If we are not going to use the current directory, ask for the alternative\n        let directory = result;\n        if (!useCurrentDirectory) {\n            directory = await input({\n                message: 'Please specify the location where the App Peformance Toolkit is located',\n                default: result,\n                required: true\n            });\n        }\n        // Translate common relative paths to absolute paths\n        directory = directory.startsWith('~/')\n            ? directory.replace('~/', homedir() + '/')\n            : directory.startsWith('./')\n                ? directory.replace('./', pwd() + '/')\n                : directory === '.'\n                    ? pwd()\n                    : directory;\n        // Check if the provided alternative is a DCAPT directory\n        const isDirectoryEligable = existsSync(resolve(join(directory, 'app/util/k8s/dcapt.tfvars')));\n        if (!isDirectoryEligable) {\n            // If it is not a DCAPT directory, ask if we need to clone it from Github\n            const mustCloneAPT = await confirm({\n                message: `The directory either doesn't exist, or it doesn't contain the App Peformance Toolkit. Do you want to clone DCAPT from source?`,\n            });\n            // If we must clone it from Github, we should clone it from Github\n            if (mustCloneAPT) {\n                await simpleGit().clone('https://github.com/atlassian/dc-app-performance-toolkit.git', directory);\n            }\n        }\n        // Check if this needs to be a default configuration (for performance regression testing)\n        if (mustUseDefaultConfiguration) {\n            // Ask nicely...\n            const isDefaultConfiguration = await confirm({\n                message: 'Please confirm that the chosen directory is using the default configuration for DCAPT (master branch)'\n            });\n            // ...but also, No is not an option\n            if (!isDefaultConfiguration) {\n                throw new Error('It is required to use the default configuration from master to continue');\n            }\n        }\n        else {\n            // Ask nicely...\n            const isAppSpecificConfiguration = await confirm({\n                message: 'Please confirm that the chosen directory has a DCAPT installation with app-specific actions'\n            });\n            // ...but also, No is not an option\n            if (!isAppSpecificConfiguration) {\n                throw new Error('It is required to have app-specific actions in order to continue');\n            }\n        }\n        // Set the result to the provided directory\n        result = directory;\n        // If we are in non-interactive mode and we need to use the default configuration, we will clone it from Github\n    }\n    else if (mustUseDefaultConfiguration) {\n        // If the provided directory does not exists we can use it\n        // Otherwise use a temporary directory to ensure a fresh non-persistent checkout\n        result = !existsSync(result)\n            ? result\n            : join(homedir(), '.dcdx', 'dcapt');\n        // Inform the user of the chosen directory\n        console.log('  Installing default configuration of DCAPT from source (non-interactive mode)');\n        console.log(`  ${result}`);\n        // Make sure the directory is empty\n        rmSync(result, { force: true, recursive: true });\n        // Retrieve DCAPT from github\n        await simpleGit().clone('https://github.com/atlassian/dc-app-performance-toolkit.git', result);\n        console.log('✔ Finished installing default configuration of DCAPT from source (non-interactive mode)');\n        // If we are in non-interactive mode and we need to use app specific configuration, make sure that it exists\n    }\n    else {\n        // Check if we are currently in the APT directory\n        const isCurrentDirectoryEligable = existsSync(join(result, 'app/util/k8s/dcapt.tfvars'));\n        // If this is not a DCAPT directory, we cannot continue\n        if (!isCurrentDirectoryEligable) {\n            throw new Error(`Could not find App Performance Toolkit in the current directory ${result}`);\n        }\n        console.log('  Using DCAPT from current directory (non-interactive mode)');\n        console.log(`  ${result}`);\n        emptyLine();\n    }\n    // This should not occur, because either we have established the current directory has DCAPT\n    // or we have cloned it into a (new) directory. This is merely a check for if the latter failed.\n    if (!existsSync(join(result, 'app/util/k8s/dcapt.tfvars'))) {\n        throw new Error(`Could not find the App Performance Toolkit in the provided directory ${result}`);\n    }\n    // Some additional checks to ensure that we are in a valid DCAPT directory\n    const hasEnvFile = existsSync(join(result, 'app/util/k8s/aws_envs'));\n    const hasSnapshotJSON = existsSync(join(result, 'app/util/k8s/dcapt-snapshots.json'));\n    const hasTerraformVariables = existsSync(join(result, 'app/util/k8s/dcapt.tfvars'));\n    if (!hasEnvFile) {\n        throw new Error(`Could not find the required 'aws_ens' file. Expected to find it in ${join(result, 'app/util/k8s/aws_envs')}`);\n    }\n    else if (!hasSnapshotJSON) {\n        throw new Error(`Could not find the required 'dcapt-snapshots.json' file. Expected to find it in ${join(result, 'app/util/k8s/dcapt-snapshots.json')}`);\n    }\n    else if (!hasTerraformVariables) {\n        throw new Error(`Could not find the required 'dcapt.tfvars' file. Expected to find it in ${join(result, 'app/util/k8s/dcapt.tfvars')}`);\n    }\n    return result;\n};\n","import { password } from '@inquirer/prompts';\nimport { provisioning } from '../messages';\nexport const getAWSCredentials = async (product, force) => {\n    // Try getting the AWS credentials from environment variables\n    const { AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY } = process.env;\n    // If they exists as environment variables, return them immediately\n    if (AWS_ACCESS_KEY_ID && AWS_SECRET_ACCESS_KEY) {\n        return [AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY];\n    }\n    // If we are not in non-interactive mode, we should ask for them\n    if (!force) {\n        // Show a message asking nicely\n        console.log(provisioning.askForAWSCredentials(product));\n        const aws_access_key_id = await password({\n            message: `AWS Access Key ID`,\n            validate: (input) => typeof input === 'string' && input.length > 0\n        });\n        const aws_secret_access_key = await password({\n            message: `AWS Secret Access Key`,\n            validate: (input) => typeof input === 'string' && input.length > 0\n        });\n        return [aws_access_key_id, aws_secret_access_key];\n    }\n    // If we are in non-interactive mode, and the credentials have not been found, we should throw an error\n    throw new Error(`The AWS credentials could not be found. Please provide the 'AWS_ACCESS_KEY_ID' and 'AWS_SECRET_ACCESS_KEY' environment variables`);\n};\n","import { input } from '@inquirer/prompts';\nimport { provisioning } from '../messages';\nexport const getEnvironmentName = async () => {\n    console.log(provisioning.askForEnvironment);\n    return input({\n        message: `Environment name`,\n        required: true\n    });\n};\n","import { select } from '@inquirer/prompts';\nexport const getProduct = async () => {\n    return select({\n        message: `Please choose the product for which you wish to run DCAPT`,\n        choices: [\n            { name: 'Jira', value: 'jira' },\n            { name: 'Confluence', value: 'confluence' },\n            { name: 'Bamboo', value: 'bamboo' },\n            { name: 'Bitbucket', value: 'bitbucket' }\n        ]\n    });\n};\n","import { spawn } from 'child_process';\nimport { writeFileSync } from 'fs';\nimport { join, resolve } from 'path';\nexport const install = async (cwd) => {\n    console.log(`\n  Start provisioning AWS using the Atlassian Data Center App Performace Toolkit (DCAPT) Terraform configuration\n  Using DCAPT configuration from ${cwd}\n`);\n    const baseDir = join(cwd, 'app/util/k8s');\n    writeFileSync(join(baseDir, 'outputs.json'), '# terraform output', 'utf-8');\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--env-file', 'aws_envs',\n            '-v', `${baseDir}/dcapt.tfvars:/data-center-terraform/conf.tfvars`,\n            '-v', `${baseDir}/dcapt-snapshots.json:/data-center-terraform/dcapt-snapshots.json`,\n            '-v', `${baseDir}/logs:/data-center-terraform/logs`,\n            '-v', `${baseDir}/outputs.json:/data-center-terraform/outputs.json`,\n            'atlassianlabs/terraform:latest',\n            './install.sh', '-c', 'conf.tfvars'\n        ], { cwd: baseDir, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n    console.log(`\n✔ Finished provisioning AWS using the Atlassian Data Center App Performace Toolkit (DCAPT) Terraform configuration\n  Cluster details can be found in ${baseDir}/outputs.json\n`);\n};\nexport const runTest = async (cwd, environment, product) => {\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--env-file', './app/util/k8s/aws_envs',\n            '-e', `REGION=us-east-2`,\n            '-e', `ENVIRONMENT_NAME=${environment}`,\n            '-v', `${cwd}:/data-center-terraform/dc-app-performance-toolkit`,\n            '-v', `${cwd}/app/util/k8s/bzt_on_pod.sh:/data-center-terraform/bzt_on_pod.sh`,\n            'atlassianlabs/terraform:latest',\n            'bash', 'bzt_on_pod.sh', `${product}.yml`\n        ], { cwd, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n};\nexport const regressionReport = async (cwd, run1Dir, run2Dir) => {\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--workdir', '//dc-app-performance-toolkit/app/reports_generation',\n            '--entrypoint', 'python',\n            '-v', `${cwd}:/dc-app-performance-toolkit`,\n            '-v', `${run1Dir}:/results/run1`,\n            '-v', `${run2Dir}:/results/run2`,\n            'atlassian/dcapt',\n            'csv_chart_generator.py', 'performance_profile.yml'\n        ], { cwd, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n    console.log(`✔ Finished generating the Performance Regression Report`);\n};\nexport const scalabilityReport = async (cwd, resultsDir1, resultsDir2, resultsDir3) => {\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--workdir', '//dc-app-performance-toolkit/app/reports_generation',\n            '--entrypoint', 'python',\n            '-v', `${cwd}:/dc-app-performance-toolkit`,\n            '-v', `${resultsDir1}:/dcapt/scale_results_1`,\n            '-v', `${resultsDir2}:/dcapt/scale_results_2`,\n            '-v', `${resultsDir3}:/dcapt/scale_results_3`,\n            'atlassian/dcapt',\n            'csv_chart_generator.py', 'scale_profile.yml'\n        ], { cwd, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n    console.log(`✔ Finished generating the Scalability Benchmark Report`);\n};\nexport const restart = async (cwd, environment, product) => {\n    writeFileSync(join(cwd, './app/util/k8s/delete_pod.sh'), `\naws eks update-kubeconfig --name atlas-$ENVIRONMENT_NAME-cluster --region $REGION\nkubectl rollout restart sts/$PRODUCT -n atlassian\nkubectl rollout status sts $PRODUCT -n atlassian`, 'utf8');\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            '-it',\n            `--pull=always`,\n            '--env-file', './app/util/k8s/aws_envs',\n            '-e', `REGION=us-east-2`,\n            '-e', `ENVIRONMENT_NAME=${environment}`,\n            '-e', `PRODUCT=${product}`,\n            '-v', `${cwd}:/data-center-terraform/dc-app-performance-toolkit`,\n            '-v', `${cwd}/app/util/k8s/delete_pod.sh:/data-center-terraform/delete_pod.sh`,\n            'atlassianlabs/terraform:latest',\n            'bash', 'delete_pod.sh'\n        ], { cwd, stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n};\nexport const terminate = async (cwd, environment) => {\n    const baseDir = resolve(join(cwd, 'app/util/k8s'));\n    await new Promise((resolve, reject) => {\n        const docker = spawn('docker', [\n            'run',\n            `--pull=always`,\n            '--env-file', 'aws_envs',\n            '--workdir', '//data-center-terraform',\n            '--entrypoint', 'python',\n            '-v', `${baseDir}/terminate_cluster.py:/data-center-terraform/terminate_cluster.py`,\n            'atlassian/dcapt',\n            'terminate_cluster.py', '--cluster_name', `atlas-${environment}-cluster`, '--aws_region', 'us-east-2'\n        ], { cwd: join(cwd, 'app/util/k8s'), stdio: 'inherit' });\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n    console.log(`✔ Finished terminating the DC cluster on AWS using the Atlassian Data Center App Performace Toolkit (DCAPT) Terraform configuration`);\n};\n","import { writeFileSync } from 'fs';\nimport { join } from 'path';\nimport { provisioning } from '../messages';\nexport const persistAWSCredentials = (cwd, aws_access_key_id, aws_secret_access_key) => {\n    writeFileSync(join(cwd, 'app/util/k8s/aws_envs'), `\n# aws_envs file should contain AWS variables needed for authorization (without quotes)\nAWS_ACCESS_KEY_ID=${aws_access_key_id}\nAWS_SECRET_ACCESS_KEY=${aws_secret_access_key}\n`.trim(), 'utf-8');\n    console.log(provisioning.awsCredentialsPersisted);\n};\n","import inquirer from 'inquirer';\nimport PressToContinuePrompt from 'inquirer-press-to-continue';\ninquirer.registerPrompt('press-to-continue', PressToContinuePrompt);\nexport const waitForUserInput = async (message, force) => {\n    const { key } = await inquirer.prompt({\n        name: 'key',\n        type: 'press-to-continue',\n        anyKey: true,\n        pressToContinueMessage: message,\n        when: !force\n    });\n    return key || { value: undefined };\n};\n","import { emptyLine, Restart } from '../messages';\nimport { restart } from './dcapt';\nimport { getAptDictory } from './getAptDirectory';\nimport { getAWSCredentials } from './getAWSCredentials';\nimport { persistAWSCredentials } from './persistsAWSCredentials';\nimport { waitForUserInput } from './waitForUserInput';\nexport const restartCluster = async (options) => {\n    // Show nice little welcome message\n    console.log(Restart.header);\n    // Ask for the proper directory of APT\n    const directory = await getAptDictory(options.cwd, true, options.force);\n    // Ask for the AWS credentials\n    const [aws_access_key_id, aws_secret_access_key] = await getAWSCredentials(options.product, options.force);\n    // Write AWS credentials to disk\n    persistAWSCredentials(directory, aws_access_key_id, aws_secret_access_key);\n    // Ask the user if they are ready to say goodbye to their cluster\n    await waitForUserInput('Press a key to continue...', options.force);\n    emptyLine();\n    // Terminate it!\n    await restart(directory, options.environment, options.product);\n    // Ask the user to quit the program\n    await waitForUserInput('Press a key to exit...', options.force);\n};\n","import { confirm, input, password as passwordPrompt, select } from '@inquirer/prompts';\nimport { Presets, SingleBar } from 'cli-progress';\nimport { rmSync } from 'fs';\nimport { registerLicense, uploadToUPM, waitForPluginToBeEnabled } from '../../helpers/upm';\nimport { downloadApp } from './downloadApp';\nimport { getAppLicense } from './getAppLicense';\nimport { getAptDictory } from './getAptDirectory';\nimport { getAWSCredentials } from './getAWSCredentials';\nimport { getEnvironmentName } from './getEnvironmentName';\nimport { getProduct } from './getProduct';\nimport { restartCluster } from './restartCluster';\nconst progressBar = new SingleBar({\n    format: '  [{bar}] {percentage}% | ETA: {eta_formatted}m',\n    formatTime: (value) => {\n        const total = progressBar.getTotal() / 60;\n        const timePassed = round((progressBar.getTotal() - value) / 60, 0.5);\n        return timePassed === total ? `${total}` : `${total - timePassed}`;\n    },\n    hideCursor: true\n}, Presets.legacy);\nconst round = (value, step = 1.0) => {\n    const inv = 1.0 / step;\n    return Math.floor(value * inv) / inv;\n};\nexport const installApp = async (options) => {\n    // Set default value for username/password\n    const username = options.username || 'admin';\n    const password = options.password || 'admin';\n    // If we are in non-interactive mode, we will download it from MPAC\n    if (options.force) {\n        // In order to do so, we need an appkey. If this is not provided, throw a hissy fit\n        if (!options.appKey) {\n            throw new Error('Failed to automatically install app into cluster, `appKey` was not provided');\n        }\n        // Get the app license\n        const appLicense = await getAppLicense(options.license, options.force);\n        // Download the file from MPAC\n        const file = await downloadApp(options.appKey);\n        let count = 0;\n        let timerId = null;\n        let isInstalledSuccesfully = false;\n        while (!isInstalledSuccesfully && count <= 4) {\n            try {\n                if (count === 0) {\n                    console.log(`\n  Installing the app (${options.appKey}) into the cluster using the Universal Plugin Manager REST API`);\n                }\n                else {\n                    console.log(`\n  Retrying installation of the app (${options.appKey}) into the cluster using the Universal Plugin Manager REST API (attempt ${count + 1})`);\n                }\n                // Show a progress bar\n                progressBar.start(180, 0);\n                timerId = setInterval(() => progressBar.increment(), 1000);\n                // Upload it into the cluster using the UPM REST API\n                const isInstalled = await uploadToUPM(options.baseUrl, file, username, password, false);\n                if (!isInstalled) {\n                    throw new Error('Failed to install app into the cluster using the Universal Plugin Manager REST API');\n                }\n                // Check if we need to restart the application container\n                if (options.restartAfterInstall) {\n                    // For restarts, the product option is required\n                    if (!options.product) {\n                        console.log('  Failed to restart application, required option `product` is missing');\n                        // For restarts, the environment option is required\n                    }\n                    else if (!options.environment) {\n                        console.log('  Failed to restart application, required option `product` is missing');\n                        // Ok, good to go!\n                    }\n                    else {\n                        // Oh right, we also need DCAPT in order to be able to restart the cluster\n                        const cwd = await getAptDictory(options.cwd, false, options.force);\n                        // We are now going to restart the cluster and hope for the best\n                        console.log(`  Restarting ${options.product} to ensure app installation`);\n                        await restartCluster({\n                            cwd,\n                            product: options.product,\n                            environment: options.environment,\n                            aws_access_key_id: options.aws_access_key_id,\n                            aws_secret_access_key: options.aws_secret_access_key,\n                            force: options.force\n                        });\n                    }\n                }\n                // Wait for the plugin to be enabled\n                const isEnabled = await waitForPluginToBeEnabled(options.appKey, options.baseUrl, username, password, false);\n                if (!isEnabled) {\n                    throw new Error('The app could not be enabled on the cluster, please refer to the application log files for more information');\n                }\n                // Register the license (use the 3 hour timebomb in non-interactive mode)\n                const isLicensed = await registerLicense(options.appKey, appLicense, options.baseUrl, username, password, false);\n                if (!isLicensed) {\n                    throw new Error('The license could not be applied for the app on the cluster, please refer to the application log files for more information');\n                }\n                isInstalledSuccesfully = isInstalled && isEnabled && isLicensed;\n            }\n            catch (err) {\n                if (count <= 3) {\n                    // Wait a minute (cooldown period) before retrying\n                    await new Promise(resolve => setTimeout(resolve, 1000));\n                }\n                else {\n                    throw err;\n                }\n            }\n            finally {\n                count++;\n                // Stop the progress bar\n                progressBar.stop();\n                if (timerId) {\n                    clearInterval(timerId);\n                }\n            }\n        }\n        // Remove the temporary file\n        rmSync(file, { force: true });\n        // Tell them we succeeded\n        console.log(`✔ Finished installing the app (${options.appKey})`);\n        // If we're in interactive mode, let's be nice\n    }\n    else {\n        // Tell the user they have options\n        console.log(`\n  It is now required to install the app into the Jira cluster.\n  We can install it from the Atlassian Marketplace or you can install it manually.\n`);\n        // Ask them if they prefer automation or tedious manual tasks\n        const method = await select({\n            message: `How do you want to install the app?`,\n            default: 'mpac',\n            choices: [\n                { name: 'Marketplace', value: 'mpac' },\n                { name: 'Manual', value: 'manual' }\n            ]\n        });\n        // If they chose automation, let's automate!\n        if (method === 'mpac') {\n            // Ask them nicely for the app key\n            const addonKey = await input({\n                message: 'Please provide the key of the app to be installed',\n                default: options.appKey,\n                required: true\n            });\n            // Ask them nicely for the app license to be used\n            const appLicense = await getAppLicense(options.license, options.force);\n            // Ask them nicely for the username\n            const adminUsername = await input({\n                message: 'Please provide the username of a system administrator',\n                default: username,\n                required: true\n            });\n            // Ask them nicely for the username\n            const adminPassword = await passwordPrompt({\n                message: 'Please provide the username of a system administrator',\n                validate: item => typeof item === 'string' && item.length > 0\n            });\n            // Ask them nicely if we need to restart the application\n            const restartAfterInstall = await confirm({\n                message: 'Restart the host application after installation?',\n            });\n            // Tell them we are starting\n            console.log(`\n  Installing the app (${addonKey}) into the cluster using the Universal Plugin Manager REST API`);\n            // Show a progress bar\n            progressBar.start(180, 0);\n            const timerId = setInterval(() => progressBar.increment(), 1000);\n            // Download the file from MPAC\n            const file = await downloadApp(addonKey);\n            // Upload it into the cluster using the UPM REST API\n            const isInstalled = await uploadToUPM(options.baseUrl, file, adminUsername, adminPassword, false);\n            if (!isInstalled) {\n                throw new Error('Failed to install app into the cluster using the Universal Plugin Manager REST API');\n            }\n            // Check if we need to restart the application container\n            if (restartAfterInstall) {\n                // Ask them nicely for the host product\n                const product = options.product || await getProduct();\n                // Ask for the AWS credentials\n                const [aws_access_key_id, aws_secret_access_key] = await getAWSCredentials(product, options.force);\n                // Ask for the environment name\n                const environment = options.environment || await getEnvironmentName();\n                // Oh right, we also need DCAPT in order to be able to restart the cluster\n                const cwd = await getAptDictory(options.cwd, false, options.force);\n                // We are now going to restart the cluster and hope for the best\n                console.log(`  Restarting ${options.product} to ensure app installation`);\n                await restartCluster({\n                    cwd,\n                    product: product,\n                    environment: environment,\n                    aws_access_key_id: aws_access_key_id,\n                    aws_secret_access_key: aws_secret_access_key,\n                    force: options.force\n                });\n            }\n            // Wait for the plugin to be enabled\n            const isEnabled = await waitForPluginToBeEnabled(addonKey, options.baseUrl, adminUsername, adminPassword, false);\n            if (!isEnabled) {\n                throw new Error('The app could not be enabled on the cluster, please refer to the application log files for more information');\n            }\n            // Register the provided license\n            const isLicensed = await registerLicense(addonKey, appLicense, options.baseUrl, adminUsername, adminPassword, false);\n            if (!isLicensed) {\n                throw new Error('The license could not be applied for the app on the cluster, please refer to the application log files for more information');\n            }\n            // Remove the temporary file\n            rmSync(file, { force: true });\n            // Stop the progress bar\n            progressBar.stop();\n            clearInterval(timerId);\n            // Tell them we succeeded\n            console.log(`✔ Finished installing the app (${addonKey})`);\n            // They chose violence\n        }\n        else {\n            // Rub it in their face\n            console.log(`\n  You can now install the app manually into the cluster.\n  Please go to the following page:\n    \n  ${options.baseUrl}/plugins/servlet/upm?source=side_nav_manage_addons\n`);\n            // Make them grovel\n            const isInstalledManually = await confirm({\n                message: `Please confirm that you have installed the app manually`\n            });\n            // If the app ain't installed, we ain't doing nothin'. So we better throw a hissy fit\n            if (!isInstalledManually) {\n                throw new Error('It is required to install the app to run the second performance regression test');\n            }\n        }\n    }\n};\n","import { asyncExitHook, gracefulExit } from 'exit-hook';\nimport { z } from 'zod';\nexport const ActionHandler = async (program, { action, errorHandler }, options) => {\n    const ops = options || program.opts();\n    await new Promise((_, reject) => {\n        let errorMessage = '';\n        asyncExitHook(async (code) => {\n            try {\n                if (code !== 0) {\n                    await errorHandler(ops).catch(() => null);\n                }\n                if (errorMessage) {\n                    throw new Error(errorMessage.trim());\n                }\n                else {\n                    // We are rejecting the promise to avoid the\n                    // \"Calling process.exit\" log message from exit-hook\n                    reject(null);\n                }\n            }\n            catch (err) {\n                const message = err instanceof Error ? err.message : err;\n                reject(message);\n            }\n        }, {\n            wait: 60 * 1 * 1000\n        });\n        action(ops).then(() => {\n            gracefulExit(0);\n        }).catch(err => {\n            if (err instanceof z.ZodError) {\n                err.issues.forEach(issue => {\n                    errorMessage += `Unable to parse option ${issue.path.join(',')}: ${issue.message}\\n`;\n                });\n            }\n            else if (err instanceof Error || typeof err === 'string') {\n                errorMessage = err.toString();\n            }\n            gracefulExit(1);\n        });\n    }).catch(message => {\n        if (message !== null) {\n            program.error(message);\n            // If there is no error message,\n            // we can assume a clean exit\n        }\n        else {\n            process.exit(0);\n        }\n    });\n};\n","import { z } from 'zod';\nimport versions from '../../assets/versions.json';\nexport const SupportedDatabaseEngines = z.enum([\n    'postgresql',\n    'mysql',\n    'mssql'\n]);\nexport const SupportedMSSQLEditions = z.enum([\n    'Developer',\n    'Express',\n    'Standard',\n    'Enterprise',\n    'EnterpriseCore'\n]);\nexport const DatabaseOptions = z.object({\n    name: SupportedDatabaseEngines,\n    port: z.number().or(z.string().transform(Number).refine(item => !isNaN(item))),\n    database: z.string().default('dcdx'),\n    username: z.string().default('dcdx'),\n    password: z.string().default('dcdx'),\n    clean: z.boolean().default(false),\n    prune: z.boolean().default(false),\n    verbose: z.boolean().default(false),\n    driver: z.string()\n});\nexport const PostgreSQLOptions = DatabaseOptions.extend({\n    name: SupportedDatabaseEngines.refine(item => item === SupportedDatabaseEngines.Values.postgresql).default(SupportedDatabaseEngines.Values.postgresql),\n    tag: z.string().refine(item => versions[SupportedDatabaseEngines.Values.postgresql].includes(item)).default('latest'),\n    port: z.number().or(z.string().transform(Number).refine(item => !isNaN(item))).default(5432),\n    driver: z.string().refine(item => item === 'org.postgresql.Driver').default('org.postgresql.Driver')\n});\nexport const MySQLOptions = DatabaseOptions.extend({\n    name: SupportedDatabaseEngines.refine(item => item === SupportedDatabaseEngines.Values.mysql).default(SupportedDatabaseEngines.Values.mysql),\n    tag: z.string().refine(item => versions[SupportedDatabaseEngines.Values.mysql].includes(item)).default('latest'),\n    port: z.number().or(z.string().transform(Number).refine(item => !isNaN(item))).default(3306),\n    driver: z.string().refine(item => item === 'com.mysql.jdbc.Driver').default('com.mysql.jdbc.Driver')\n});\nexport const MSSQLOptions = DatabaseOptions.extend({\n    name: SupportedDatabaseEngines.refine(item => item === SupportedDatabaseEngines.Values.mssql).default(SupportedDatabaseEngines.Values.mssql),\n    tag: z.string().refine(item => versions[SupportedDatabaseEngines.Values.mssql].includes(item)).default('latest'),\n    edition: SupportedMSSQLEditions.default('Developer'),\n    port: z.number().or(z.string().transform(Number).refine(item => !isNaN(item))).default(1433),\n    username: z.string().refine(item => item === 'sa').default('sa'),\n    password: z.string().default('DataCenterDX!'),\n    driver: z.string().refine(item => item === 'com.microsoft.sqlserver.jdbc.SQLServerDriver').default('com.microsoft.sqlserver.jdbc.SQLServerDriver')\n});\n","import { z } from 'zod';\nimport { SupportedDatabaseEngines } from './Database';\nexport const SupportedApplications = z.enum([\n    'jira',\n    'confluence',\n    'bitbucket',\n    'bamboo'\n]);\nexport const ApplicationOptions = z.object({\n    name: SupportedApplications,\n    tag: z.string().default('latest'),\n    database: SupportedDatabaseEngines.default('postgresql'),\n    databaseTag: z.string().default('latest'),\n    port: z.string().transform(Number).refine(item => !isNaN(item)).default('80'),\n    contextPath: z.string(),\n    xms: z.string().default('1024m'),\n    xmx: z.string().default('1024m'),\n    watch: z.boolean().default(false),\n    ext: z.array(z.string()),\n    install: z.boolean(),\n    outputDirectory: z.string(),\n    activateProfiles: z.string(),\n    clean: z.boolean().default(false),\n    prune: z.boolean().default(false),\n    debug: z.boolean().default(true),\n    cwd: z.string()\n}).partial({\n    contextPath: true,\n    ext: true,\n    install: true,\n    outputDirectory: true,\n    activateProfiles: true,\n    cwd: true\n});\n","import { DOMParser, XMLSerializer } from '@xmldom/xmldom';\nimport { spawn } from 'child_process';\nimport { XMLParser } from 'fast-xml-parser';\nimport { existsSync, readFileSync } from 'fs';\nimport { join } from 'path';\nimport { cwd } from 'process';\nimport xpath from 'xpath';\nimport { SupportedApplications } from '../types/Application';\nexport class AMPS {\n    options;\n    maven = null;\n    // ------------------------------------------------------------------------------------------ Constructor\n    constructor(options = {\n        profiles: []\n    }) {\n        this.options = options;\n    }\n    // ------------------------------------------------------------------------------------------ Public Methods\n    stop() {\n        if (this.maven) {\n            const killed = this.maven.kill(0);\n            if (!killed) {\n                throw new Error('Failed to terminate existing Maven process');\n            }\n        }\n    }\n    async build(args) {\n        return new Promise((resolve, reject) => {\n            if (this.maven) {\n                const killed = this.maven.kill(0);\n                if (!killed) {\n                    reject(new Error('Failed to terminate existing Maven process'));\n                }\n            }\n            this.maven = spawn('mvn', ['package', ...args], { cwd: this.options?.cwd || cwd(), stdio: 'inherit' });\n            this.maven.on('exit', (code) => {\n                this.maven = null;\n                if (code === 0 || code === 130) {\n                    resolve();\n                }\n                else {\n                    reject(new Error(`Maven exited with code ${code}`));\n                }\n            });\n        });\n    }\n    isAtlassianPlugin = () => {\n        try {\n            const nodes = this.getNodes('//*[local-name()=\\'packaging\\']');\n            return nodes.some(item => item.textContent === 'atlassian-plugin');\n        }\n        catch (err) {\n            return false;\n        }\n    };\n    getApplicationVersion() {\n        const applications = this.getApplications();\n        if (applications.size === 1) {\n            const [, version] = Array.from(applications)[0];\n            return version;\n        }\n        else if (applications.size > 1) {\n            throw new Error('The Atlassian Plugin project contains multiple AMPS configuration, unable to decide which product to use 😰');\n        }\n        return undefined;\n    }\n    getApplication() {\n        const applications = this.getApplications();\n        if (applications.size === 1) {\n            const [name] = Array.from(applications)[0];\n            return name;\n        }\n        else if (applications.size > 1) {\n            throw new Error('The Atlassian Plugin project contains multiple AMPS configuration, unable to decide which product to use 😰');\n        }\n        return null;\n    }\n    getApplications() {\n        const result = new Map();\n        const nodes = this.getNodes('//*[local-name()=\\'groupId\\' and text()=\\'com.atlassian.maven.plugins\\']');\n        const nodesWithActiveProfile = nodes.filter(node => this.isActivatedProfile(node));\n        nodesWithActiveProfile.forEach(node => {\n            const parentNode = node.parentNode;\n            if (parentNode) {\n                const { plugin } = this.toObject(parentNode);\n                if ('amps-maven-plugin' === plugin?.artifactId) {\n                    const { configuration } = plugin || {};\n                    if (configuration?.products) {\n                        if (Array.isArray(configuration?.products)) {\n                            configuration.products.forEach((product) => {\n                                const supportedApplication = this.getSupportedApplication(product.id) || this.getSupportedApplication(product.instanceId);\n                                if (supportedApplication) {\n                                    const version = this.doPropertyReplacement(product.version);\n                                    if (version) {\n                                        result.set(supportedApplication, version);\n                                    }\n                                }\n                            });\n                        }\n                        else {\n                            const { product } = configuration?.products || {};\n                            if (product) {\n                                const supportedApplication = this.getSupportedApplication(product.id) || this.getSupportedApplication(product.instanceId);\n                                if (supportedApplication) {\n                                    const version = this.doPropertyReplacement(product.version);\n                                    if (version) {\n                                        result.set(supportedApplication, version);\n                                    }\n                                }\n                            }\n                        }\n                    }\n                }\n                else {\n                    const supportedApplication = this.getSupportedApplication(plugin?.artifactId);\n                    const version = this.getVersion(node);\n                    if (supportedApplication) {\n                        result.set(supportedApplication, version);\n                    }\n                }\n            }\n        });\n        return result;\n    }\n    // ------------------------------------------------------------------------------------------ Private Methods\n    getSupportedApplication(value) {\n        if (value?.includes(SupportedApplications.Values.jira)) {\n            return SupportedApplications.Values.jira;\n        }\n        else if (value?.includes(SupportedApplications.Values.confluence)) {\n            return SupportedApplications.Values.confluence;\n        }\n        else if (value?.includes(SupportedApplications.Values.bamboo)) {\n            return SupportedApplications.Values.bamboo;\n        }\n        else if (value?.includes(SupportedApplications.Values.bitbucket)) {\n            return SupportedApplications.Values.bitbucket;\n        }\n        return null;\n    }\n    getVersion(node) {\n        const parentNode = node.parentNode;\n        if (parentNode) {\n            const { plugin } = this.toObject(parentNode);\n            const { configuration } = plugin || {};\n            if (configuration?.productVersion) {\n                return this.doPropertyReplacement(plugin.configuration.productVersion);\n            }\n            else if (configuration?.products) {\n                const product = Array.isArray(configuration?.products) ? configuration?.products[0] : configuration.products.product;\n                if (product && product.version) {\n                    return this.doPropertyReplacement(product.version);\n                }\n            }\n        }\n        return undefined;\n    }\n    doPropertyReplacement(value) {\n        let result = value;\n        // If there is a profile, replace profile properties first as they take precedence\n        const profileProperties = this.getProperties();\n        Object.entries(profileProperties).forEach(([propertyKey, propertyValue]) => {\n            result = result.replaceAll(`$\\{${propertyKey}}`, propertyValue);\n        });\n        const properties = this.getProperties();\n        Object.entries(properties).forEach(([propertyKey, propertyValue]) => {\n            result = result.replaceAll(`$\\{${propertyKey}}`, propertyValue);\n        });\n        return result;\n    }\n    getProperties() {\n        const result = {};\n        const nodes = this.getNodes('//*[local-name()=\\'properties\\']');\n        const nodesWithActiveProfile = nodes.filter(node => this.isActivatedProfile(node));\n        nodesWithActiveProfile.forEach(node => {\n            const { properties } = this.toObject(node);\n            Object.entries(properties).forEach(([key, value]) => result[key] = value);\n        });\n        return result;\n    }\n    getNodes(expression, single) {\n        const pomFilePath = join(this.options?.cwd || cwd(), './pom.xml');\n        const hasPomFile = existsSync(pomFilePath);\n        if (hasPomFile) {\n            const xml = readFileSync(pomFilePath, 'utf8');\n            const doc = new DOMParser().parseFromString(xml, 'text/xml');\n            const nodes = single ? xpath.select(expression, doc, true) : xpath.select(expression, doc, false);\n            if (Array.isArray(nodes)) {\n                return nodes;\n            }\n            else if (single) {\n                return nodes;\n            }\n            else {\n                return [];\n            }\n        }\n        return [];\n    }\n    toObject(node) {\n        try {\n            const parser = new XMLParser();\n            return parser.parse(new XMLSerializer().serializeToString(node));\n        }\n        catch (err) {\n            return null;\n        }\n    }\n    findParentNodeByTagName(tagName, node) {\n        const { parentNode } = node;\n        if (parentNode) {\n            if (parentNode.nodeName.toLowerCase() === tagName.toLowerCase()) {\n                return parentNode;\n            }\n            return this.findParentNodeByTagName(tagName, parentNode);\n        }\n        return null;\n    }\n    isActivatedProfile(node) {\n        const profileParentNode = this.findParentNodeByTagName('profile', node);\n        const profileNode = profileParentNode ? this.toObject(profileParentNode) : null;\n        if (!profileNode) {\n            return true;\n        }\n        else if (profileNode && (profileNode.activeByDefault === 'true' || this.options.profiles.includes(profileNode.profile.id))) {\n            return true;\n        }\n        else {\n            return false;\n        }\n    }\n}\n","export const isRecursiveBuild = (lastBuildCompleted) => lastBuildCompleted > (new Date().getTime() - 5 * 1000);\n","export const showRecursiveBuildWarning = (outputDirectory) => {\n    console.log(`\n===============================================================================================================\nRecursive build trigger detected. The last build completed last than 5 seconds ago\nThis may indicate that the build changes files outside of the output directory\nAlternatively, Maven is using a different output directory than configured:\n'${outputDirectory}'\n\nPlease make sure to check your build process and/or specify a different output directory using the '-o' option\n===============================================================================================================`);\n};\n","import { execSync } from 'child_process';\nimport { cwd } from 'process';\nexport class CustomBuilder {\n    options;\n    proc = null;\n    // ------------------------------------------------------------------------------------------ Constructor\n    constructor(options) {\n        this.options = options;\n    }\n    // ------------------------------------------------------------------------------------------ Public Methods\n    stop() {\n        if (this.proc) {\n            const killed = this.proc.kill(0);\n            if (!killed) {\n                throw new Error('Failed to terminate existing build process');\n            }\n        }\n    }\n    async build() {\n        return new Promise((resolve, reject) => {\n            if (this.proc) {\n                const killed = this.proc.kill(0);\n                if (!killed) {\n                    reject(new Error('Failed to terminate existing build process'));\n                }\n            }\n            try {\n                execSync(this.options.cmd, { cwd: this.options?.cwd || cwd(), stdio: 'inherit' });\n                resolve();\n            }\n            catch (err) {\n                const { status } = err;\n                reject(new Error(`Build exited with code ${status}`));\n            }\n        });\n    }\n}\n","import { spawn } from 'child_process';\nimport Dockerode from 'dockerode';\nimport { cwd } from 'process';\nconst docker = new Dockerode();\nexport const getRunningContainerIds = async (application) => {\n    const containers = await docker.listContainers({ filters: {\n            status: ['running'],\n            label: [`com.docker.compose.service=${application}`]\n        } });\n    return containers.map(item => item.Id);\n};\nexport const copy = async (sourcePath, destinationPath) => {\n    return new Promise((resolve, reject) => {\n        const docker = spawn('docker', ['cp', sourcePath, destinationPath], { cwd: cwd(), stdio: 'inherit' });\n        docker.on('error', reject);\n        docker.on('exit', (code) => (code === 0) ? resolve() : reject(new Error(`Docker exited with code ${code}`)));\n    });\n};\n","import { resolve as resolvePath } from 'path';\nimport { cwd } from 'process';\nimport * as Docker from './docker';\nimport { uploadToUPM } from './upm';\nexport const Installer = async (name, path, options) => {\n    const containerIds = await Docker.getRunningContainerIds(name);\n    if (!containerIds || containerIds.length <= 0) {\n        console.log(`There are no running instance of ${name}, unable to install plugin 🤔`);\n        return;\n    }\n    else if (containerIds.length > 1) {\n        console.log(`There are multple running instance of ${name}, unable to determine which one to use 🤔`);\n        return;\n    }\n    const containerId = containerIds[0];\n    if (containerId) {\n        if (options.obr) {\n            console.log(`Found updated plugin, uploading it to UPM on running instances of ${name}`);\n            const hostUrl = options.port ? `localhost:${options.port}` : `localhost`;\n            const baseUrl = options.username && options.password ? `http://${options.username}:${options.password}@${hostUrl}` : `http://${hostUrl}`;\n            await uploadToUPM(resolvePath(options.cwd || cwd(), path), baseUrl).catch(err => {\n                console.log('Failed to upload plugin archive file to UPM', err);\n            });\n        }\n        else {\n            console.log(`Found updated plugin, uploading it to QuickReload on running instances of ${name}`);\n            await Docker.copy(resolvePath(options.cwd || cwd(), path), `${containerId}:/opt/quickreload/`)\n                .then(() => console.log('Finished uploading plugin archive to QuickReload'))\n                .catch(err => console.log('Failed to upload plugin archive file to QuickReload', err));\n        }\n    }\n};\n","import { watch } from 'chokidar';\nimport { cwd } from 'process';\nimport { isRecursiveBuild } from '../helpers/isRecursiveBuild';\nimport { showRecursiveBuildWarning } from '../helpers/showRecursiveBuildWarning';\nimport { AMPS } from './amps';\nimport { CustomBuilder } from './CustomBuilder';\nimport { Installer } from './Installer';\nexport const FileWatcher = (name, options, mavenOpts, installOnly = false) => {\n    let lastBuildCompleted = new Date().getTime();\n    const outputDirectory = options.outputDirectory || 'target';\n    const patterns = options.ext || ['**/*'];\n    console.log(`Watching filesystem for changes to source files (${patterns.join(', ')})`);\n    const amps = new AMPS({\n        cwd: options.cwd,\n        profiles: options.activateProfiles?.split(',') || []\n    });\n    const deliverableExtension = options.obr ? '.obr' : '.jar';\n    return watch(patterns, {\n        cwd: options.cwd || cwd(),\n        usePolling: true,\n        interval: 2 * 1000,\n        binaryInterval: 2 * 1000,\n        awaitWriteFinish: true,\n        persistent: true,\n        atomic: true\n    }).on('change', async (path) => {\n        if (options.install && path.startsWith(outputDirectory) && path.toLowerCase().endsWith(deliverableExtension)) {\n            await Installer(name, path, options);\n        }\n        else if (!path.startsWith(outputDirectory) && !installOnly) {\n            if (isRecursiveBuild(lastBuildCompleted)) {\n                showRecursiveBuildWarning(outputDirectory);\n            }\n            else {\n                console.log('Detected file change, rebuilding Atlasian Data Center plugin');\n                if (!options.exec) {\n                    await amps.build(mavenOpts).then(() => {\n                        console.log(`Finished building Atlassian Data Center plugin for ${name}... 💪`);\n                    }).catch(() => {\n                        console.log(`Failed to build Atlassian Data Center plugin for ${name}... 😰`);\n                    });\n                }\n                else {\n                    const builder = new CustomBuilder({ cmd: options.exec, cwd: options.cwd || cwd() });\n                    await builder.build().then(() => {\n                        console.log(`Finished building Atlassian Data Center plugin for ${name}... 💪`);\n                    }).catch(() => {\n                        console.log(`Failed to build Atlassian Data Center plugin for ${name}... 😰`);\n                    });\n                }\n                lastBuildCompleted = new Date().getTime();\n            }\n        }\n    });\n};\n","import { realpathSync } from 'fs';\nimport { dirname, join } from 'path';\nexport const toAbsolutePath = (relativePath) => {\n    const [, filePath] = process.argv;\n    const executableFileDir = dirname(realpathSync(filePath));\n    const basedir = executableFileDir.substring(0, executableFileDir.indexOf('dcdx') + 4);\n    return join(basedir, relativePath.replaceAll('../', ''));\n};\n","import { readFileSync } from 'fs';\nimport { toAbsolutePath } from './toAbsolutePath';\nexport const getVersions = () => {\n    const content = readFileSync(toAbsolutePath('../../assets/versions.json'), 'utf-8');\n    const versions = JSON.parse(content);\n    return versions;\n};\n","#!/usr/bin/env node\nimport { Command as Commander, InvalidOptionArgumentError, Option } from 'commander';\nimport { gracefulExit } from 'exit-hook';\nimport { glob } from 'glob';\nimport { resolve } from 'path';\nimport { cwd } from 'process';\nimport { getAppLicense } from '../apt/helpers/getAppLicense';\nimport { installApp } from '../apt/helpers/installApp';\nimport { ActionHandler } from '../helpers/ActionHandler';\nimport { AMPS } from '../helpers/amps';\nimport { FileWatcher } from '../helpers/FileWatcher';\nimport { getVersions } from '../helpers/getVersions';\nimport { Installer } from '../helpers/Installer';\nconst program = new Commander();\nconst versions = getVersions();\nconst Command = () => {\n    let quickReload = null;\n    return {\n        action: async (options) => {\n            const amps = new AMPS({\n                cwd: options.cwd,\n                profiles: options.activateProfiles?.split(',') || []\n            });\n            if (options.mpac) {\n                if (!options.baseUrl) {\n                    throw new InvalidOptionArgumentError('Missing argument \"--baseUrl\", required for installing from the Atlassian Marketplace');\n                }\n                else if (!options.appKey) {\n                    throw new InvalidOptionArgumentError('Missing argument \"--appKey\", required for installing from the Atlassian Marketplace');\n                }\n                await installApp({\n                    baseUrl: options.baseUrl,\n                    appKey: options.appKey,\n                    license: await getAppLicense(options.license, true),\n                    username: options.username,\n                    password: options.password,\n                    restartAfterInstall: false,\n                    force: true\n                });\n            }\n            else {\n                if (!amps.isAtlassianPlugin()) {\n                    throw new Error('Unable to find an Atlassian Plugin project in the current directory 🤔');\n                }\n                const name = amps.getApplication();\n                if (!name) {\n                    throw new Error('The Atlassian Plugin project does not contain an AMPS configuration, unable to detect product 😰');\n                }\n                const version = amps.getApplicationVersion();\n                if (!version) {\n                    throw new Error('Failed to determine version from AMPS and no product version provided (--tag)');\n                }\n                else if (!versions[name].includes(version)) {\n                    throw new Error(`Product version '${version}' is invalid. Allowed choices are ${versions[name].join(', ')}.`);\n                }\n                if (options.obr && !options.username) {\n                    throw new InvalidOptionArgumentError('Missing argument \"--username\", required for installing OBR artifacts');\n                }\n                else if (options.obr && !options.password) {\n                    throw new InvalidOptionArgumentError('Missing argument \"--password\", required for installing OBR artifacts');\n                }\n                if (options.watch) {\n                    quickReload = FileWatcher(name, options, [], true);\n                }\n                const outputDirectory = options.outputDirectory || 'target';\n                const deliverableExtension = options.obr ? 'obr' : 'jar';\n                const files = await glob(`${outputDirectory}/*.${deliverableExtension}`, { cwd: resolve(options.cwd || cwd()) });\n                await Promise.all(files.map(path => Installer(name, path, options)));\n            }\n        },\n        errorHandler: async () => {\n            if (quickReload) {\n                console.log(`Stopping filesystem watcher... ⏳`);\n                await quickReload.close().catch(() => null);\n            }\n            console.log(`Successfully stopped all running processes 💪`);\n        }\n    };\n};\nprogram\n    .name('dcdx install')\n    .description(`Install the Atlassian Data Center plugin using the Atlassian Maven Plugin Suite (AMPS) configuration.\nIf there is a running instance, it will try to install the plugin using QuickReload or the UPM (for OBR).`)\n    .showHelpAfterError(true)\n    .addOption(new Option('-w, --watch', 'Watch for filesystem changes to JAR or OBR files in the current working directory').default(false))\n    .addOption(new Option('-o, --outputDirectory <directory>', 'Output directory where to look for generated JAR or OBR files (defaults to `target`)'))\n    .addOption(new Option('-P, --activate-profiles <arg>', 'Comma-delimited list of profiles to activate'))\n    .addOption(new Option('--obr', 'Upload generated OBR file instead of JAR file when installing the app').default(false))\n    .addOption(new Option('--username <username>', 'The username of the administrator (required with --obr, optional for --mpac)'))\n    .addOption(new Option('--password <password>', 'The password of the administrator (required with --obr, optional for --mpac)'))\n    .addOption(new Option('--mpac', 'Install the app from the Atlassian Marketplace'))\n    .addOption(new Option('--baseUrl <url>', 'URL of the instance (required with --mpac)'))\n    .addOption(new Option('--appKey <key>', 'The key of the app to be installed (required with --mpac)'))\n    .addOption(new Option('--license <path_or_license>', 'The app license, either as a path to a file or the license itself'))\n    .addOption(new Option('--cwd <directory>', 'Specify the working directory where to find the AMPS configuration'))\n    .action(options => ActionHandler(program, Command(), { ...options, install: true }));\nprogram.parseAsync(process.argv).catch(() => gracefulExit(1));\nprocess.on('SIGINT', () => {\n    console.log(`Received term signal, trying to stop gracefully 💪`);\n    gracefulExit(1);\n});\n"],"names":["cwd","pwd","password","passwordPrompt","versions","Docker.getRunningContainerIds","resolvePath","Docker.copy","Commander"],"mappings":"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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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"}