appium 2.0.0-beta.30 → 2.0.0-beta.35

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/build/lib/appium.d.ts +1 -1
  2. package/build/lib/appium.d.ts.map +1 -1
  3. package/build/lib/appium.js +5 -2
  4. package/build/lib/cli/args.js +1 -1
  5. package/build/lib/cli/driver-command.d.ts +3 -3
  6. package/build/lib/cli/driver-command.d.ts.map +1 -1
  7. package/build/lib/cli/driver-command.js +8 -8
  8. package/build/lib/cli/extension-command.d.ts +22 -17
  9. package/build/lib/cli/extension-command.d.ts.map +1 -1
  10. package/build/lib/cli/extension-command.js +35 -36
  11. package/build/lib/cli/extension.js +1 -1
  12. package/build/lib/cli/parser.d.ts +3 -2
  13. package/build/lib/cli/parser.d.ts.map +1 -1
  14. package/build/lib/cli/parser.js +1 -1
  15. package/build/lib/cli/plugin-command.d.ts +9 -15
  16. package/build/lib/cli/plugin-command.d.ts.map +1 -1
  17. package/build/lib/cli/plugin-command.js +8 -8
  18. package/build/lib/cli/utils.js +1 -1
  19. package/build/lib/config-file.js +1 -1
  20. package/build/lib/config.d.ts +5 -4
  21. package/build/lib/config.d.ts.map +1 -1
  22. package/build/lib/config.js +1 -1
  23. package/build/lib/constants.js +1 -1
  24. package/build/lib/extension/driver-config.js +1 -1
  25. package/build/lib/extension/extension-config.js +1 -1
  26. package/build/lib/extension/index.js +1 -1
  27. package/build/lib/extension/manifest.d.ts.map +1 -1
  28. package/build/lib/extension/manifest.js +1 -1
  29. package/build/lib/extension/package-changed.js +1 -1
  30. package/build/lib/extension/plugin-config.js +1 -1
  31. package/build/lib/grid-register.js +1 -1
  32. package/build/lib/logger.js +1 -1
  33. package/build/lib/logsink.js +1 -1
  34. package/build/lib/main.d.ts +13 -10
  35. package/build/lib/main.d.ts.map +1 -1
  36. package/build/lib/main.js +57 -50
  37. package/build/lib/schema/arg-spec.js +1 -1
  38. package/build/lib/schema/cli-args.js +1 -1
  39. package/build/lib/schema/cli-transformers.js +1 -1
  40. package/build/lib/schema/index.js +1 -1
  41. package/build/lib/schema/keywords.js +1 -1
  42. package/build/lib/schema/schema.js +1 -1
  43. package/build/lib/utils.js +1 -1
  44. package/build/tsconfig.tsbuildinfo +1 -1
  45. package/build/types/appium-manifest.d.ts +40 -0
  46. package/build/types/appium-manifest.d.ts.map +1 -0
  47. package/build/types/cli.d.ts +112 -0
  48. package/build/types/cli.d.ts.map +1 -0
  49. package/build/types/extension.d.ts +43 -0
  50. package/build/types/extension.d.ts.map +1 -0
  51. package/build/types/external-manifest.d.ts +47 -0
  52. package/build/types/external-manifest.d.ts.map +1 -0
  53. package/build/types/index.d.ts +15 -0
  54. package/build/types/index.d.ts.map +1 -0
  55. package/lib/appium.js +7 -3
  56. package/lib/cli/driver-command.js +45 -20
  57. package/lib/cli/extension-command.js +229 -123
  58. package/lib/cli/parser.js +2 -1
  59. package/lib/cli/plugin-command.js +33 -18
  60. package/lib/config.js +6 -5
  61. package/lib/extension/manifest.js +0 -2
  62. package/lib/main.js +78 -63
  63. package/package.json +20 -14
  64. package/types/{appium-manifest.d.ts → appium-manifest.ts} +1 -1
  65. package/types/{cli.d.ts → cli.ts} +48 -29
  66. package/types/{extension.d.ts → extension.ts} +4 -4
  67. package/types/{external-manifest.d.ts → external-manifest.ts} +2 -2
  68. package/types/{index.d.ts → index.ts} +7 -0
  69. package/lib/appium-config.schema.json +0 -278
@@ -63,7 +63,7 @@ export type RunOptions = {
63
63
  /**
64
64
  * - name of the extension to run a script from
65
65
  */
66
- ext: string;
66
+ installSpec: string;
67
67
  /**
68
68
  * - name of the script to run
69
69
  */
@@ -89,7 +89,7 @@ export type ExtensionUpdateOpts = {
89
89
  /**
90
90
  * - the name of the extension to update
91
91
  */
92
- ext: string;
92
+ installSpec: string;
93
93
  /**
94
94
  * - if true, will perform unsafe updates past major revision boundaries
95
95
  */
@@ -128,7 +128,7 @@ export type UninstallOpts = {
128
128
  /**
129
129
  * - the name or spec of an extension to uninstall
130
130
  */
131
- ext: string;
131
+ installSpec: string;
132
132
  };
133
133
  /**
134
134
  * Used by {@linkcode ExtensionCommand.getPostInstallText }
@@ -150,7 +150,7 @@ export type InstallViaNpmArgs = {
150
150
  /**
151
151
  * - the name or spec of an extension to install
152
152
  */
153
- ext: string;
153
+ installSpec: string;
154
154
  /**
155
155
  * - the NPM package name of the extension
156
156
  */
@@ -184,7 +184,7 @@ export type InstallArgs = {
184
184
  /**
185
185
  * - the name or spec of an extension to install
186
186
  */
187
- ext: string;
187
+ installSpec: string;
188
188
  /**
189
189
  * - how to install this extension. One of the INSTALL_TYPES
190
190
  */
@@ -264,13 +264,13 @@ export class ExtensionCommand<ExtType extends import("../../types").ExtensionTyp
264
264
  * @param {InstallArgs} args
265
265
  * @return {Promise<ExtRecord<ExtType>>} map of all installed extension names to extension data
266
266
  */
267
- _install({ ext, installType, packageName }: InstallArgs): Promise<ExtRecord<ExtType>>;
267
+ _install({ installSpec, installType, packageName }: InstallArgs): Promise<ExtRecord<ExtType>>;
268
268
  /**
269
269
  * Install an extension via NPM
270
270
  *
271
271
  * @param {InstallViaNpmArgs} args
272
272
  */
273
- installViaNpm({ ext, pkgName, pkgVer }: InstallViaNpmArgs): Promise<ExtensionFields<ExtType>>;
273
+ installViaNpm({ installSpec, pkgName, pkgVer }: InstallViaNpmArgs): Promise<ExtensionFields<ExtType>>;
274
274
  /**
275
275
  * Get the text which should be displayed to the user after an extension has been installed. This
276
276
  * is designed to be overridden by drivers/plugins with their own particular text.
@@ -285,33 +285,38 @@ export class ExtensionCommand<ExtType extends import("../../types").ExtensionTyp
285
285
  * load as the main driver class, or to be able to detect incompatibilities between driver and
286
286
  * appium versions.
287
287
  *
288
- * @param {ExtPackageJson<ExtType>} pkgJsonData - the package.json data for a driver module, as if it had been
289
- * straightforwardly 'require'd
288
+ * @param {ExtPackageJson<ExtType>} pkgJsonData - the package.json data for a driver module, as if it had been straightforwardly 'require'd
289
+ * @param {string} installSpec
290
290
  * @returns {ExtensionFields<ExtType>}
291
291
  */
292
- getExtensionFields(pkgJsonData: ExtPackageJson<ExtType>): ExtensionFields<ExtType>;
292
+ getExtensionFields(pkgJsonData: ExtPackageJson<ExtType>, installSpec: string): ExtensionFields<ExtType>;
293
293
  /**
294
294
  * For any package.json fields which a particular type of extension requires, validate the
295
295
  * presence and form of those fields on the package.json data, throwing an error if anything is
296
+
297
+ /**
298
+ * For any `package.json` fields which a particular type of extension requires, validate the
299
+ * presence and form of those fields on the `package.json` data, throwing an error if anything is
296
300
  * amiss.
297
301
  *
298
- * @param {ExtMetadata<ExtType>} appiumPkgData - the data in the "appium" field of package.json for an extension
302
+ * @param {ExtMetadata<ExtType>} extMetadata - the data in the "appium" field of `package.json` for an extension
303
+ * @param {string} installSpec - Extension name/spec
299
304
  */
300
- validateExtensionFields(appiumPkgData: ExtMetadata<ExtType>): void;
305
+ validateExtensionFields(extMetadata: ExtMetadata<ExtType>, installSpec: string): void;
301
306
  /**
302
307
  * Uninstall an extension
303
308
  *
304
309
  * @param {UninstallOpts} opts
305
310
  * @return {Promise<ExtRecord<ExtType>>} map of all installed extension names to extension data
306
311
  */
307
- _uninstall({ ext }: UninstallOpts): Promise<ExtRecord<ExtType>>;
312
+ _uninstall({ installSpec }: UninstallOpts): Promise<ExtRecord<ExtType>>;
308
313
  /**
309
314
  * Attempt to update one or more drivers using NPM
310
315
  *
311
316
  * @param {ExtensionUpdateOpts} updateSpec
312
317
  * @return {Promise<ExtensionUpdateResult>}
313
318
  */
314
- _update({ ext, unsafe }: ExtensionUpdateOpts): Promise<ExtensionUpdateResult>;
319
+ _update({ installSpec, unsafe }: ExtensionUpdateOpts): Promise<ExtensionUpdateResult>;
315
320
  /**
316
321
  * Given an extension name, figure out what its highest possible version upgrade is, and also the
317
322
  * highest possible safe upgrade.
@@ -324,11 +329,11 @@ export class ExtensionCommand<ExtType extends import("../../types").ExtensionTyp
324
329
  * Actually update an extension installed by NPM, using the NPM cli. And update the installation
325
330
  * manifest.
326
331
  *
327
- * @param {string} ext - name of extension to update
332
+ * @param {string} installSpec - name of extension to update
328
333
  * @param {string} version - version string identifier to update extension to
329
334
  * @returns {Promise<void>}
330
335
  */
331
- updateExtension(ext: string, version: string): Promise<void>;
336
+ updateExtension(installSpec: string, version: string): Promise<void>;
332
337
  /**
333
338
  * Runs a script cached inside the "scripts" field under "appium"
334
339
  * inside of the driver/plugins "package.json" file. Will throw
@@ -340,6 +345,6 @@ export class ExtensionCommand<ExtType extends import("../../types").ExtensionTyp
340
345
  * @param {RunOptions} opts
341
346
  * @return {Promise<RunOutput>}
342
347
  */
343
- _run({ ext, scriptName }: RunOptions): Promise<RunOutput>;
348
+ _run({ installSpec, scriptName }: RunOptions): Promise<RunOutput>;
344
349
  }
345
350
  //# sourceMappingURL=extension-command.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"extension-command.d.ts","sourceRoot":"","sources":["../../../lib/cli/extension-command.js"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"extension-command.d.ts","sourceRoot":"","sources":["../../../lib/cli/extension-command.js"],"names":[],"mappings":"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"}
@@ -157,12 +157,11 @@ class ExtensionCommand {
157
157
  }
158
158
 
159
159
  async _install({
160
- ext,
160
+ installSpec,
161
161
  installType,
162
162
  packageName
163
163
  }) {
164
164
  let extData;
165
- let installSpec = ext;
166
165
 
167
166
  if (packageName && [_extensionConfig.INSTALL_TYPE_LOCAL, _extensionConfig.INSTALL_TYPE_NPM].includes(installType)) {
168
167
  throw new Error(`When using --source=${installType}, cannot also use --package`);
@@ -178,13 +177,13 @@ class ExtensionCommand {
178
177
  }
179
178
 
180
179
  extData = await this.installViaNpm({
181
- ext: installSpec,
180
+ installSpec,
182
181
  pkgName: packageName
183
182
  });
184
183
  } else if (installType === _extensionConfig.INSTALL_TYPE_GIT) {
185
184
  installSpec = installSpec.replace(/\.git$/, '');
186
185
  extData = await this.installViaNpm({
187
- ext: installSpec,
186
+ installSpec,
188
187
  pkgName: packageName
189
188
  });
190
189
  } else {
@@ -218,7 +217,7 @@ class ExtensionCommand {
218
217
  }
219
218
 
220
219
  extData = await this.installViaNpm({
221
- ext,
220
+ installSpec,
222
221
  pkgName,
223
222
  pkgVer
224
223
  });
@@ -249,19 +248,19 @@ class ExtensionCommand {
249
248
  }
250
249
 
251
250
  async installViaNpm({
252
- ext,
251
+ installSpec,
253
252
  pkgName,
254
253
  pkgVer
255
254
  }) {
256
255
  const npmSpec = `${pkgName}${pkgVer ? '@' + pkgVer : ''}`;
257
- const specMsg = npmSpec === ext ? '' : ` using NPM install spec '${npmSpec}'`;
258
- const msg = `Installing '${ext}'${specMsg}`;
256
+ const specMsg = npmSpec === installSpec ? '' : ` using NPM install spec '${npmSpec}'`;
257
+ const msg = `Installing '${installSpec}'${specMsg}`;
259
258
 
260
259
  try {
261
260
  const pkgJsonData = await (0, _utils.spinWith)(this.isJsonOutput, msg, async () => await _support.npm.installPackage(this.config.appiumHome, pkgName, {
262
261
  pkgVer
263
262
  }));
264
- return this.getExtensionFields(pkgJsonData);
263
+ return this.getExtensionFields(pkgJsonData, installSpec);
265
264
  } catch (err) {
266
265
  throw new Error(`Encountered an error when installing package: ${err.message}`);
267
266
  }
@@ -271,7 +270,7 @@ class ExtensionCommand {
271
270
  throw new Error('Must be implemented in final class');
272
271
  }
273
272
 
274
- getExtensionFields(pkgJsonData) {
273
+ getExtensionFields(pkgJsonData, installSpec) {
275
274
  if (!pkgJsonData.appium) {
276
275
  throw new Error(`Installed driver did not have an 'appium' section in its ` + `package.json file as expected`);
277
276
  }
@@ -281,7 +280,7 @@ class ExtensionCommand {
281
280
  name,
282
281
  version
283
282
  } = pkgJsonData;
284
- this.validateExtensionFields(appium);
283
+ this.validateExtensionFields(appium, installSpec);
285
284
  const result = { ...appium,
286
285
  pkgName: name,
287
286
  version
@@ -289,40 +288,40 @@ class ExtensionCommand {
289
288
  return result;
290
289
  }
291
290
 
292
- validateExtensionFields(appiumPkgData) {
291
+ validateExtensionFields(extMetadata, installSpec) {
293
292
  throw new Error('Must be implemented in final class');
294
293
  }
295
294
 
296
295
  async _uninstall({
297
- ext
296
+ installSpec
298
297
  }) {
299
- if (!this.config.isInstalled(ext)) {
300
- throw new Error(`Can't uninstall ${this.type} '${ext}'; it is not installed`);
298
+ if (!this.config.isInstalled(installSpec)) {
299
+ throw new Error(`Can't uninstall ${this.type} '${installSpec}'; it is not installed`);
301
300
  }
302
301
 
303
- const installPath = this.config.getInstallPath(ext);
302
+ const installPath = this.config.getInstallPath(installSpec);
304
303
 
305
304
  try {
306
305
  await _support.fs.rimraf(installPath);
307
306
  } finally {
308
- await this.config.removeExtension(ext);
307
+ await this.config.removeExtension(installSpec);
309
308
  }
310
309
 
311
- (0, _utils.log)(this.isJsonOutput, `Successfully uninstalled ${this.type} '${ext}'`.green);
310
+ (0, _utils.log)(this.isJsonOutput, `Successfully uninstalled ${this.type} '${installSpec}'`.green);
312
311
  return this.config.installedExtensions;
313
312
  }
314
313
 
315
314
  async _update({
316
- ext,
315
+ installSpec,
317
316
  unsafe
318
317
  }) {
319
- const shouldUpdateAll = ext === UPDATE_ALL;
318
+ const shouldUpdateAll = installSpec === UPDATE_ALL;
320
319
 
321
- if (!shouldUpdateAll && !this.config.isInstalled(ext)) {
322
- throw new Error(`The ${this.type} '${ext}' was not installed, so can't be updated`);
320
+ if (!shouldUpdateAll && !this.config.isInstalled(installSpec)) {
321
+ throw new Error(`The ${this.type} '${installSpec}' was not installed, so can't be updated`);
323
322
  }
324
323
 
325
- const extsToUpdate = shouldUpdateAll ? Object.keys(this.config.installedExtensions) : [ext];
324
+ const extsToUpdate = shouldUpdateAll ? Object.keys(this.config.installedExtensions) : [installSpec];
326
325
  const errors = {};
327
326
  const updates = {};
328
327
 
@@ -408,46 +407,46 @@ class ExtensionCommand {
408
407
  };
409
408
  }
410
409
 
411
- async updateExtension(ext, version) {
410
+ async updateExtension(installSpec, version) {
412
411
  const {
413
412
  pkgName
414
- } = this.config.installedExtensions[ext];
415
- await _support.fs.rimraf(this.config.getInstallPath(ext));
413
+ } = this.config.installedExtensions[installSpec];
414
+ await _support.fs.rimraf(this.config.getInstallPath(installSpec));
416
415
  const extData = await this.installViaNpm({
417
- ext,
416
+ installSpec,
418
417
  pkgName,
419
418
  pkgVer: version
420
419
  });
421
420
  delete extData[`${this.type}Name`];
422
- await this.config.updateExtension(ext, extData);
421
+ await this.config.updateExtension(installSpec, extData);
423
422
  }
424
423
 
425
424
  async _run({
426
- ext,
425
+ installSpec,
427
426
  scriptName
428
427
  }) {
429
- if (!_lodash.default.has(this.config.installedExtensions, ext)) {
428
+ if (!_lodash.default.has(this.config.installedExtensions, installSpec)) {
430
429
  throw new Error(`please install the ${this.type} first`);
431
430
  }
432
431
 
433
- const extConfig = this.config.installedExtensions[ext];
432
+ const extConfig = this.config.installedExtensions[installSpec];
434
433
 
435
434
  if (!extConfig.scripts) {
436
- throw new Error(`The ${this.type} named '${ext}' does not contain the ` + `"scripts" field underneath the "appium" field in its package.json`);
435
+ throw new Error(`The ${this.type} named '${installSpec}' does not contain the ` + `"scripts" field underneath the "appium" field in its package.json`);
437
436
  }
438
437
 
439
438
  const extScripts = extConfig.scripts;
440
439
 
441
440
  if (!_lodash.default.isPlainObject(extScripts)) {
442
- throw new Error(`The ${this.type} named '${ext}' "scripts" field must be a plain object`);
441
+ throw new Error(`The ${this.type} named '${installSpec}' "scripts" field must be a plain object`);
443
442
  }
444
443
 
445
444
  if (!_lodash.default.has(extScripts, scriptName)) {
446
- throw new Error(`The ${this.type} named '${ext}' does not support the script: '${scriptName}'`);
445
+ throw new Error(`The ${this.type} named '${installSpec}' does not support the script: '${scriptName}'`);
447
446
  }
448
447
 
449
448
  const runner = new _teen_process.SubProcess(process.execPath, [extScripts[scriptName]], {
450
- cwd: this.config.getInstallPath(ext)
449
+ cwd: this.config.getInstallPath(installSpec)
451
450
  });
452
451
  const output = new _utils.RingBuffer(50);
453
452
  runner.on('stream-line', line => {
@@ -476,4 +475,4 @@ class ExtensionCommand {
476
475
  exports.ExtensionCommand = ExtensionCommand;
477
476
  var _default = ExtensionCommand;
478
477
  exports.default = _default;
479
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/cli/extension-command.js"],"names":["UPDATE_ALL","NotUpdatableError","Error","NoUpdatesAvailableError","ExtensionCommand","config","knownExtensions","isJsonOutput","constructor","json","type","extensionType","execute","args","cmd","_","isFunction","executeCmd","bind","list","showInstalled","showUpdates","lsMsg","installedNames","Object","keys","installedExtensions","knownNames","exts","reduce","acc","name","includes","installed","pkgName","ext","data","toPairs","installType","INSTALL_TYPE_NPM","updates","checkForExtensionUpdate","updateVersion","safeUpdate","unsafeUpdateVersion","unsafeUpdate","upToDate","listData","installTxt","grey","updateTxt","upToDateTxt","unsafeUpdateTxt","installSpec","version","typeTxt","INSTALL_TYPE_GIT","INSTALL_TYPE_GITHUB","yellow","INSTALL_TYPE_LOCAL","magenta","green","cyan","console","log","_install","packageName","extData","split","length","installViaNpm","replace","pkgVer","path","isAbsolute","resolve","splits","msg","JSON","stringify","extName","isInstalled","extManifest","addExtension","env","hasAppiumDependency","appiumHome","getPostInstallText","npmSpec","specMsg","pkgJsonData","npm","installPackage","getExtensionFields","err","message","appium","validateExtensionFields","result","appiumPkgData","_uninstall","installPath","getInstallPath","fs","rimraf","removeExtension","_update","unsafe","shouldUpdateAll","extsToUpdate","errors","e","update","current","updateVer","updateExtension","from","to","red","getLatestVersion","getLatestSafeUpgradeVersion","util","compareVersions","_run","scriptName","has","extConfig","scripts","extScripts","isPlainObject","runner","SubProcess","process","execPath","cwd","output","RingBuffer","on","line","enqueue","start","join","getBuff","error"],"mappings":"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","sourcesContent":["/* eslint-disable no-console */\n\nimport _ from 'lodash';\nimport path from 'path';\nimport { npm, fs, util, env } from '@appium/support';\nimport { log, spinWith, RingBuffer } from './utils';\nimport { SubProcess } from 'teen_process';\nimport { INSTALL_TYPE_NPM, INSTALL_TYPE_GIT, INSTALL_TYPE_GITHUB,\n         INSTALL_TYPE_LOCAL } from '../extension/extension-config';\nimport { packageDidChange } from '../extension/package-changed';\n\nconst UPDATE_ALL = 'installed';\n\nclass NotUpdatableError extends Error {}\nclass NoUpdatesAvailableError extends Error {}\n\n/**\n * @template {ExtensionType} ExtType\n */\nclass ExtensionCommand {\n  /**\n   * This is the `DriverConfig` or `PluginConfig`, depending on `ExtType`.\n   * @type {ExtensionConfig<ExtType>}\n   */\n  config;\n\n  /**\n   * {@linkcode Record} of official plugins or drivers.\n   * @type {KnownExtensions<ExtType>}\n   */\n  knownExtensions;\n\n  /**\n   * If `true`, command output has been requested as JSON.\n   * @type {boolean}\n   */\n  isJsonOutput;\n\n  /**\n   * Build an ExtensionCommand\n   * @param {ExtensionCommandOptions<ExtType>} opts\n   */\n  constructor ({config, json}) {\n    this.config = config;\n    this.isJsonOutput = json;\n  }\n\n  /**\n   * `driver` or `plugin`, depending on the `ExtensionConfig`.\n   */\n  get type () {\n    return this.config.extensionType;\n  }\n\n  /**\n   * Take a CLI parse and run an extension command based on its type\n   *\n   * @param {object} args - a key/value object with CLI flags and values\n   * @return {Promise<object>} the result of the specific command which is executed\n   */\n  async execute (args) {\n    const cmd = args[`${this.type}Command`];\n    if (!_.isFunction(this[cmd])) {\n      throw new Error(`Cannot handle ${this.type} command ${cmd}`);\n    }\n    const executeCmd = this[cmd].bind(this);\n    return await executeCmd(args);\n  }\n\n  /**\n   * @typedef ListOptions\n   * @property {boolean} showInstalled - whether should show only installed extensions\n   * @property {boolean} showUpdates - whether should show available updates\n   */\n\n  /**\n   * List extensions\n   *\n   * @param {ListOptions} opts\n   * @return {Promise<ExtensionListData>} map of extension names to extension data\n   */\n  async list ({showInstalled, showUpdates}) {\n    const lsMsg = `Listing ${showInstalled ? 'installed' : 'available'} ${this.type}s`;\n    const installedNames = Object.keys(this.config.installedExtensions);\n    const knownNames = Object.keys(this.knownExtensions);\n    const exts = [...installedNames, ...knownNames].reduce((acc, name) => {\n      if (!acc[name]) {\n        if (installedNames.includes(name)) {\n          acc[name] = {...this.config.installedExtensions[name], installed: true};\n        } else if (!showInstalled) {\n          acc[name] = {pkgName: this.knownExtensions[name], installed: false};\n        }\n      }\n      return acc;\n    },\n    /**\n     * This accumulator contains either {@linkcode UninstalledExtensionLIstData} _or_\n     * {@linkcode InstalledExtensionListData} without upgrade information (which is added by the below code block)\n     * @type {Record<string,Partial<InstalledExtensionListData>|UninstalledExtensionListData>}\n     */({}));\n\n    // if we want to show whether updates are available, put that behind a spinner\n    await spinWith(this.isJsonOutput, lsMsg, async () => {\n      if (!showUpdates) {\n        return;\n      }\n      for (const [ext, data] of _.toPairs(exts)) {\n        if (!data.installed || data.installType !== INSTALL_TYPE_NPM) {\n          // don't need to check for updates on exts that aren't installed\n          // also don't need to check for updates on non-npm exts\n          continue;\n        }\n        const updates = await this.checkForExtensionUpdate(ext);\n        data.updateVersion = updates.safeUpdate;\n        data.unsafeUpdateVersion = updates.unsafeUpdate;\n        data.upToDate = updates.safeUpdate === null && updates.unsafeUpdate === null;\n      }\n    });\n\n    const listData = /** @type {ExtensionListData} */(exts);\n\n    // if we're just getting the data, short circuit return here since we don't need to do any\n    // formatting logic\n    if (this.isJsonOutput) {\n      return listData;\n    }\n\n    for (const [\n      name,\n      data\n    ] of _.toPairs(listData)) {\n      let installTxt = ' [not installed]'.grey;\n      let updateTxt = '';\n      let upToDateTxt = '';\n      let unsafeUpdateTxt = '';\n      if (data.installed) {\n        const {installType, installSpec, updateVersion, unsafeUpdateVersion, version, upToDate} = data;\n        let typeTxt;\n        switch (installType) {\n          case INSTALL_TYPE_GIT:\n          case INSTALL_TYPE_GITHUB:\n            typeTxt = `(cloned from ${installSpec})`.yellow;\n            break;\n          case INSTALL_TYPE_LOCAL:\n            typeTxt = `(linked from ${installSpec})`.magenta;\n            break;\n          default:\n            typeTxt = '(NPM)';\n        }\n        installTxt = `@${version.yellow} ${('[installed ' + typeTxt + ']').green}`;\n\n        if (showUpdates) {\n          if (updateVersion) {\n            updateTxt = ` [${updateVersion} available]`.magenta;\n          }\n          if (upToDate) {\n            upToDateTxt = ` [Up to date]`.green;\n          }\n          if (unsafeUpdateVersion) {\n            unsafeUpdateTxt = ` [${unsafeUpdateVersion} available (potentially unsafe)]`.cyan;\n          }\n        }\n      }\n\n      console.log(`- ${name.yellow}${installTxt}${updateTxt}${upToDateTxt}${unsafeUpdateTxt}`);\n    }\n\n    return listData;\n  }\n\n  /**\n   * Install an extension\n   *\n   * @param {InstallArgs} args\n   * @return {Promise<ExtRecord<ExtType>>} map of all installed extension names to extension data\n   */\n  async _install ({ext, installType, packageName}) {\n    let extData;\n    let installSpec = ext;\n\n    if (packageName && [INSTALL_TYPE_LOCAL, INSTALL_TYPE_NPM].includes(installType)) {\n      throw new Error(`When using --source=${installType}, cannot also use --package`);\n    }\n\n    if (!packageName && [INSTALL_TYPE_GIT, INSTALL_TYPE_GITHUB].includes(installType)) {\n      throw new Error(`When using --source=${installType}, must also use --package`);\n    }\n\n    if (installType === INSTALL_TYPE_GITHUB) {\n      if (installSpec.split('/').length !== 2) {\n        throw new Error(`Github ${this.type} spec ${installSpec} appeared to be invalid; ` +\n                        'it should be of the form <org>/<repo>');\n      }\n      extData = await this.installViaNpm({ext: installSpec, pkgName: /** @type {string} */(packageName)});\n    } else if (installType === INSTALL_TYPE_GIT) {\n      // git urls can have '.git' at the end, but this is not necessary and would complicate the\n      // way we download and name directories, so we can just remove it\n      installSpec = installSpec.replace(/\\.git$/, '');\n      extData = await this.installViaNpm({ext: installSpec, pkgName: /** @type {string} */(packageName)});\n    } else {\n      let pkgName, pkgVer;\n      if (installType === INSTALL_TYPE_LOCAL) {\n        pkgName = path.isAbsolute(installSpec) ? installSpec : path.resolve(installSpec);\n      } else {\n        // at this point we have either an npm package or an appium verified extension\n        // name or a local path. both of which will be installed via npm.\n        // extensions installed via npm can include versions or tags after the '@'\n        // sign, so check for that. We also need to be careful that package names themselves can\n        // contain the '@' symbol, as in `npm install @appium/fake-driver@1.2.0`\n        let name;\n        const splits = installSpec.split('@');\n        if (installSpec[0] === '@') {\n          // this is the case where we have an npm org included in the package name\n          [name, pkgVer] = [`@${splits[1]}`, splits[2]];\n        } else {\n          // this is the case without an npm org\n          [name, pkgVer] = splits;\n        }\n\n        if (installType === INSTALL_TYPE_NPM) {\n          // if we're installing a named package from npm, we don't need to check\n          // against the appium extension list; just use the installSpec as is\n          pkgName = name;\n        } else {\n          // if we're installing a named appium driver (like 'xcuitest') we need to\n          // dereference the actual npm package ('appiupm-xcuitest-driver'), so\n          // check it exists and get the correct package\n          const knownNames = Object.keys(this.knownExtensions);\n          if (!_.includes(knownNames, name)) {\n            const msg = `Could not resolve ${this.type}; are you sure it's in the list ` +\n                        `of supported ${this.type}s? ${JSON.stringify(knownNames)}`;\n            throw new Error(msg);\n          }\n          pkgName = this.knownExtensions[name];\n          // given that we'll use the install type in the driver json, store it as\n          // 'npm' now\n          installType = INSTALL_TYPE_NPM;\n        }\n      }\n\n      extData = await this.installViaNpm({ext, pkgName, pkgVer});\n    }\n\n    const extName = extData[/** @type {string} */(`${this.type}Name`)];\n    delete extData[/** @type {string} */(`${this.type}Name`)];\n\n    if (this.config.isInstalled(extName)) {\n      throw new Error(`A ${this.type} named '${extName}' is already installed. ` +\n                      `Did you mean to update? 'appium ${this.type} update'. See ` +\n                      `installed ${this.type}s with 'appium ${this.type} list --installed'.`);\n    }\n\n    const extManifest = {...extData, installType, installSpec};\n    await this.config.addExtension(extName, extManifest);\n\n    // update the if we've changed the local `package.json`\n    if (await env.hasAppiumDependency(this.config.appiumHome)) {\n      await packageDidChange(this.config.appiumHome);\n    }\n\n    // log info for the user\n    log(this.isJsonOutput, this.getPostInstallText({extName, extData}));\n\n    return this.config.installedExtensions;\n  }\n\n  /**\n   * Install an extension via NPM\n   *\n   * @param {InstallViaNpmArgs} args\n   */\n  async installViaNpm ({ext, pkgName, pkgVer}) {\n    const npmSpec = `${pkgName}${pkgVer ? '@' + pkgVer : ''}`;\n    const specMsg = npmSpec === ext ? '' : ` using NPM install spec '${npmSpec}'`;\n    const msg = `Installing '${ext}'${specMsg}`;\n    try {\n      const pkgJsonData = await spinWith(this.isJsonOutput, msg, async () => (\n        await npm.installPackage(this.config.appiumHome, pkgName, {\n          pkgVer\n        })\n      ));\n      return this.getExtensionFields(pkgJsonData);\n    } catch (err) {\n      throw new Error(`Encountered an error when installing package: ${err.message}`);\n    }\n  }\n\n  /**\n   * Get the text which should be displayed to the user after an extension has been installed. This\n   * is designed to be overridden by drivers/plugins with their own particular text.\n   *\n   * @param {ExtensionArgs} args\n   * @returns {string}\n   */\n  // eslint-disable-next-line no-unused-vars\n  getPostInstallText (args) {\n    throw new Error('Must be implemented in final class');\n  }\n\n  /**\n   * Take an NPM module's package.json and extract Appium driver information from a special\n   * 'appium' field in the JSON data. We need this information to e.g. determine which class to\n   * load as the main driver class, or to be able to detect incompatibilities between driver and\n   * appium versions.\n   *\n   * @param {ExtPackageJson<ExtType>} pkgJsonData - the package.json data for a driver module, as if it had been\n   * straightforwardly 'require'd\n   * @returns {ExtensionFields<ExtType>}\n   */\n  getExtensionFields (pkgJsonData) {\n    if (!pkgJsonData.appium) {\n      throw new Error(`Installed driver did not have an 'appium' section in its ` +\n                      `package.json file as expected`);\n    }\n    const {appium, name, version} = pkgJsonData;\n    this.validateExtensionFields(appium);\n    /** @type {unknown} */\n    const result = {...appium, pkgName: name, version};\n    return /** @type {ExtensionFields<ExtType>} */(result);\n  }\n\n  /**\n   * For any package.json fields which a particular type of extension requires, validate the\n   * presence and form of those fields on the package.json data, throwing an error if anything is\n   * amiss.\n   *\n   * @param {ExtMetadata<ExtType>} appiumPkgData - the data in the \"appium\" field of package.json for an extension\n   */\n  // eslint-disable-next-line no-unused-vars\n  validateExtensionFields (appiumPkgData) {\n    throw new Error('Must be implemented in final class');\n  }\n\n  /**\n   * Uninstall an extension\n   *\n   * @param {UninstallOpts} opts\n   * @return {Promise<ExtRecord<ExtType>>} map of all installed extension names to extension data\n   */\n  async _uninstall ({ext}) {\n    if (!this.config.isInstalled(ext)) {\n      throw new Error(`Can't uninstall ${this.type} '${ext}'; it is not installed`);\n    }\n    const installPath = this.config.getInstallPath(ext);\n    try {\n      await fs.rimraf(installPath);\n    } finally {\n      await this.config.removeExtension(ext);\n    }\n    log(this.isJsonOutput, `Successfully uninstalled ${this.type} '${ext}'`.green);\n    return this.config.installedExtensions;\n  }\n\n  /**\n   * Attempt to update one or more drivers using NPM\n   *\n   * @param {ExtensionUpdateOpts} updateSpec\n   * @return {Promise<ExtensionUpdateResult>}\n   */\n  async _update ({ext, unsafe}) {\n    const shouldUpdateAll = ext === UPDATE_ALL;\n    // if we're specifically requesting an update for an extension, make sure it's installed\n    if (!shouldUpdateAll && !this.config.isInstalled(ext)) {\n      throw new Error(`The ${this.type} '${ext}' was not installed, so can't be updated`);\n    }\n    const extsToUpdate = shouldUpdateAll ? Object.keys(this.config.installedExtensions) : [ext];\n\n    // 'errors' will have ext names as keys and error objects as values\n    /** @type {Record<string,Error>} */\n    const errors = {};\n\n    // 'updates' will have ext names as keys and update objects as values, where an update\n    // object is of the form {from: versionString, to: versionString}\n    /** @type {Record<string,UpdateReport>} */\n    const updates = {};\n\n    for (const e of extsToUpdate) {\n      try {\n        await spinWith(this.isJsonOutput, `Checking if ${this.type} '${e}' is updatable`, () => {\n          if (this.config.installedExtensions[e].installType !== INSTALL_TYPE_NPM) {\n            throw new NotUpdatableError();\n          }\n        });\n        const update = await spinWith(this.isJsonOutput, `Checking if ${this.type} '${e}' needs an update`, async () => {\n          const update = await this.checkForExtensionUpdate(e);\n          if (!(update.safeUpdate || update.unsafeUpdate)) {\n            throw new NoUpdatesAvailableError();\n          }\n          return update;\n        });\n        if (!unsafe && !update.safeUpdate) {\n          throw new Error(`The ${this.type} '${e}' has a major revision update ` +\n                          `(${update.current} => ${update.unsafeUpdate}), which could include ` +\n                          `breaking changes. If you want to apply this update, re-run with --unsafe`);\n        }\n        const updateVer = unsafe && update.unsafeUpdate ? update.unsafeUpdate : update.safeUpdate;\n        await spinWith(\n          this.isJsonOutput,\n          `Updating driver '${e}' from ${update.current} to ${updateVer}`,\n          async () => await this.updateExtension(e, updateVer)\n        );\n        updates[e] = {from: update.current, to: updateVer};\n      } catch (err) {\n        errors[e] = err;\n      }\n    }\n\n    log(this.isJsonOutput, 'Update report:');\n    for (const [e, update] of _.toPairs(updates)) {\n      log(this.isJsonOutput, `- ${this.type} ${e} updated: ${update.from} => ${update.to}`.green);\n    }\n    for (const [e, err] of _.toPairs(errors)) {\n      if (err instanceof NotUpdatableError) {\n        log(this.isJsonOutput, `- '${e}' was not installed via npm, so we could not check ` +\n                               `for updates`.yellow);\n      } else if (err instanceof NoUpdatesAvailableError) {\n        log(this.isJsonOutput, `- '${e}' had no updates available`.yellow);\n      } else {\n        // otherwise, make it pop with red!\n        log(this.isJsonOutput, `- '${e}' failed to update: ${err}`.red);\n      }\n    }\n\n    return {updates, errors};\n  }\n\n  /**\n   * Given an extension name, figure out what its highest possible version upgrade is, and also the\n   * highest possible safe upgrade.\n   *\n   * @param {string} ext - name of extension\n   * @return {Promise<PossibleUpdates>}\n   */\n  async checkForExtensionUpdate (ext) {\n    // TODO decide how we want to handle beta versions?\n    // this is a helper method, 'ext' is assumed to already be installed here, and of the npm\n    // install type\n    const {version, pkgName} = this.config.installedExtensions[ext];\n    let unsafeUpdate = await npm.getLatestVersion(this.config.appiumHome, pkgName);\n    let safeUpdate = await npm.getLatestSafeUpgradeVersion(this.config.appiumHome, pkgName, version);\n    if (!util.compareVersions(unsafeUpdate, '>', version)) {\n      // the latest version is not greater than the current version, so there's no possible update\n      unsafeUpdate = null;\n      safeUpdate = null;\n    }\n    if (unsafeUpdate && unsafeUpdate === safeUpdate) {\n      // the latest update is the same as the safe update, which means it's not actually unsafe\n      unsafeUpdate = null;\n    }\n    if (safeUpdate && !util.compareVersions(safeUpdate, '>', version)) {\n      // even the safe update is not later than the current, so it is not actually an update\n      safeUpdate = null;\n    }\n    return {current: version, safeUpdate, unsafeUpdate};\n  }\n\n  /**\n   * Actually update an extension installed by NPM, using the NPM cli. And update the installation\n   * manifest.\n   *\n   * @param {string} ext - name of extension to update\n   * @param {string} version - version string identifier to update extension to\n   * @returns {Promise<void>}\n   */\n  async updateExtension (ext, version) {\n    const {pkgName} = this.config.installedExtensions[ext];\n    await fs.rimraf(this.config.getInstallPath(ext));\n    const extData = await this.installViaNpm({ext, pkgName, pkgVer: version});\n    delete extData[/** @type {string} */(`${this.type}Name`)];\n    await this.config.updateExtension(ext, extData);\n  }\n\n  /**\n   * Runs a script cached inside the \"scripts\" field under \"appium\"\n   * inside of the driver/plugins \"package.json\" file. Will throw\n   * an error if the driver/plugin does not contain a \"scripts\" field\n   * underneath the \"appium\" field in its package.json, if the\n   * \"scripts\" field is not a plain object, or if the scriptName is\n   * not found within \"scripts\" object.\n   *\n   * @param {RunOptions} opts\n   * @return {Promise<RunOutput>}\n   */\n  async _run ({ext, scriptName}) {\n    if (!_.has(this.config.installedExtensions, ext)) {\n      throw new Error(`please install the ${this.type} first`);\n    }\n\n    const extConfig = this.config.installedExtensions[ext];\n\n    // note: TS cannot understand that _.has() is a type guard\n    if (!extConfig.scripts) {\n      throw new Error(`The ${this.type} named '${ext}' does not contain the ` +\n                      `\"scripts\" field underneath the \"appium\" field in its package.json`);\n    }\n\n    const extScripts = extConfig.scripts;\n\n    if (!_.isPlainObject(extScripts)) {\n      throw new Error(`The ${this.type} named '${ext}' \"scripts\" field must be a plain object`);\n    }\n\n    if (!_.has(extScripts, scriptName)) {\n      throw new Error(`The ${this.type} named '${ext}' does not support the script: '${scriptName}'`);\n    }\n\n    const runner = new SubProcess(process.execPath, [\n      extScripts[scriptName]\n    ], {\n      cwd: this.config.getInstallPath(ext)\n    });\n\n    const output = new RingBuffer(50);\n\n    runner.on('stream-line', (line) => {\n      output.enqueue(line);\n      log(this.isJsonOutput, line);\n    });\n\n    await runner.start(0);\n\n    try {\n      await runner.join();\n      log(this.isJsonOutput, `${scriptName} successfully ran`.green);\n      return {output: output.getBuff()};\n    } catch (err) {\n      log(this.isJsonOutput, `Encountered an error when running '${scriptName}': ${err.message}`.red);\n      return {error: err.message, output: output.getBuff()};\n    }\n  }\n}\n\nexport default ExtensionCommand;\nexport {ExtensionCommand};\n\n/**\n * Options for the {@linkcode ExtensionCommand} constructor\n * @template {ExtensionType} ExtType\n * @typedef ExtensionCommandOptions\n * @property {ExtensionConfig<ExtType>} config - the `DriverConfig` or `PluginConfig` instance used for this command\n * @property {boolean} json - whether the output of this command should be JSON or text\n */\n\n/**\n * Extra stuff about extensions; used indirectly by {@linkcode ExtensionCommand.list}.\n *\n * @typedef ExtensionMetadata\n * @property {boolean} installed - If `true`, the extension is installed\n * @property {string?} updateVersion - If the extension is installed, the version it can be updated to\n * @property {string?} unsafeUpdateVersion - Same as above, but a major version bump\n * @property {boolean} upToDate - If the extension is installed and the latest\n */\n\n/**\n * @typedef {import('../../types').ExtensionType} ExtensionType\n * @typedef {import('../../types').DriverType} DriverType\n * @typedef {import('../../types').PluginType} PluginType\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../../types/appium-manifest').ExtRecord<ExtType>} ExtRecord\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../extension/extension-config').ExtensionConfig<ExtType>} ExtensionConfig\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../../types/external-manifest').ExtMetadata<ExtType>} ExtMetadata\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../../types/appium-manifest').ExtManifest<ExtType>} ExtManifest\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../../types/external-manifest').ExtPackageJson<ExtType>} ExtPackageJson\n */\n\n/**\n * Possible return value for {@linkcode ExtensionCommand.list}\n * @typedef UninstalledExtensionListData\n * @property {string} pkgName\n * @property {false} installed\n */\n\n/**\n * Possible return value for {@linkcode ExtensionCommand.list}\n * @typedef {import('../../types/appium-manifest').InternalMetadata & ExtensionMetadata} InstalledExtensionListData\n */\n\n/**\n * Return value of {@linkcode ExtensionCommand.list}.\n * @typedef {Record<string,InstalledExtensionListData|UninstalledExtensionListData>} ExtensionListData\n */\n\n/**\n * Options for {@linkcode ExtensionCommand._run}.\n * @typedef RunOptions\n * @property {string} ext - name of the extension to run a script from\n * @property {string} scriptName - name of the script to run\n */\n\n/**\n * Return value of {@linkcode ExtensionCommand._run}\n *\n * @typedef RunOutput\n * @property {string} [error] - error message if script ran unsuccessfully, otherwise undefined\n * @property {string[]} output - script output\n */\n\n/**\n * Options for {@linkcode ExtensionCommand._update}.\n * @typedef ExtensionUpdateOpts\n * @property {string} ext - the name of the extension to update\n * @property {boolean} unsafe - if true, will perform unsafe updates past major revision boundaries\n */\n\n/**\n * Return value of {@linkcode ExtensionCommand._update}.\n * @typedef ExtensionUpdateResult\n * @property {Record<string,Error>} errors - map of ext names to error objects\n * @property {Record<string,UpdateReport>} updates - map of ext names to {@linkcode UpdateReport}s\n */\n\n/**\n * Part of result of {@linkcode ExtensionCommand._update}.\n * @typedef UpdateReport\n * @property {string} from - version the extension was updated from\n * @property {string} to - version the extension was updated to\n */\n\n/**\n * Options for {@linkcode ExtensionCommand._uninstall}.\n * @typedef UninstallOpts\n * @property {string} ext - the name or spec of an extension to uninstall\n */\n\n/**\n * Used by {@linkcode ExtensionCommand.getPostInstallText}\n * @typedef ExtensionArgs\n * @property {string} extName - the name of an extension\n * @property {object} extData - the data for an installed extension\n */\n\n/**\n * Options for {@linkcode ExtensionCommand.installViaNpm}\n * @typedef InstallViaNpmArgs\n * @property {string} ext - the name or spec of an extension to install\n * @property {string} pkgName - the NPM package name of the extension\n * @property {string} [pkgVer] - the specific version of the NPM package\n */\n\n/**\n * Object returned by {@linkcode ExtensionCommand.checkForExtensionUpdate}\n * @typedef PossibleUpdates\n * @property {string} current - current version\n * @property {string?} safeUpdate - version we can safely update to if it exists, or null\n * @property {string?} unsafeUpdate - version we can unsafely update to if it exists, or null\n */\n\n/**\n * Options for {@linkcode ExtensionCommand._install}\n * @typedef InstallArgs\n * @property {string} ext - the name or spec of an extension to install\n * @property {import('../../types/appium-manifest').InstallType} installType - how to install this extension. One of the INSTALL_TYPES\n * @property {string} [packageName] - for git/github installs, the extension node package name\n */\n\n/**\n * Returned by {@linkcode ExtensionCommand.getExtensionFields}\n * @template {ExtensionType} ExtType\n * @typedef {ExtMetadata<ExtType> & { pkgName: string, version: string } & import('../../types/external-manifest').CommonMetadata} ExtensionFields\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {ExtType extends DriverType ? typeof import('../constants').KNOWN_DRIVERS : ExtType extends PluginType ? typeof import('../constants').KNOWN_PLUGINS : never} KnownExtensions\n */\n"]}
478
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["UPDATE_ALL","NotUpdatableError","Error","NoUpdatesAvailableError","ExtensionCommand","config","knownExtensions","isJsonOutput","constructor","json","type","extensionType","execute","args","cmd","_","isFunction","executeCmd","bind","list","showInstalled","showUpdates","lsMsg","installedNames","Object","keys","installedExtensions","knownNames","exts","reduce","acc","name","includes","installed","pkgName","ext","data","toPairs","installType","INSTALL_TYPE_NPM","updates","checkForExtensionUpdate","updateVersion","safeUpdate","unsafeUpdateVersion","unsafeUpdate","upToDate","listData","installTxt","grey","updateTxt","upToDateTxt","unsafeUpdateTxt","installSpec","version","typeTxt","INSTALL_TYPE_GIT","INSTALL_TYPE_GITHUB","yellow","INSTALL_TYPE_LOCAL","magenta","green","cyan","console","log","_install","packageName","extData","split","length","installViaNpm","replace","pkgVer","path","isAbsolute","resolve","splits","msg","JSON","stringify","extName","isInstalled","extManifest","addExtension","env","hasAppiumDependency","appiumHome","getPostInstallText","npmSpec","specMsg","pkgJsonData","npm","installPackage","getExtensionFields","err","message","appium","validateExtensionFields","result","extMetadata","_uninstall","installPath","getInstallPath","fs","rimraf","removeExtension","_update","unsafe","shouldUpdateAll","extsToUpdate","errors","e","update","current","updateVer","updateExtension","from","to","red","getLatestVersion","getLatestSafeUpgradeVersion","util","compareVersions","_run","scriptName","has","extConfig","scripts","extScripts","isPlainObject","runner","SubProcess","process","execPath","cwd","output","RingBuffer","on","line","enqueue","start","join","getBuff","error"],"sources":["../../../lib/cli/extension-command.js"],"sourcesContent":["/* eslint-disable no-console */\n\nimport _ from 'lodash';\nimport path from 'path';\nimport {npm, fs, util, env} from '@appium/support';\nimport {log, spinWith, RingBuffer} from './utils';\nimport {SubProcess} from 'teen_process';\nimport {\n  INSTALL_TYPE_NPM,\n  INSTALL_TYPE_GIT,\n  INSTALL_TYPE_GITHUB,\n  INSTALL_TYPE_LOCAL,\n} from '../extension/extension-config';\nimport {packageDidChange} from '../extension/package-changed';\n\nconst UPDATE_ALL = 'installed';\n\nclass NotUpdatableError extends Error {}\nclass NoUpdatesAvailableError extends Error {}\n\n/**\n * @template {ExtensionType} ExtType\n */\nclass ExtensionCommand {\n  /**\n   * This is the `DriverConfig` or `PluginConfig`, depending on `ExtType`.\n   * @type {ExtensionConfig<ExtType>}\n   */\n  config;\n\n  /**\n   * {@linkcode Record} of official plugins or drivers.\n   * @type {KnownExtensions<ExtType>}\n   */\n  knownExtensions;\n\n  /**\n   * If `true`, command output has been requested as JSON.\n   * @type {boolean}\n   */\n  isJsonOutput;\n\n  /**\n   * Build an ExtensionCommand\n   * @param {ExtensionCommandOptions<ExtType>} opts\n   */\n  constructor ({config, json}) {\n    this.config = config;\n    this.isJsonOutput = json;\n  }\n\n  /**\n   * `driver` or `plugin`, depending on the `ExtensionConfig`.\n   */\n  get type () {\n    return this.config.extensionType;\n  }\n\n  /**\n   * Take a CLI parse and run an extension command based on its type\n   *\n   * @param {object} args - a key/value object with CLI flags and values\n   * @return {Promise<object>} the result of the specific command which is executed\n   */\n  async execute (args) {\n    const cmd = args[`${this.type}Command`];\n    if (!_.isFunction(this[cmd])) {\n      throw new Error(`Cannot handle ${this.type} command ${cmd}`);\n    }\n    const executeCmd = this[cmd].bind(this);\n    return await executeCmd(args);\n  }\n\n  /**\n   * @typedef ListOptions\n   * @property {boolean} showInstalled - whether should show only installed extensions\n   * @property {boolean} showUpdates - whether should show available updates\n   */\n\n  /**\n   * List extensions\n   *\n   * @param {ListOptions} opts\n   * @return {Promise<ExtensionListData>} map of extension names to extension data\n   */\n  async list ({showInstalled, showUpdates}) {\n    const lsMsg = `Listing ${showInstalled ? 'installed' : 'available'} ${\n      this.type\n    }s`;\n    const installedNames = Object.keys(this.config.installedExtensions);\n    const knownNames = Object.keys(this.knownExtensions);\n    const exts = [...installedNames, ...knownNames].reduce(\n      (acc, name) => {\n        if (!acc[name]) {\n          if (installedNames.includes(name)) {\n            acc[name] = {\n              ...this.config.installedExtensions[name],\n              installed: true,\n            };\n          } else if (!showInstalled) {\n            acc[name] = {pkgName: this.knownExtensions[name], installed: false};\n          }\n        }\n        return acc;\n      },\n      /**\n       * This accumulator contains either {@linkcode UninstalledExtensionLIstData} _or_\n       * {@linkcode InstalledExtensionListData} without upgrade information (which is added by the below code block)\n       * @type {Record<string,Partial<InstalledExtensionListData>|UninstalledExtensionListData>}\n       */ ({})\n    );\n\n    // if we want to show whether updates are available, put that behind a spinner\n    await spinWith(this.isJsonOutput, lsMsg, async () => {\n      if (!showUpdates) {\n        return;\n      }\n      for (const [ext, data] of _.toPairs(exts)) {\n        if (!data.installed || data.installType !== INSTALL_TYPE_NPM) {\n          // don't need to check for updates on exts that aren't installed\n          // also don't need to check for updates on non-npm exts\n          continue;\n        }\n        const updates = await this.checkForExtensionUpdate(ext);\n        data.updateVersion = updates.safeUpdate;\n        data.unsafeUpdateVersion = updates.unsafeUpdate;\n        data.upToDate =\n          updates.safeUpdate === null && updates.unsafeUpdate === null;\n      }\n    });\n\n    const listData = /** @type {ExtensionListData} */ (exts);\n\n    // if we're just getting the data, short circuit return here since we don't need to do any\n    // formatting logic\n    if (this.isJsonOutput) {\n      return listData;\n    }\n\n    for (const [name, data] of _.toPairs(listData)) {\n      let installTxt = ' [not installed]'.grey;\n      let updateTxt = '';\n      let upToDateTxt = '';\n      let unsafeUpdateTxt = '';\n      if (data.installed) {\n        const {\n          installType,\n          installSpec,\n          updateVersion,\n          unsafeUpdateVersion,\n          version,\n          upToDate,\n        } = data;\n        let typeTxt;\n        switch (installType) {\n          case INSTALL_TYPE_GIT:\n          case INSTALL_TYPE_GITHUB:\n            typeTxt = `(cloned from ${installSpec})`.yellow;\n            break;\n          case INSTALL_TYPE_LOCAL:\n            typeTxt = `(linked from ${installSpec})`.magenta;\n            break;\n          default:\n            typeTxt = '(NPM)';\n        }\n        installTxt = `@${version.yellow} ${\n          ('[installed ' + typeTxt + ']').green\n        }`;\n\n        if (showUpdates) {\n          if (updateVersion) {\n            updateTxt = ` [${updateVersion} available]`.magenta;\n          }\n          if (upToDate) {\n            upToDateTxt = ` [Up to date]`.green;\n          }\n          if (unsafeUpdateVersion) {\n            unsafeUpdateTxt =\n              ` [${unsafeUpdateVersion} available (potentially unsafe)]`.cyan;\n          }\n        }\n      }\n\n      console.log(\n        `- ${name.yellow}${installTxt}${updateTxt}${upToDateTxt}${unsafeUpdateTxt}`\n      );\n    }\n\n    return listData;\n  }\n\n  /**\n   * Install an extension\n   *\n   * @param {InstallArgs} args\n   * @return {Promise<ExtRecord<ExtType>>} map of all installed extension names to extension data\n   */\n  async _install ({installSpec, installType, packageName}) {\n    /** @type {ExtensionFields<typeof this.type>} */\n    let extData;\n\n    if (\n      packageName &&\n      [INSTALL_TYPE_LOCAL, INSTALL_TYPE_NPM].includes(installType)\n    ) {\n      throw new Error(\n        `When using --source=${installType}, cannot also use --package`\n      );\n    }\n\n    if (\n      !packageName &&\n      [INSTALL_TYPE_GIT, INSTALL_TYPE_GITHUB].includes(installType)\n    ) {\n      throw new Error(\n        `When using --source=${installType}, must also use --package`\n      );\n    }\n\n    if (installType === INSTALL_TYPE_GITHUB) {\n      if (installSpec.split('/').length !== 2) {\n        throw new Error(\n          `Github ${this.type} spec ${installSpec} appeared to be invalid; ` +\n            'it should be of the form <org>/<repo>'\n        );\n      }\n      extData = await this.installViaNpm({\n        installSpec,\n        pkgName: /** @type {string} */ (packageName),\n      });\n    } else if (installType === INSTALL_TYPE_GIT) {\n      // git urls can have '.git' at the end, but this is not necessary and would complicate the\n      // way we download and name directories, so we can just remove it\n      installSpec = installSpec.replace(/\\.git$/, '');\n      extData = await this.installViaNpm({\n        installSpec,\n        pkgName: /** @type {string} */ (packageName),\n      });\n    } else {\n      let pkgName, pkgVer;\n      if (installType === INSTALL_TYPE_LOCAL) {\n        pkgName = path.isAbsolute(installSpec)\n          ? installSpec\n          : path.resolve(installSpec);\n      } else {\n        // at this point we have either an npm package or an appium verified extension\n        // name or a local path. both of which will be installed via npm.\n        // extensions installed via npm can include versions or tags after the '@'\n        // sign, so check for that. We also need to be careful that package names themselves can\n        // contain the '@' symbol, as in `npm install @appium/fake-driver@1.2.0`\n        let name;\n        const splits = installSpec.split('@');\n        if (installSpec[0] === '@') {\n          // this is the case where we have an npm org included in the package name\n          [name, pkgVer] = [`@${splits[1]}`, splits[2]];\n        } else {\n          // this is the case without an npm org\n          [name, pkgVer] = splits;\n        }\n\n        if (installType === INSTALL_TYPE_NPM) {\n          // if we're installing a named package from npm, we don't need to check\n          // against the appium extension list; just use the installSpec as is\n          pkgName = name;\n        } else {\n          // if we're installing a named appium driver (like 'xcuitest') we need to\n          // dereference the actual npm package ('appiupm-xcuitest-driver'), so\n          // check it exists and get the correct package\n          const knownNames = Object.keys(this.knownExtensions);\n          if (!_.includes(knownNames, name)) {\n            const msg =\n              `Could not resolve ${this.type}; are you sure it's in the list ` +\n              `of supported ${this.type}s? ${JSON.stringify(knownNames)}`;\n            throw new Error(msg);\n          }\n          pkgName = this.knownExtensions[name];\n          // given that we'll use the install type in the driver json, store it as\n          // 'npm' now\n          installType = INSTALL_TYPE_NPM;\n        }\n      }\n\n      extData = await this.installViaNpm({installSpec, pkgName, pkgVer});\n    }\n\n    const extName = extData[/** @type {string} */ (`${this.type}Name`)];\n    delete extData[/** @type {string} */ (`${this.type}Name`)];\n\n    if (this.config.isInstalled(extName)) {\n      throw new Error(\n        `A ${this.type} named '${extName}' is already installed. ` +\n          `Did you mean to update? 'appium ${this.type} update'. See ` +\n          `installed ${this.type}s with 'appium ${this.type} list --installed'.`\n      );\n    }\n\n    const extManifest = {...extData, installType, installSpec};\n    await this.config.addExtension(extName, extManifest);\n\n    // update the if we've changed the local `package.json`\n    if (await env.hasAppiumDependency(this.config.appiumHome)) {\n      await packageDidChange(this.config.appiumHome);\n    }\n\n    // log info for the user\n    log(this.isJsonOutput, this.getPostInstallText({extName, extData}));\n\n    return this.config.installedExtensions;\n  }\n\n  /**\n   * Install an extension via NPM\n   *\n   * @param {InstallViaNpmArgs} args\n   */\n  async installViaNpm ({installSpec, pkgName, pkgVer}) {\n    const npmSpec = `${pkgName}${pkgVer ? '@' + pkgVer : ''}`;\n    const specMsg =\n      npmSpec === installSpec ? '' : ` using NPM install spec '${npmSpec}'`;\n    const msg = `Installing '${installSpec}'${specMsg}`;\n    try {\n      const pkgJsonData = await spinWith(\n        this.isJsonOutput,\n        msg,\n        async () =>\n          await npm.installPackage(this.config.appiumHome, pkgName, {\n            pkgVer,\n          })\n      );\n      return this.getExtensionFields(pkgJsonData, installSpec);\n    } catch (err) {\n      throw new Error(\n        `Encountered an error when installing package: ${err.message}`\n      );\n    }\n  }\n\n  /**\n   * Get the text which should be displayed to the user after an extension has been installed. This\n   * is designed to be overridden by drivers/plugins with their own particular text.\n   *\n   * @param {ExtensionArgs} args\n   * @returns {string}\n   */\n  // eslint-disable-next-line no-unused-vars\n  getPostInstallText (args) {\n    throw new Error('Must be implemented in final class');\n  }\n\n  /**\n   * Take an NPM module's package.json and extract Appium driver information from a special\n   * 'appium' field in the JSON data. We need this information to e.g. determine which class to\n   * load as the main driver class, or to be able to detect incompatibilities between driver and\n   * appium versions.\n   *\n   * @param {ExtPackageJson<ExtType>} pkgJsonData - the package.json data for a driver module, as if it had been straightforwardly 'require'd\n   * @param {string} installSpec\n   * @returns {ExtensionFields<ExtType>}\n   */\n  getExtensionFields (pkgJsonData, installSpec) {\n    if (!pkgJsonData.appium) {\n      throw new Error(\n        `Installed driver did not have an 'appium' section in its ` +\n          `package.json file as expected`\n      );\n    }\n    const {appium, name, version} = pkgJsonData;\n    this.validateExtensionFields(appium, installSpec);\n    /** @type {unknown} */\n    const result = {...appium, pkgName: name, version};\n    return /** @type {ExtensionFields<ExtType>} */ (result);\n  }\n\n  /**\n   * For any package.json fields which a particular type of extension requires, validate the\n   * presence and form of those fields on the package.json data, throwing an error if anything is\n\n  /**\n   * For any `package.json` fields which a particular type of extension requires, validate the\n   * presence and form of those fields on the `package.json` data, throwing an error if anything is\n   * amiss.\n   *\n   * @param {ExtMetadata<ExtType>} extMetadata - the data in the \"appium\" field of `package.json` for an extension\n   * @param {string} installSpec - Extension name/spec\n   */\n  // eslint-disable-next-line no-unused-vars\n  validateExtensionFields (extMetadata, installSpec) {\n    throw new Error('Must be implemented in final class');\n  }\n\n  /**\n   * Uninstall an extension\n   *\n   * @param {UninstallOpts} opts\n   * @return {Promise<ExtRecord<ExtType>>} map of all installed extension names to extension data\n   */\n  async _uninstall ({installSpec}) {\n    if (!this.config.isInstalled(installSpec)) {\n      throw new Error(\n        `Can't uninstall ${this.type} '${installSpec}'; it is not installed`\n      );\n    }\n    const installPath = this.config.getInstallPath(installSpec);\n    try {\n      await fs.rimraf(installPath);\n    } finally {\n      await this.config.removeExtension(installSpec);\n    }\n    log(\n      this.isJsonOutput,\n      `Successfully uninstalled ${this.type} '${installSpec}'`.green\n    );\n    return this.config.installedExtensions;\n  }\n\n  /**\n   * Attempt to update one or more drivers using NPM\n   *\n   * @param {ExtensionUpdateOpts} updateSpec\n   * @return {Promise<ExtensionUpdateResult>}\n   */\n  async _update ({installSpec, unsafe}) {\n    const shouldUpdateAll = installSpec === UPDATE_ALL;\n    // if we're specifically requesting an update for an extension, make sure it's installed\n    if (!shouldUpdateAll && !this.config.isInstalled(installSpec)) {\n      throw new Error(\n        `The ${this.type} '${installSpec}' was not installed, so can't be updated`\n      );\n    }\n    const extsToUpdate = shouldUpdateAll\n      ? Object.keys(this.config.installedExtensions)\n      : [installSpec];\n\n    // 'errors' will have ext names as keys and error objects as values\n    /** @type {Record<string,Error>} */\n    const errors = {};\n\n    // 'updates' will have ext names as keys and update objects as values, where an update\n    // object is of the form {from: versionString, to: versionString}\n    /** @type {Record<string,UpdateReport>} */\n    const updates = {};\n\n    for (const e of extsToUpdate) {\n      try {\n        await spinWith(\n          this.isJsonOutput,\n          `Checking if ${this.type} '${e}' is updatable`,\n          () => {\n            if (\n              this.config.installedExtensions[e].installType !==\n              INSTALL_TYPE_NPM\n            ) {\n              throw new NotUpdatableError();\n            }\n          }\n        );\n        const update = await spinWith(\n          this.isJsonOutput,\n          `Checking if ${this.type} '${e}' needs an update`,\n          async () => {\n            const update = await this.checkForExtensionUpdate(e);\n            if (!(update.safeUpdate || update.unsafeUpdate)) {\n              throw new NoUpdatesAvailableError();\n            }\n            return update;\n          }\n        );\n        if (!unsafe && !update.safeUpdate) {\n          throw new Error(\n            `The ${this.type} '${e}' has a major revision update ` +\n              `(${update.current} => ${update.unsafeUpdate}), which could include ` +\n              `breaking changes. If you want to apply this update, re-run with --unsafe`\n          );\n        }\n        const updateVer =\n          unsafe && update.unsafeUpdate\n            ? update.unsafeUpdate\n            : update.safeUpdate;\n        await spinWith(\n          this.isJsonOutput,\n          `Updating driver '${e}' from ${update.current} to ${updateVer}`,\n          async () => await this.updateExtension(e, updateVer)\n        );\n        updates[e] = {from: update.current, to: updateVer};\n      } catch (err) {\n        errors[e] = err;\n      }\n    }\n\n    log(this.isJsonOutput, 'Update report:');\n    for (const [e, update] of _.toPairs(updates)) {\n      log(\n        this.isJsonOutput,\n        `- ${this.type} ${e} updated: ${update.from} => ${update.to}`.green\n      );\n    }\n    for (const [e, err] of _.toPairs(errors)) {\n      if (err instanceof NotUpdatableError) {\n        log(\n          this.isJsonOutput,\n          `- '${e}' was not installed via npm, so we could not check ` +\n            `for updates`.yellow\n        );\n      } else if (err instanceof NoUpdatesAvailableError) {\n        log(this.isJsonOutput, `- '${e}' had no updates available`.yellow);\n      } else {\n        // otherwise, make it pop with red!\n        log(this.isJsonOutput, `- '${e}' failed to update: ${err}`.red);\n      }\n    }\n\n    return {updates, errors};\n  }\n\n  /**\n   * Given an extension name, figure out what its highest possible version upgrade is, and also the\n   * highest possible safe upgrade.\n   *\n   * @param {string} ext - name of extension\n   * @return {Promise<PossibleUpdates>}\n   */\n  async checkForExtensionUpdate (ext) {\n    // TODO decide how we want to handle beta versions?\n    // this is a helper method, 'ext' is assumed to already be installed here, and of the npm\n    // install type\n    const {version, pkgName} = this.config.installedExtensions[ext];\n    let unsafeUpdate = await npm.getLatestVersion(\n      this.config.appiumHome,\n      pkgName\n    );\n    let safeUpdate = await npm.getLatestSafeUpgradeVersion(\n      this.config.appiumHome,\n      pkgName,\n      version\n    );\n    if (!util.compareVersions(unsafeUpdate, '>', version)) {\n      // the latest version is not greater than the current version, so there's no possible update\n      unsafeUpdate = null;\n      safeUpdate = null;\n    }\n    if (unsafeUpdate && unsafeUpdate === safeUpdate) {\n      // the latest update is the same as the safe update, which means it's not actually unsafe\n      unsafeUpdate = null;\n    }\n    if (safeUpdate && !util.compareVersions(safeUpdate, '>', version)) {\n      // even the safe update is not later than the current, so it is not actually an update\n      safeUpdate = null;\n    }\n    return {current: version, safeUpdate, unsafeUpdate};\n  }\n\n  /**\n   * Actually update an extension installed by NPM, using the NPM cli. And update the installation\n   * manifest.\n   *\n   * @param {string} installSpec - name of extension to update\n   * @param {string} version - version string identifier to update extension to\n   * @returns {Promise<void>}\n   */\n  async updateExtension (installSpec, version) {\n    const {pkgName} = this.config.installedExtensions[installSpec];\n    await fs.rimraf(this.config.getInstallPath(installSpec));\n    const extData = await this.installViaNpm({\n      installSpec,\n      pkgName,\n      pkgVer: version,\n    });\n    delete extData[/** @type {string} */ (`${this.type}Name`)];\n    await this.config.updateExtension(installSpec, extData);\n  }\n\n  /**\n   * Runs a script cached inside the \"scripts\" field under \"appium\"\n   * inside of the driver/plugins \"package.json\" file. Will throw\n   * an error if the driver/plugin does not contain a \"scripts\" field\n   * underneath the \"appium\" field in its package.json, if the\n   * \"scripts\" field is not a plain object, or if the scriptName is\n   * not found within \"scripts\" object.\n   *\n   * @param {RunOptions} opts\n   * @return {Promise<RunOutput>}\n   */\n  async _run ({installSpec, scriptName}) {\n    if (!_.has(this.config.installedExtensions, installSpec)) {\n      throw new Error(`please install the ${this.type} first`);\n    }\n\n    const extConfig = this.config.installedExtensions[installSpec];\n\n    // note: TS cannot understand that _.has() is a type guard\n    if (!extConfig.scripts) {\n      throw new Error(\n        `The ${this.type} named '${installSpec}' does not contain the ` +\n          `\"scripts\" field underneath the \"appium\" field in its package.json`\n      );\n    }\n\n    const extScripts = extConfig.scripts;\n\n    if (!_.isPlainObject(extScripts)) {\n      throw new Error(\n        `The ${this.type} named '${installSpec}' \"scripts\" field must be a plain object`\n      );\n    }\n\n    if (!_.has(extScripts, scriptName)) {\n      throw new Error(\n        `The ${this.type} named '${installSpec}' does not support the script: '${scriptName}'`\n      );\n    }\n\n    const runner = new SubProcess(process.execPath, [extScripts[scriptName]], {\n      cwd: this.config.getInstallPath(installSpec),\n    });\n\n    const output = new RingBuffer(50);\n\n    runner.on('stream-line', (line) => {\n      output.enqueue(line);\n      log(this.isJsonOutput, line);\n    });\n\n    await runner.start(0);\n\n    try {\n      await runner.join();\n      log(this.isJsonOutput, `${scriptName} successfully ran`.green);\n      return {output: output.getBuff()};\n    } catch (err) {\n      log(\n        this.isJsonOutput,\n        `Encountered an error when running '${scriptName}': ${err.message}`.red\n      );\n      return {error: err.message, output: output.getBuff()};\n    }\n  }\n}\n\nexport default ExtensionCommand;\nexport {ExtensionCommand};\n\n/**\n * Options for the {@linkcode ExtensionCommand} constructor\n * @template {ExtensionType} ExtType\n * @typedef ExtensionCommandOptions\n * @property {ExtensionConfig<ExtType>} config - the `DriverConfig` or `PluginConfig` instance used for this command\n * @property {boolean} json - whether the output of this command should be JSON or text\n */\n\n/**\n * Extra stuff about extensions; used indirectly by {@linkcode ExtensionCommand.list}.\n *\n * @typedef ExtensionMetadata\n * @property {boolean} installed - If `true`, the extension is installed\n * @property {string?} updateVersion - If the extension is installed, the version it can be updated to\n * @property {string?} unsafeUpdateVersion - Same as above, but a major version bump\n * @property {boolean} upToDate - If the extension is installed and the latest\n */\n\n/**\n * @typedef {import('../../types').ExtensionType} ExtensionType\n * @typedef {import('../../types').DriverType} DriverType\n * @typedef {import('../../types').PluginType} PluginType\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../../types/appium-manifest').ExtRecord<ExtType>} ExtRecord\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../extension/extension-config').ExtensionConfig<ExtType>} ExtensionConfig\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../../types/external-manifest').ExtMetadata<ExtType>} ExtMetadata\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../../types/appium-manifest').ExtManifest<ExtType>} ExtManifest\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {import('../../types/external-manifest').ExtPackageJson<ExtType>} ExtPackageJson\n */\n\n/**\n * Possible return value for {@linkcode ExtensionCommand.list}\n * @typedef UninstalledExtensionListData\n * @property {string} pkgName\n * @property {false} installed\n */\n\n/**\n * Possible return value for {@linkcode ExtensionCommand.list}\n * @typedef {import('../../types/appium-manifest').InternalMetadata & ExtensionMetadata} InstalledExtensionListData\n */\n\n/**\n * Return value of {@linkcode ExtensionCommand.list}.\n * @typedef {Record<string,InstalledExtensionListData|UninstalledExtensionListData>} ExtensionListData\n */\n\n/**\n * Options for {@linkcode ExtensionCommand._run}.\n * @typedef RunOptions\n * @property {string} installSpec - name of the extension to run a script from\n * @property {string} scriptName - name of the script to run\n */\n\n/**\n * Return value of {@linkcode ExtensionCommand._run}\n *\n * @typedef RunOutput\n * @property {string} [error] - error message if script ran unsuccessfully, otherwise undefined\n * @property {string[]} output - script output\n */\n\n/**\n * Options for {@linkcode ExtensionCommand._update}.\n * @typedef ExtensionUpdateOpts\n * @property {string} installSpec - the name of the extension to update\n * @property {boolean} unsafe - if true, will perform unsafe updates past major revision boundaries\n */\n\n/**\n * Return value of {@linkcode ExtensionCommand._update}.\n * @typedef ExtensionUpdateResult\n * @property {Record<string,Error>} errors - map of ext names to error objects\n * @property {Record<string,UpdateReport>} updates - map of ext names to {@linkcode UpdateReport}s\n */\n\n/**\n * Part of result of {@linkcode ExtensionCommand._update}.\n * @typedef UpdateReport\n * @property {string} from - version the extension was updated from\n * @property {string} to - version the extension was updated to\n */\n\n/**\n * Options for {@linkcode ExtensionCommand._uninstall}.\n * @typedef UninstallOpts\n * @property {string} installSpec - the name or spec of an extension to uninstall\n */\n\n/**\n * Used by {@linkcode ExtensionCommand.getPostInstallText}\n * @typedef ExtensionArgs\n * @property {string} extName - the name of an extension\n * @property {object} extData - the data for an installed extension\n */\n\n/**\n * Options for {@linkcode ExtensionCommand.installViaNpm}\n * @typedef InstallViaNpmArgs\n * @property {string} installSpec - the name or spec of an extension to install\n * @property {string} pkgName - the NPM package name of the extension\n * @property {string} [pkgVer] - the specific version of the NPM package\n */\n\n/**\n * Object returned by {@linkcode ExtensionCommand.checkForExtensionUpdate}\n * @typedef PossibleUpdates\n * @property {string} current - current version\n * @property {string?} safeUpdate - version we can safely update to if it exists, or null\n * @property {string?} unsafeUpdate - version we can unsafely update to if it exists, or null\n */\n\n/**\n * Options for {@linkcode ExtensionCommand._install}\n * @typedef InstallArgs\n * @property {string} installSpec - the name or spec of an extension to install\n * @property {import('../../types/appium-manifest').InstallType} installType - how to install this extension. One of the INSTALL_TYPES\n * @property {string} [packageName] - for git/github installs, the extension node package name\n */\n\n/**\n * Returned by {@linkcode ExtensionCommand.getExtensionFields}\n * @template {ExtensionType} ExtType\n * @typedef {ExtMetadata<ExtType> & { pkgName: string, version: string } & import('../../types/external-manifest').CommonMetadata} ExtensionFields\n */\n\n/**\n * @template {ExtensionType} ExtType\n * @typedef {ExtType extends DriverType ? typeof import('../constants').KNOWN_DRIVERS : ExtType extends PluginType ? typeof import('../constants').KNOWN_PLUGINS : never} KnownExtensions\n */\n"],"mappings":"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"}
@@ -68,4 +68,4 @@ async function runExtensionCommand(args, configObject) {
68
68
 
69
69
  return jsonResult;
70
70
  }
71
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9jbGkvZXh0ZW5zaW9uLmpzIl0sIm5hbWVzIjpbImNvbW1hbmRDbGFzc2VzIiwiT2JqZWN0IiwiZnJlZXplIiwiRFJJVkVSX1RZUEUiLCJEcml2ZXJDb21tYW5kIiwiUExVR0lOX1RZUEUiLCJQbHVnaW5Db21tYW5kIiwicnVuRXh0ZW5zaW9uQ29tbWFuZCIsImFyZ3MiLCJjb25maWdPYmplY3QiLCJqc29uUmVzdWx0IiwiZXh0ZW5zaW9uVHlwZSIsInR5cGUiLCJleHRDbWQiLCJUeXBlRXJyb3IiLCJqc29uIiwic3VwcHJlc3NPdXRwdXQiLCJsb2dGbiIsIm1zZyIsImNvbmZpZyIsImxvZyIsIkNvbW1hbmRDbGFzcyIsImNtZCIsImV4ZWN1dGUiLCJlcnIiLCJjb25zb2xlIiwiSlNPTiIsInN0cmluZ2lmeSIsIkpTT05fU1BBQ0VTIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUVBOztBQUNBOztBQUNBOztBQUNBOztBQUVBLE1BQU1BLGNBQWMsR0FBR0MsTUFBTSxDQUFDQyxNQUFQLENBQW1DO0FBQ3hELEdBQUNDLHNCQUFELEdBQWVDLHNCQUR5QztBQUV4RCxHQUFDQyxzQkFBRCxHQUFlQztBQUZ5QyxDQUFuQyxDQUF2Qjs7QUFjQSxlQUFlQyxtQkFBZixDQUFvQ0MsSUFBcEMsRUFBMENDLFlBQTFDLEVBQXdEO0FBR3RELE1BQUlDLFVBQVUsR0FBRyxJQUFqQjtBQUNBLFFBQU07QUFBQ0MsSUFBQUEsYUFBYSxFQUFFQztBQUFoQixNQUF3QkgsWUFBOUI7QUFDQSxRQUFNSSxNQUFNLEdBQUdMLElBQUksQ0FBRSxHQUFFSSxJQUFLLFNBQVQsQ0FBbkI7O0FBQ0EsTUFBSSxDQUFDQyxNQUFMLEVBQWE7QUFDWCxVQUFNLElBQUlDLFNBQUosQ0FBZSxlQUFjRixJQUFLLDhDQUFsQyxDQUFOO0FBQ0Q7O0FBQ0QsTUFBSTtBQUFDRyxJQUFBQSxJQUFEO0FBQU9DLElBQUFBO0FBQVAsTUFBeUJSLElBQTdCOztBQUNBLE1BQUlRLGNBQUosRUFBb0I7QUFDbEJELElBQUFBLElBQUksR0FBRyxJQUFQO0FBQ0Q7O0FBQ0QsUUFBTUUsS0FBSyxHQUFJQyxHQUFELElBQVMsZ0JBQUlILElBQUosRUFBVUcsR0FBVixDQUF2Qjs7QUFDQSxNQUFJQyxNQUFNLEdBQUdWLFlBQWI7QUFDQVUsRUFBQUEsTUFBTSxDQUFDQyxHQUFQLEdBQWFILEtBQWI7QUFDQSxRQUFNSSxZQUFZLEdBQXNDckIsY0FBYyxDQUFDWSxJQUFELENBQXRFO0FBQ0EsUUFBTVUsR0FBRyxHQUFHLElBQUlELFlBQUosQ0FBaUI7QUFBQ0YsSUFBQUEsTUFBRDtBQUFTSixJQUFBQTtBQUFULEdBQWpCLENBQVo7O0FBQ0EsTUFBSTtBQUNGTCxJQUFBQSxVQUFVLEdBQUcsTUFBTVksR0FBRyxDQUFDQyxPQUFKLENBQVlmLElBQVosQ0FBbkI7QUFDRCxHQUZELENBRUUsT0FBT2dCLEdBQVAsRUFBWTtBQUdaLFFBQUlSLGNBQUosRUFBb0I7QUFDbEIsWUFBTVEsR0FBTjtBQUNEOztBQUNELDJCQUFXVCxJQUFYLEVBQWlCUyxHQUFqQjtBQUNEOztBQUVELE1BQUlULElBQUksSUFBSSxDQUFDQyxjQUFiLEVBQTZCO0FBQzNCUyxJQUFBQSxPQUFPLENBQUNMLEdBQVIsQ0FBWU0sSUFBSSxDQUFDQyxTQUFMLENBQWVqQixVQUFmLEVBQTJCLElBQTNCLEVBQWlDa0Isa0JBQWpDLENBQVo7QUFDRDs7QUFFRCxTQUFPbEIsVUFBUDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tY29uc29sZSAqL1xuXG5pbXBvcnQgRHJpdmVyQ29tbWFuZCBmcm9tICcuL2RyaXZlci1jb21tYW5kJztcbmltcG9ydCBQbHVnaW5Db21tYW5kIGZyb20gJy4vcGx1Z2luLWNvbW1hbmQnO1xuaW1wb3J0IHsgRFJJVkVSX1RZUEUsIFBMVUdJTl9UWVBFIH0gZnJvbSAnLi4vY29uc3RhbnRzJztcbmltcG9ydCB7IGVyckFuZFF1aXQsIGxvZywgSlNPTl9TUEFDRVMgfSBmcm9tICcuL3V0aWxzJztcblxuY29uc3QgY29tbWFuZENsYXNzZXMgPSBPYmplY3QuZnJlZXplKC8qKiBAdHlwZSB7Y29uc3R9ICovKHtcbiAgW0RSSVZFUl9UWVBFXTogRHJpdmVyQ29tbWFuZCxcbiAgW1BMVUdJTl9UWVBFXTogUGx1Z2luQ29tbWFuZFxufSkpO1xuXG4vKipcbiAqIFJ1biBhIHN1YmNvbW1hbmQgb2YgdGhlICdhcHBpdW0gZHJpdmVyJyB0eXBlLiBFYWNoIHN1YmNvbW1hbmQgaGFzIGl0cyBvd24gc2V0IG9mIGFyZ3VtZW50cyB3aGljaFxuICogY2FuIGJlIHJlcHJlc2VudGVkIGFzIGEgSlMgb2JqZWN0LlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSBhcmdzIC0gSlMgb2JqZWN0IHdoZXJlIHRoZSBrZXkgaXMgdGhlIHBhcmFtZXRlciBuYW1lIChhcyBkZWZpbmVkIGluXG4gKiBkcml2ZXItcGFyc2VyLmpzKVxuICogQHRlbXBsYXRlIHtpbXBvcnQoJy4uL2V4dGVuc2lvbi9tYW5pZmVzdCcpLkV4dGVuc2lvblR5cGV9IEV4dFR5cGVcbiAqIEBwYXJhbSB7aW1wb3J0KCcuLi9leHRlbnNpb24vZXh0ZW5zaW9uLWNvbmZpZycpLkV4dGVuc2lvbkNvbmZpZzxFeHRUeXBlPn0gY29uZmlnT2JqZWN0IC0gRXh0ZW5zaW9uIGNvbmZpZyBvYmplY3RcbiAqL1xuYXN5bmMgZnVuY3Rpb24gcnVuRXh0ZW5zaW9uQ29tbWFuZCAoYXJncywgY29uZmlnT2JqZWN0KSB7XG4gIC8vIFRPRE8gZHJpdmVyIGNvbmZpZyBmaWxlIHNob3VsZCBiZSBsb2NrZWQgd2hpbGUgYW55IG9mIHRoZXNlIGNvbW1hbmRzIGFyZVxuICAvLyBydW5uaW5nIHRvIHByZXZlbnQgd2VpcmQgc2l0dWF0aW9uc1xuICBsZXQganNvblJlc3VsdCA9IG51bGw7XG4gIGNvbnN0IHtleHRlbnNpb25UeXBlOiB0eXBlfSA9IGNvbmZpZ09iamVjdDtcbiAgY29uc3QgZXh0Q21kID0gYXJnc1tgJHt0eXBlfUNvbW1hbmRgXTtcbiAgaWYgKCFleHRDbWQpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKGBDYW5ub3QgY2FsbCAke3R5cGV9IGNvbW1hbmQgd2l0aG91dCBhIHN1YmNvbW1hbmQgbGlrZSAnaW5zdGFsbCdgKTtcbiAgfVxuICBsZXQge2pzb24sIHN1cHByZXNzT3V0cHV0fSA9IGFyZ3M7XG4gIGlmIChzdXBwcmVzc091dHB1dCkge1xuICAgIGpzb24gPSB0cnVlO1xuICB9XG4gIGNvbnN0IGxvZ0ZuID0gKG1zZykgPT4gbG9nKGpzb24sIG1zZyk7XG4gIGxldCBjb25maWcgPSBjb25maWdPYmplY3Q7XG4gIGNvbmZpZy5sb2cgPSBsb2dGbjtcbiAgY29uc3QgQ29tbWFuZENsYXNzID0gLyoqIEB0eXBlIHtFeHRDb21tYW5kPEV4dFR5cGU+fSAqLyhjb21tYW5kQ2xhc3Nlc1t0eXBlXSk7XG4gIGNvbnN0IGNtZCA9IG5ldyBDb21tYW5kQ2xhc3Moe2NvbmZpZywganNvbn0pO1xuICB0cnkge1xuICAgIGpzb25SZXN1bHQgPSBhd2FpdCBjbWQuZXhlY3V0ZShhcmdzKTtcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgLy8gaW4gdGhlIHN1cHByZXNzIG91dHB1dCBjYXNlLCB3ZSBhcmUgY2FsbGluZyB0aGlzIGZ1bmN0aW9uIGludGVybmFsbHkgYW5kIHNob3VsZFxuICAgIC8vIGp1c3QgdGhyb3cgaW5zdGVhZCBvZiBwcmludGluZyBhbiBlcnJvciBhbmQgZW5kaW5nIHRoZSBwcm9jZXNzXG4gICAgaWYgKHN1cHByZXNzT3V0cHV0KSB7XG4gICAgICB0aHJvdyBlcnI7XG4gICAgfVxuICAgIGVyckFuZFF1aXQoanNvbiwgZXJyKTtcbiAgfVxuXG4gIGlmIChqc29uICYmICFzdXBwcmVzc091dHB1dCkge1xuICAgIGNvbnNvbGUubG9nKEpTT04uc3RyaW5naWZ5KGpzb25SZXN1bHQsIG51bGwsIEpTT05fU1BBQ0VTKSk7XG4gIH1cblxuICByZXR1cm4ganNvblJlc3VsdDtcbn1cblxuZXhwb3J0IHtcbiAgcnVuRXh0ZW5zaW9uQ29tbWFuZCxcbn07XG5cbi8qKlxuICogQHRlbXBsYXRlIHtpbXBvcnQoJy4uLy4uL3R5cGVzJykuRXh0ZW5zaW9uVHlwZX0gRXh0VHlwZVxuICogQHR5cGVkZWYge0V4dFR5cGUgZXh0ZW5kcyBpbXBvcnQoJy4uLy4uL3R5cGVzJykuRHJpdmVyVHlwZSA/IGltcG9ydCgnQGFwcGl1bS90eXBlcycpLkNsYXNzPERyaXZlckNvbW1hbmQ+IDogRXh0VHlwZSBleHRlbmRzIGltcG9ydCgnLi4vLi4vdHlwZXMnKS5QbHVnaW5UeXBlID8gaW1wb3J0KCdAYXBwaXVtL3R5cGVzJykuQ2xhc3M8UGx1Z2luQ29tbWFuZD4gOiBuZXZlcn0gRXh0Q29tbWFuZFxuICovXG4iXX0=
71
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjb21tYW5kQ2xhc3NlcyIsIk9iamVjdCIsImZyZWV6ZSIsIkRSSVZFUl9UWVBFIiwiRHJpdmVyQ29tbWFuZCIsIlBMVUdJTl9UWVBFIiwiUGx1Z2luQ29tbWFuZCIsInJ1bkV4dGVuc2lvbkNvbW1hbmQiLCJhcmdzIiwiY29uZmlnT2JqZWN0IiwianNvblJlc3VsdCIsImV4dGVuc2lvblR5cGUiLCJ0eXBlIiwiZXh0Q21kIiwiVHlwZUVycm9yIiwianNvbiIsInN1cHByZXNzT3V0cHV0IiwibG9nRm4iLCJtc2ciLCJjb25maWciLCJsb2ciLCJDb21tYW5kQ2xhc3MiLCJjbWQiLCJleGVjdXRlIiwiZXJyIiwiY29uc29sZSIsIkpTT04iLCJzdHJpbmdpZnkiLCJKU09OX1NQQUNFUyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9jbGkvZXh0ZW5zaW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLWNvbnNvbGUgKi9cblxuaW1wb3J0IERyaXZlckNvbW1hbmQgZnJvbSAnLi9kcml2ZXItY29tbWFuZCc7XG5pbXBvcnQgUGx1Z2luQ29tbWFuZCBmcm9tICcuL3BsdWdpbi1jb21tYW5kJztcbmltcG9ydCB7IERSSVZFUl9UWVBFLCBQTFVHSU5fVFlQRSB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBlcnJBbmRRdWl0LCBsb2csIEpTT05fU1BBQ0VTIH0gZnJvbSAnLi91dGlscyc7XG5cbmNvbnN0IGNvbW1hbmRDbGFzc2VzID0gT2JqZWN0LmZyZWV6ZSgvKiogQHR5cGUge2NvbnN0fSAqLyh7XG4gIFtEUklWRVJfVFlQRV06IERyaXZlckNvbW1hbmQsXG4gIFtQTFVHSU5fVFlQRV06IFBsdWdpbkNvbW1hbmRcbn0pKTtcblxuLyoqXG4gKiBSdW4gYSBzdWJjb21tYW5kIG9mIHRoZSAnYXBwaXVtIGRyaXZlcicgdHlwZS4gRWFjaCBzdWJjb21tYW5kIGhhcyBpdHMgb3duIHNldCBvZiBhcmd1bWVudHMgd2hpY2hcbiAqIGNhbiBiZSByZXByZXNlbnRlZCBhcyBhIEpTIG9iamVjdC5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gYXJncyAtIEpTIG9iamVjdCB3aGVyZSB0aGUga2V5IGlzIHRoZSBwYXJhbWV0ZXIgbmFtZSAoYXMgZGVmaW5lZCBpblxuICogZHJpdmVyLXBhcnNlci5qcylcbiAqIEB0ZW1wbGF0ZSB7aW1wb3J0KCcuLi9leHRlbnNpb24vbWFuaWZlc3QnKS5FeHRlbnNpb25UeXBlfSBFeHRUeXBlXG4gKiBAcGFyYW0ge2ltcG9ydCgnLi4vZXh0ZW5zaW9uL2V4dGVuc2lvbi1jb25maWcnKS5FeHRlbnNpb25Db25maWc8RXh0VHlwZT59IGNvbmZpZ09iamVjdCAtIEV4dGVuc2lvbiBjb25maWcgb2JqZWN0XG4gKi9cbmFzeW5jIGZ1bmN0aW9uIHJ1bkV4dGVuc2lvbkNvbW1hbmQgKGFyZ3MsIGNvbmZpZ09iamVjdCkge1xuICAvLyBUT0RPIGRyaXZlciBjb25maWcgZmlsZSBzaG91bGQgYmUgbG9ja2VkIHdoaWxlIGFueSBvZiB0aGVzZSBjb21tYW5kcyBhcmVcbiAgLy8gcnVubmluZyB0byBwcmV2ZW50IHdlaXJkIHNpdHVhdGlvbnNcbiAgbGV0IGpzb25SZXN1bHQgPSBudWxsO1xuICBjb25zdCB7ZXh0ZW5zaW9uVHlwZTogdHlwZX0gPSBjb25maWdPYmplY3Q7XG4gIGNvbnN0IGV4dENtZCA9IGFyZ3NbYCR7dHlwZX1Db21tYW5kYF07XG4gIGlmICghZXh0Q21kKSB7XG4gICAgdGhyb3cgbmV3IFR5cGVFcnJvcihgQ2Fubm90IGNhbGwgJHt0eXBlfSBjb21tYW5kIHdpdGhvdXQgYSBzdWJjb21tYW5kIGxpa2UgJ2luc3RhbGwnYCk7XG4gIH1cbiAgbGV0IHtqc29uLCBzdXBwcmVzc091dHB1dH0gPSBhcmdzO1xuICBpZiAoc3VwcHJlc3NPdXRwdXQpIHtcbiAgICBqc29uID0gdHJ1ZTtcbiAgfVxuICBjb25zdCBsb2dGbiA9IChtc2cpID0+IGxvZyhqc29uLCBtc2cpO1xuICBsZXQgY29uZmlnID0gY29uZmlnT2JqZWN0O1xuICBjb25maWcubG9nID0gbG9nRm47XG4gIGNvbnN0IENvbW1hbmRDbGFzcyA9IC8qKiBAdHlwZSB7RXh0Q29tbWFuZDxFeHRUeXBlPn0gKi8oY29tbWFuZENsYXNzZXNbdHlwZV0pO1xuICBjb25zdCBjbWQgPSBuZXcgQ29tbWFuZENsYXNzKHtjb25maWcsIGpzb259KTtcbiAgdHJ5IHtcbiAgICBqc29uUmVzdWx0ID0gYXdhaXQgY21kLmV4ZWN1dGUoYXJncyk7XG4gIH0gY2F0Y2ggKGVycikge1xuICAgIC8vIGluIHRoZSBzdXBwcmVzcyBvdXRwdXQgY2FzZSwgd2UgYXJlIGNhbGxpbmcgdGhpcyBmdW5jdGlvbiBpbnRlcm5hbGx5IGFuZCBzaG91bGRcbiAgICAvLyBqdXN0IHRocm93IGluc3RlYWQgb2YgcHJpbnRpbmcgYW4gZXJyb3IgYW5kIGVuZGluZyB0aGUgcHJvY2Vzc1xuICAgIGlmIChzdXBwcmVzc091dHB1dCkge1xuICAgICAgdGhyb3cgZXJyO1xuICAgIH1cbiAgICBlcnJBbmRRdWl0KGpzb24sIGVycik7XG4gIH1cblxuICBpZiAoanNvbiAmJiAhc3VwcHJlc3NPdXRwdXQpIHtcbiAgICBjb25zb2xlLmxvZyhKU09OLnN0cmluZ2lmeShqc29uUmVzdWx0LCBudWxsLCBKU09OX1NQQUNFUykpO1xuICB9XG5cbiAgcmV0dXJuIGpzb25SZXN1bHQ7XG59XG5cbmV4cG9ydCB7XG4gIHJ1bkV4dGVuc2lvbkNvbW1hbmQsXG59O1xuXG4vKipcbiAqIEB0ZW1wbGF0ZSB7aW1wb3J0KCcuLi8uLi90eXBlcycpLkV4dGVuc2lvblR5cGV9IEV4dFR5cGVcbiAqIEB0eXBlZGVmIHtFeHRUeXBlIGV4dGVuZHMgaW1wb3J0KCcuLi8uLi90eXBlcycpLkRyaXZlclR5cGUgPyBpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5DbGFzczxEcml2ZXJDb21tYW5kPiA6IEV4dFR5cGUgZXh0ZW5kcyBpbXBvcnQoJy4uLy4uL3R5cGVzJykuUGx1Z2luVHlwZSA/IGltcG9ydCgnQGFwcGl1bS90eXBlcycpLkNsYXNzPFBsdWdpbkNvbW1hbmQ+IDogbmV2ZXJ9IEV4dENvbW1hbmRcbiAqL1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUVBOztBQUNBOztBQUNBOztBQUNBOztBQUVBLE1BQU1BLGNBQWMsR0FBR0MsTUFBTSxDQUFDQyxNQUFQLENBQW1DO0VBQ3hELENBQUNDLHNCQUFELEdBQWVDLHNCQUR5QztFQUV4RCxDQUFDQyxzQkFBRCxHQUFlQztBQUZ5QyxDQUFuQyxDQUF2Qjs7QUFjQSxlQUFlQyxtQkFBZixDQUFvQ0MsSUFBcEMsRUFBMENDLFlBQTFDLEVBQXdEO0VBR3RELElBQUlDLFVBQVUsR0FBRyxJQUFqQjtFQUNBLE1BQU07SUFBQ0MsYUFBYSxFQUFFQztFQUFoQixJQUF3QkgsWUFBOUI7RUFDQSxNQUFNSSxNQUFNLEdBQUdMLElBQUksQ0FBRSxHQUFFSSxJQUFLLFNBQVQsQ0FBbkI7O0VBQ0EsSUFBSSxDQUFDQyxNQUFMLEVBQWE7SUFDWCxNQUFNLElBQUlDLFNBQUosQ0FBZSxlQUFjRixJQUFLLDhDQUFsQyxDQUFOO0VBQ0Q7O0VBQ0QsSUFBSTtJQUFDRyxJQUFEO0lBQU9DO0VBQVAsSUFBeUJSLElBQTdCOztFQUNBLElBQUlRLGNBQUosRUFBb0I7SUFDbEJELElBQUksR0FBRyxJQUFQO0VBQ0Q7O0VBQ0QsTUFBTUUsS0FBSyxHQUFJQyxHQUFELElBQVMsZ0JBQUlILElBQUosRUFBVUcsR0FBVixDQUF2Qjs7RUFDQSxJQUFJQyxNQUFNLEdBQUdWLFlBQWI7RUFDQVUsTUFBTSxDQUFDQyxHQUFQLEdBQWFILEtBQWI7RUFDQSxNQUFNSSxZQUFZLEdBQXNDckIsY0FBYyxDQUFDWSxJQUFELENBQXRFO0VBQ0EsTUFBTVUsR0FBRyxHQUFHLElBQUlELFlBQUosQ0FBaUI7SUFBQ0YsTUFBRDtJQUFTSjtFQUFULENBQWpCLENBQVo7O0VBQ0EsSUFBSTtJQUNGTCxVQUFVLEdBQUcsTUFBTVksR0FBRyxDQUFDQyxPQUFKLENBQVlmLElBQVosQ0FBbkI7RUFDRCxDQUZELENBRUUsT0FBT2dCLEdBQVAsRUFBWTtJQUdaLElBQUlSLGNBQUosRUFBb0I7TUFDbEIsTUFBTVEsR0FBTjtJQUNEOztJQUNELHVCQUFXVCxJQUFYLEVBQWlCUyxHQUFqQjtFQUNEOztFQUVELElBQUlULElBQUksSUFBSSxDQUFDQyxjQUFiLEVBQTZCO0lBQzNCUyxPQUFPLENBQUNMLEdBQVIsQ0FBWU0sSUFBSSxDQUFDQyxTQUFMLENBQWVqQixVQUFmLEVBQTJCLElBQTNCLEVBQWlDa0Isa0JBQWpDLENBQVo7RUFDRDs7RUFFRCxPQUFPbEIsVUFBUDtBQUNEIn0=