@appium/base-driver 8.4.2 → 8.5.2

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.
@@ -1 +1 @@
1
- {"version":3,"file":"log.d.ts","sourceRoot":"","sources":["../../../../lib/basedriver/commands/log.js"],"names":[],"mappings":"AAKA;;;;GAIG;AACH,+BAHW,QAAQ,GACN,OAAO,CA2CnB;2BAIY,OAAO,eAAe,EAAE,WAAW;qBACnC,OAAO,eAAe,EAAE,MAAM;uBAC9B,OAAO,QAAQ,EAAE,QAAQ;sBACzB,OAAO,WAAW,EAAE,cAAc,CAAC,OAAO,eAAe,EAAE,eAAe,GAAG,OAAO,eAAe,EAAE,aAAa,GAAG,OAAO,eAAe,EAAE,YAAY,GAAG,YAAY,CAAC;yBAKzK,OAAO,eAAe,EAAE,OAAO,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"log.d.ts","sourceRoot":"","sources":["../../../../lib/basedriver/commands/log.js"],"names":[],"mappings":"AAKA;;;;GAIG;AACH,+BAHW,QAAQ,GACN,OAAO,CAsCnB;2BAIY,OAAO,eAAe,EAAE,WAAW;qBACnC,OAAO,eAAe,EAAE,MAAM;uBAC9B,OAAO,QAAQ,EAAE,QAAQ;sBACzB,OAAO,WAAW,EAAE,cAAc,CAAC,OAAO,eAAe,EAAE,eAAe,GAAG,OAAO,eAAe,EAAE,aAAa,GAAG,OAAO,eAAe,EAAE,YAAY,GAAG,YAAY,CAAC;yBAKzK,OAAO,eAAe,EAAE,OAAO,CAAC,CAAC,CAAC"}
@@ -13,7 +13,12 @@ var _lodash = _interopRequireDefault(require("lodash"));
13
13
 
14
14
  function LogMixin(Base) {
15
15
  class LogCommands extends Base {
16
- supportedLogTypes;
16
+ constructor(...args) {
17
+ var _this$supportedLogTyp;
18
+
19
+ super(...args);
20
+ this.supportedLogTypes = (_this$supportedLogTyp = this.supportedLogTypes) !== null && _this$supportedLogTyp !== void 0 ? _this$supportedLogTyp : {};
21
+ }
17
22
 
18
23
  async getLogTypes() {
19
24
  this.log.debug('Retrieving supported log types');
@@ -24,10 +29,7 @@ function LogMixin(Base) {
24
29
  this.log.debug(`Retrieving '${logType}' logs`);
25
30
 
26
31
  if (!(await this.getLogTypes()).includes(logType)) {
27
- const logsTypesWithDescriptions = _lodash.default.reduce(this.supportedLogTypes, (acc, value, key) => {
28
- acc[key] = value.description;
29
- return acc;
30
- }, {});
32
+ const logsTypesWithDescriptions = _lodash.default.mapValues(this.supportedLogTypes, 'description');
31
33
 
32
34
  throw new Error(`Unsupported log type '${logType}'. ` + `Supported types: ${JSON.stringify(logsTypesWithDescriptions)}`);
33
35
  }
@@ -39,4 +41,4 @@ function LogMixin(Base) {
39
41
 
40
42
  return LogCommands;
41
43
  }
42
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYi9iYXNlZHJpdmVyL2NvbW1hbmRzL2xvZy5qcyJdLCJuYW1lcyI6WyJMb2dNaXhpbiIsIkJhc2UiLCJMb2dDb21tYW5kcyIsInN1cHBvcnRlZExvZ1R5cGVzIiwiZ2V0TG9nVHlwZXMiLCJsb2ciLCJkZWJ1ZyIsIl8iLCJrZXlzIiwiZ2V0TG9nIiwibG9nVHlwZSIsImluY2x1ZGVzIiwibG9nc1R5cGVzV2l0aERlc2NyaXB0aW9ucyIsInJlZHVjZSIsImFjYyIsInZhbHVlIiwia2V5IiwiZGVzY3JpcHRpb24iLCJFcnJvciIsIkpTT04iLCJzdHJpbmdpZnkiLCJnZXR0ZXIiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBR0E7O0FBT08sU0FBU0EsUUFBVCxDQUFtQkMsSUFBbkIsRUFBeUI7QUFJOUIsUUFBTUMsV0FBTixTQUEwQkQsSUFBMUIsQ0FBK0I7QUFLN0JFLElBQUFBLGlCQUFpQjs7QUFFQSxVQUFYQyxXQUFXLEdBQUk7QUFDbkIsV0FBS0MsR0FBTCxDQUFTQyxLQUFULENBQWUsZ0NBQWY7QUFDQSxhQUFPQyxnQkFBRUMsSUFBRixDQUFPLEtBQUtMLGlCQUFaLENBQVA7QUFDRDs7QUFLVyxVQUFOTSxNQUFNLENBQUVDLE9BQUYsRUFBVztBQUNyQixXQUFLTCxHQUFMLENBQVNDLEtBQVQsQ0FBZ0IsZUFBY0ksT0FBUSxRQUF0Qzs7QUFFQSxVQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUtOLFdBQUwsRUFBUCxFQUEyQk8sUUFBM0IsQ0FBb0NELE9BQXBDLENBQUwsRUFBbUQ7QUFDakQsY0FBTUUseUJBQXlCLEdBQUdMLGdCQUFFTSxNQUFGLENBQ2hDLEtBQUtWLGlCQUQyQixFQUVoQyxDQUFDVyxHQUFELEVBQU1DLEtBQU4sRUFBYUMsR0FBYixLQUFxQjtBQUNuQkYsVUFBQUEsR0FBRyxDQUFDRSxHQUFELENBQUgsR0FBV0QsS0FBSyxDQUFDRSxXQUFqQjtBQUNBLGlCQUFPSCxHQUFQO0FBQ0QsU0FMK0IsRUFNaEMsRUFOZ0MsQ0FBbEM7O0FBUUEsY0FBTSxJQUFJSSxLQUFKLENBQ0gseUJBQXdCUixPQUFRLEtBQWpDLEdBQ0csb0JBQW1CUyxJQUFJLENBQUNDLFNBQUwsQ0FBZVIseUJBQWYsQ0FBMEMsRUFGNUQsQ0FBTjtBQUlEOztBQUVELGFBQU8sTUFBTSxLQUFLVCxpQkFBTCxDQUF1Qk8sT0FBdkIsRUFBZ0NXLE1BQWhDLENBQXVDLElBQXZDLENBQWI7QUFDRDs7QUFsQzRCOztBQW9DL0IsU0FBT25CLFdBQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlcXVpcmUtYXdhaXQgKi9cbi8vIEB0cy1jaGVja1xuXG5pbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuXG4vKipcbiAqXG4gKiBAcGFyYW0ge0ZpbmRCYXNlfSBCYXNlXG4gKiBAcmV0dXJucyB7TG9nQmFzZX1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIExvZ01peGluIChCYXNlKSB7XG4gIC8qKlxuICAgKiBAaW1wbGVtZW50cyB7SUxvZ0NvbW1hbmRzfVxuICAgKi9cbiAgY2xhc3MgTG9nQ29tbWFuZHMgZXh0ZW5kcyBCYXNlIHtcbiAgICAvKipcbiAgICAgKiBYWFg6IGR1YmlvdXNcbiAgICAgKiBAdHlwZSB7UmVjb3JkPHN0cmluZyxMb2dUeXBlPERyaXZlcj4+fVxuICAgICAqL1xuICAgIHN1cHBvcnRlZExvZ1R5cGVzO1xuXG4gICAgYXN5bmMgZ2V0TG9nVHlwZXMgKCkge1xuICAgICAgdGhpcy5sb2cuZGVidWcoJ1JldHJpZXZpbmcgc3VwcG9ydGVkIGxvZyB0eXBlcycpO1xuICAgICAgcmV0dXJuIF8ua2V5cyh0aGlzLnN1cHBvcnRlZExvZ1R5cGVzKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBAdGhpcyB7RHJpdmVyfVxuICAgICAqL1xuICAgIGFzeW5jIGdldExvZyAobG9nVHlwZSkge1xuICAgICAgdGhpcy5sb2cuZGVidWcoYFJldHJpZXZpbmcgJyR7bG9nVHlwZX0nIGxvZ3NgKTtcblxuICAgICAgaWYgKCEoYXdhaXQgdGhpcy5nZXRMb2dUeXBlcygpKS5pbmNsdWRlcyhsb2dUeXBlKSkge1xuICAgICAgICBjb25zdCBsb2dzVHlwZXNXaXRoRGVzY3JpcHRpb25zID0gXy5yZWR1Y2UoXG4gICAgICAgICAgdGhpcy5zdXBwb3J0ZWRMb2dUeXBlcyxcbiAgICAgICAgICAoYWNjLCB2YWx1ZSwga2V5KSA9PiB7XG4gICAgICAgICAgICBhY2Nba2V5XSA9IHZhbHVlLmRlc2NyaXB0aW9uO1xuICAgICAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgICAgICB9LFxuICAgICAgICAgIHt9LFxuICAgICAgICApO1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgYFVuc3VwcG9ydGVkIGxvZyB0eXBlICcke2xvZ1R5cGV9Jy4gYCArXG4gICAgICAgICAgICBgU3VwcG9ydGVkIHR5cGVzOiAke0pTT04uc3RyaW5naWZ5KGxvZ3NUeXBlc1dpdGhEZXNjcmlwdGlvbnMpfWAsXG4gICAgICAgICk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBhd2FpdCB0aGlzLnN1cHBvcnRlZExvZ1R5cGVzW2xvZ1R5cGVdLmdldHRlcih0aGlzKTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIExvZ0NvbW1hbmRzO1xufVxuXG5cbi8qKlxuICogQHR5cGVkZWYge2ltcG9ydCgnQGFwcGl1bS90eXBlcycpLkxvZ0NvbW1hbmRzfSBJTG9nQ29tbWFuZHNcbiAqIEB0eXBlZGVmIHtpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5Ecml2ZXJ9IERyaXZlclxuICogQHR5cGVkZWYge2ltcG9ydCgnLi9maW5kJykuRmluZEJhc2V9IEZpbmRCYXNlXG4gKiBAdHlwZWRlZiB7aW1wb3J0KCcuLi9kcml2ZXInKS5CYXNlRHJpdmVyQmFzZTxpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5UaW1lb3V0Q29tbWFuZHMgJiBpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5FdmVudENvbW1hbmRzICYgaW1wb3J0KCdAYXBwaXVtL3R5cGVzJykuRmluZENvbW1hbmRzICYgSUxvZ0NvbW1hbmRzPn0gTG9nQmFzZVxuICovXG5cbi8qKlxuICogQHRlbXBsYXRlIFRcbiAqIEB0eXBlZGVmIHtpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5Mb2dUeXBlPFQ+fSBMb2dUeXBlXG4gKi9cbiJdfQ==
44
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYi9iYXNlZHJpdmVyL2NvbW1hbmRzL2xvZy5qcyJdLCJuYW1lcyI6WyJMb2dNaXhpbiIsIkJhc2UiLCJMb2dDb21tYW5kcyIsImNvbnN0cnVjdG9yIiwiYXJncyIsInN1cHBvcnRlZExvZ1R5cGVzIiwiZ2V0TG9nVHlwZXMiLCJsb2ciLCJkZWJ1ZyIsIl8iLCJrZXlzIiwiZ2V0TG9nIiwibG9nVHlwZSIsImluY2x1ZGVzIiwibG9nc1R5cGVzV2l0aERlc2NyaXB0aW9ucyIsIm1hcFZhbHVlcyIsIkVycm9yIiwiSlNPTiIsInN0cmluZ2lmeSIsImdldHRlciJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFHQTs7QUFPTyxTQUFTQSxRQUFULENBQW1CQyxJQUFuQixFQUF5QjtBQUk5QixRQUFNQyxXQUFOLFNBQTBCRCxJQUExQixDQUErQjtBQUU3QkUsSUFBQUEsV0FBVyxDQUFFLEdBQUdDLElBQUwsRUFBVztBQUFBOztBQUNwQixZQUFNLEdBQUdBLElBQVQ7QUFFQSxXQUFLQyxpQkFBTCw0QkFBeUIsS0FBS0EsaUJBQTlCLHlFQUFtRCxFQUFuRDtBQUNEOztBQUVnQixVQUFYQyxXQUFXLEdBQUk7QUFDbkIsV0FBS0MsR0FBTCxDQUFTQyxLQUFULENBQWUsZ0NBQWY7QUFDQSxhQUFPQyxnQkFBRUMsSUFBRixDQUFPLEtBQUtMLGlCQUFaLENBQVA7QUFDRDs7QUFNVyxVQUFOTSxNQUFNLENBQUVDLE9BQUYsRUFBVztBQUNyQixXQUFLTCxHQUFMLENBQVNDLEtBQVQsQ0FBZ0IsZUFBY0ksT0FBUSxRQUF0Qzs7QUFFQSxVQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUtOLFdBQUwsRUFBUCxFQUEyQk8sUUFBM0IsQ0FBb0NELE9BQXBDLENBQUwsRUFBbUQ7QUFDakQsY0FBTUUseUJBQXlCLEdBQUdMLGdCQUFFTSxTQUFGLENBQVksS0FBS1YsaUJBQWpCLEVBQW9DLGFBQXBDLENBQWxDOztBQUNBLGNBQU0sSUFBSVcsS0FBSixDQUNILHlCQUF3QkosT0FBUSxLQUFqQyxHQUNHLG9CQUFtQkssSUFBSSxDQUFDQyxTQUFMLENBQWVKLHlCQUFmLENBQTBDLEVBRjVELENBQU47QUFJRDs7QUFFRCxhQUFPLE1BQU0sS0FBS1QsaUJBQUwsQ0FBdUJPLE9BQXZCLEVBQWdDTyxNQUFoQyxDQUF1QyxJQUF2QyxDQUFiO0FBQ0Q7O0FBN0I0Qjs7QUErQi9CLFNBQU9qQixXQUFQO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSByZXF1aXJlLWF3YWl0ICovXG4vLyBAdHMtY2hlY2tcblxuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcblxuLyoqXG4gKlxuICogQHBhcmFtIHtGaW5kQmFzZX0gQmFzZVxuICogQHJldHVybnMge0xvZ0Jhc2V9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBMb2dNaXhpbiAoQmFzZSkge1xuICAvKipcbiAgICogQGltcGxlbWVudHMge0lMb2dDb21tYW5kc31cbiAgICovXG4gIGNsYXNzIExvZ0NvbW1hbmRzIGV4dGVuZHMgQmFzZSB7XG5cbiAgICBjb25zdHJ1Y3RvciAoLi4uYXJncykge1xuICAgICAgc3VwZXIoLi4uYXJncyk7XG4gICAgICAvKiogQHR5cGUge1JlY29yZDxzdHJpbmcsIExvZ1R5cGU8RHJpdmVyPj59ICovXG4gICAgICB0aGlzLnN1cHBvcnRlZExvZ1R5cGVzID0gdGhpcy5zdXBwb3J0ZWRMb2dUeXBlcyA/PyB7fTtcbiAgICB9XG5cbiAgICBhc3luYyBnZXRMb2dUeXBlcyAoKSB7XG4gICAgICB0aGlzLmxvZy5kZWJ1ZygnUmV0cmlldmluZyBzdXBwb3J0ZWQgbG9nIHR5cGVzJyk7XG4gICAgICByZXR1cm4gXy5rZXlzKHRoaXMuc3VwcG9ydGVkTG9nVHlwZXMpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEB0aGlzIHtEcml2ZXJ9XG4gICAgICogQHBhcmFtIHtzdHJpbmd9IGxvZ1R5cGVcbiAgICAgKi9cbiAgICBhc3luYyBnZXRMb2cgKGxvZ1R5cGUpIHtcbiAgICAgIHRoaXMubG9nLmRlYnVnKGBSZXRyaWV2aW5nICcke2xvZ1R5cGV9JyBsb2dzYCk7XG5cbiAgICAgIGlmICghKGF3YWl0IHRoaXMuZ2V0TG9nVHlwZXMoKSkuaW5jbHVkZXMobG9nVHlwZSkpIHtcbiAgICAgICAgY29uc3QgbG9nc1R5cGVzV2l0aERlc2NyaXB0aW9ucyA9IF8ubWFwVmFsdWVzKHRoaXMuc3VwcG9ydGVkTG9nVHlwZXMsICdkZXNjcmlwdGlvbicpO1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgYFVuc3VwcG9ydGVkIGxvZyB0eXBlICcke2xvZ1R5cGV9Jy4gYCArXG4gICAgICAgICAgICBgU3VwcG9ydGVkIHR5cGVzOiAke0pTT04uc3RyaW5naWZ5KGxvZ3NUeXBlc1dpdGhEZXNjcmlwdGlvbnMpfWAsXG4gICAgICAgICk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBhd2FpdCB0aGlzLnN1cHBvcnRlZExvZ1R5cGVzW2xvZ1R5cGVdLmdldHRlcih0aGlzKTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIExvZ0NvbW1hbmRzO1xufVxuXG5cbi8qKlxuICogQHR5cGVkZWYge2ltcG9ydCgnQGFwcGl1bS90eXBlcycpLkxvZ0NvbW1hbmRzfSBJTG9nQ29tbWFuZHNcbiAqIEB0eXBlZGVmIHtpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5Ecml2ZXJ9IERyaXZlclxuICogQHR5cGVkZWYge2ltcG9ydCgnLi9maW5kJykuRmluZEJhc2V9IEZpbmRCYXNlXG4gKiBAdHlwZWRlZiB7aW1wb3J0KCcuLi9kcml2ZXInKS5CYXNlRHJpdmVyQmFzZTxpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5UaW1lb3V0Q29tbWFuZHMgJiBpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5FdmVudENvbW1hbmRzICYgaW1wb3J0KCdAYXBwaXVtL3R5cGVzJykuRmluZENvbW1hbmRzICYgSUxvZ0NvbW1hbmRzPn0gTG9nQmFzZVxuICovXG5cbi8qKlxuICogQHRlbXBsYXRlIFRcbiAqIEB0eXBlZGVmIHtpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5Mb2dUeXBlPFQ+fSBMb2dUeXBlXG4gKi9cbiJdfQ==
@@ -2,7 +2,7 @@ export type Capabilities = import('@appium/types').Capabilities;
2
2
  export type W3CCapabilities = import('@appium/types').W3CCapabilities;
3
3
  export type Driver = import('@appium/types').Driver;
4
4
  export type Core = import('@appium/types').Core;
5
- export type DriverOpts = import('@appium/types').DriverOpts;
5
+ export type DriverOpts = import('@appium/types').ServerArgs;
6
6
  export type EventHistory = import('@appium/types').EventHistory;
7
7
  export type AppiumLogger = import('@appium/types').AppiumLogger;
8
8
  /**
@@ -14,7 +14,7 @@ export class DriverCore implements Core {
14
14
  * know which version of basedriver it inherited from
15
15
  */
16
16
  static baseVersion: any;
17
- constructor(opts?: import("@appium/types").DriverOpts, shouldValidateCaps?: boolean);
17
+ constructor(opts?: import("@appium/types").ServerArgs, shouldValidateCaps?: boolean);
18
18
  /**
19
19
  * @type {string?}
20
20
  */
@@ -22,7 +22,7 @@ export class DriverCore implements Core {
22
22
  /**
23
23
  * @type {DriverOpts & Capabilities}
24
24
  */
25
- opts: import("@appium/types").DriverOpts & Partial<import("@wdio/types/build/Capabilities").Capabilities & import("@wdio/types/build/Capabilities").AppiumCapabilities & {
25
+ opts: import("@appium/types").ServerArgs & Partial<import("@wdio/types/build/Capabilities").Capabilities & import("@wdio/types/build/Capabilities").AppiumCapabilities & {
26
26
  [x: string]: any;
27
27
  }>;
28
28
  /**
@@ -280,4 +280,4 @@ class DriverCore {
280
280
  }
281
281
 
282
282
  exports.DriverCore = DriverCore;
283
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/basedriver/core.js"],"names":["version","BASEDRIVER_VER","fs","readPackageJsonFrom","__dirname","NEW_COMMAND_TIMEOUT_MS","ON_UNEXPECTED_SHUTDOWN_EVENT","DriverCore","baseVersion","sessionId","opts","initialOpts","caps","originalCaps","helpers","basePath","DEFAULT_BASE_PATH","relaxedSecurityEnabled","allowInsecure","denyInsecure","newCommandTimeoutMs","implicitWaitMs","locatorStrategies","webLocatorStrategies","managedDrivers","noCommandTimer","_eventHistory","commands","_constraints","_","cloneDeep","desiredCapabilityConstraints","eventEmitter","EventEmitter","_log","shutdownUnexpectedly","shouldValidateCaps","commandsQueueGuard","AsyncLock","settings","DeviceSettings","constructor","logger","getLogger","generateDriverLogPrefix","tmpDir","process","env","APPIUM_TMP_DIR","os","tmpdir","log","onUnexpectedShutdown","handler","on","driverData","isCommandsQueueEnabled","eventHistory","logEvent","eventName","Error","ts","Date","now","logTime","toTimeString","push","debug","getStatus","desiredCapConstraints","constraints","Object","assign","value","toPairs","presence","allowEmpty","sessionExists","driverForSession","logExtraCaps","extraCaps","difference","keys","length","warn","cap","validateDesiredCaps","e","errorAndThrow","errors","SessionNotCreatedError","message","isMjsonwpProtocol","protocol","PROTOCOLS","MJSONWP","isW3CProtocol","W3C","setProtocolMJSONWP","setProtocolW3C","isFeatureEnabled","name","includes","ensureFeatureEnabled","validateLocatorStrategy","strategy","webContext","validStrategies","join","concat","InvalidSelectorError","proxyActive","getProxyAvoidList","canProxy","proxyRouteIsAvoided","method","url","body","avoidSchema","isArray","avoidMethod","avoidPathRegex","isRegExp","normalizedUrl","replace","RegExp","escapeRegExp","test","addManagedDriver","driver","getManagedDrivers","clearNewCommandTimeout","clearTimeout"],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable no-unused-vars */\n/* eslint-disable require-await */\n\nimport { fs, logger, node } from '@appium/support';\nimport AsyncLock from 'async-lock';\nimport { EventEmitter } from 'events';\nimport _ from 'lodash';\nimport os from 'os';\nimport { DEFAULT_BASE_PATH, PROTOCOLS } from '../constants';\nimport { errors } from '../protocol';\nimport { validateCaps } from './capabilities';\nimport { desiredCapabilityConstraints } from './desired-caps';\nimport DeviceSettings from './device-settings';\nimport helpers from './helpers';\n\n// for compat with running tests transpiled and in-place\nconst {version: BASEDRIVER_VER} = fs.readPackageJsonFrom(__dirname);\n\nconst NEW_COMMAND_TIMEOUT_MS = 60 * 1000;\n\nconst ON_UNEXPECTED_SHUTDOWN_EVENT = 'onUnexpectedShutdown';\n/**\n * @implements {Core}\n */\nclass DriverCore {\n\n  /**\n   * Make the basedriver version available so for any driver which inherits from this package, we\n   * know which version of basedriver it inherited from\n   */\n  static baseVersion = BASEDRIVER_VER;\n\n  /**\n  * @type {string?}\n  */\n  sessionId = null;\n\n  /**\n  * @type {DriverOpts & Capabilities}\n  */\n  opts;\n\n  /**\n  * @type {DriverOpts}\n  */\n  initialOpts;\n\n  /**\n  * @type {Capabilities}\n  */\n  caps;\n\n  /**\n  * @type {W3CCapabilities}\n  */\n  originalCaps;\n\n  helpers = helpers;\n\n  /**\n  * basePath is used for several purposes, for example in setting up\n  * proxying to other drivers, since we need to know what the base path\n  * of any incoming request might look like. We set it to the default\n  * initially but it is automatically updated during any actual program\n  * execution by the routeConfiguringFunction, which is necessarily run as\n  * the entrypoint for any Appium server\n  */\n  basePath = DEFAULT_BASE_PATH;\n\n  relaxedSecurityEnabled = false;\n\n  /** @type {string[]} */\n  allowInsecure = [];\n\n  /** @type {string[]} */\n  denyInsecure = [];\n\n  newCommandTimeoutMs = NEW_COMMAND_TIMEOUT_MS;\n\n  implicitWaitMs = 0;\n\n  /** @type {string[]} */\n  locatorStrategies = [];\n\n  /** @type {string[]} */\n  webLocatorStrategies = [];\n\n  /** @type {Driver[]} */\n  managedDrivers = [];\n\n  /** @type {NodeJS.Timeout?} */\n  noCommandTimer = null;\n\n  /** @type {EventHistory} */\n  _eventHistory = {commands: []};\n\n  _constraints = _.cloneDeep(desiredCapabilityConstraints);\n\n  // used to handle driver events\n  /** @type {NodeJS.EventEmitter} */\n  eventEmitter = new EventEmitter();\n\n  /**\n  * @type {AppiumLogger}\n  */\n  _log;\n\n  /**\n  * @protected\n  */\n  shutdownUnexpectedly = false;\n\n  /**\n  * @type {boolean}\n  * @protected\n  */\n  shouldValidateCaps;\n\n  /**\n  * @protected\n  */\n  commandsQueueGuard = new AsyncLock();\n\n  /**\n  * settings should be instantiated by drivers which extend BaseDriver, but\n  * we set it to an empty DeviceSettings instance here to make sure that the\n  * default settings are applied even if an extending driver doesn't utilize\n  * the settings functionality itself\n  */\n  settings = new DeviceSettings();\n\n  constructor (\n    opts = /** @type {DriverOpts} */ ({}),\n    shouldValidateCaps = true,\n  ) {\n    this._log = logger.getLogger(helpers.generateDriverLogPrefix(this));\n\n    // setup state\n    this.opts = opts;\n\n    // use a custom tmp dir to avoid losing data and app when computer is\n    // restarted\n    this.opts.tmpDir =\n      this.opts.tmpDir || process.env.APPIUM_TMP_DIR || os.tmpdir();\n\n    // base-driver internals\n    this.shouldValidateCaps = shouldValidateCaps;\n\n    // keeping track of initial opts\n    this.initialOpts = _.cloneDeep(this.opts);\n\n    this.sessionId = null;\n  }\n\n  get log () {\n    return this._log;\n  }\n\n  /**\n  * Set a callback handler if needed to execute a custom piece of code\n  * when the driver is shut down unexpectedly. Multiple calls to this method\n  * will cause the handler to be executed mutiple times\n  *\n  * @param {(...args: any[]) => void} handler The code to be executed on unexpected shutdown.\n  * The function may accept one argument, which is the actual error instance, which\n  * caused the driver to shut down.\n  */\n  onUnexpectedShutdown (handler) {\n    this.eventEmitter.on(ON_UNEXPECTED_SHUTDOWN_EVENT, handler);\n  }\n\n  /**\n  * This property is used by AppiumDriver to store the data of the\n  * specific driver sessions. This data can be later used to adjust\n  * properties for driver instances running in parallel.\n  * Override it in inherited driver classes if necessary.\n  *\n  * @return {Record<string,unknown>} Driver properties mapping\n  */\n  get driverData () {\n    return {};\n  }\n\n  /**\n  * This property controls the way {#executeCommand} method\n  * handles new driver commands received from the client.\n  * Override it for inherited classes only in special cases.\n  *\n  * @return {boolean} If the returned value is true (default) then all the commands\n  *   received by the particular driver instance are going to be put into the queue,\n  *   so each following command will not be executed until the previous command\n  *   execution is completed. False value disables that queue, so each driver command\n  *   is executed independently and does not wait for anything.\n  */\n  get isCommandsQueueEnabled () {\n    return true;\n  }\n\n  /*\n  * make eventHistory a property and return a cloned object so a consumer can't\n  * inadvertently change data outside of logEvent\n  */\n  get eventHistory () {\n    return _.cloneDeep(this._eventHistory);\n  }\n\n  /**\n  * API method for driver developers to log timings for important events\n  * @param {string} eventName\n  */\n  logEvent (eventName) {\n    if (eventName === 'commands') {\n      throw new Error('Cannot log commands directly');\n    }\n    if (typeof eventName !== 'string') {\n      throw new Error(`Invalid eventName ${eventName}`);\n    }\n    if (!this._eventHistory[eventName]) {\n      this._eventHistory[eventName] = [];\n    }\n    const ts = Date.now();\n    const logTime = new Date(ts).toTimeString();\n    this._eventHistory[eventName].push(ts);\n    this.log.debug(`Event '${eventName}' logged at ${ts} (${logTime})`);\n  }\n\n  /**\n  * Overridden in appium driver, but here so that individual drivers can be\n  * tested with clients that poll\n  */\n  async getStatus () {\n    return {};\n  }\n\n  // we only want subclasses to ever extend the contraints\n  set desiredCapConstraints (constraints) {\n    this._constraints = Object.assign(this._constraints, constraints);\n    // 'presence' means different things in different versions of the validator,\n    // when we say 'true' we mean that it should not be able to be empty\n    for (const [, value] of _.toPairs(this._constraints)) {\n      if (value && value.presence === true) {\n        value.presence = {\n          allowEmpty: false,\n        };\n      }\n    }\n  }\n\n  get desiredCapConstraints () {\n    return this._constraints;\n  }\n\n  /**\n  * method required by MJSONWP in order to determine whether it should\n  * respond with an invalid session response\n  * @param {string} [sessionId]\n  * @returns {boolean}\n  */\n  sessionExists (sessionId) {\n    if (!sessionId) return false; // eslint-disable-line curly\n    return sessionId === this.sessionId;\n  }\n\n  /**\n  * method required by MJSONWP in order to determine if the command should\n  * be proxied directly to the driver\n  * @param {string} sessionId\n  * @returns {this | import('@appium/types').Driver}\n  */\n  driverForSession (sessionId) {\n    return this;\n  }\n\n  /**\n  *\n  * @param {Capabilities} caps\n  */\n  logExtraCaps (caps) {\n    let extraCaps = _.difference(_.keys(caps), _.keys(this._constraints));\n    if (extraCaps.length) {\n      this.log.warn(\n        `The following capabilities were provided, but are not ` +\n          `recognized by Appium:`,\n      );\n      for (const cap of extraCaps) {\n        this.log.warn(`  ${cap}`);\n      }\n    }\n  }\n\n  /**\n  *\n  * @param {Capabilities} caps\n  * @returns {boolean}\n  */\n  validateDesiredCaps (caps) {\n    if (!this.shouldValidateCaps) {\n      return true;\n    }\n\n    try {\n      validateCaps(caps, this._constraints);\n    } catch (e) {\n      this.log.errorAndThrow(\n        new errors.SessionNotCreatedError(\n          `The desiredCapabilities object was not valid for the ` +\n            `following reason(s): ${e.message}`,\n        ),\n      );\n    }\n\n    this.logExtraCaps(caps);\n\n    return true;\n  }\n\n  isMjsonwpProtocol () {\n    return this.protocol === PROTOCOLS.MJSONWP;\n  }\n\n  isW3CProtocol () {\n    return this.protocol === PROTOCOLS.W3C;\n  }\n\n  setProtocolMJSONWP () {\n    this.protocol = PROTOCOLS.MJSONWP;\n  }\n\n  setProtocolW3C () {\n    this.protocol = PROTOCOLS.W3C;\n  }\n\n  /**\n  * Check whether a given feature is enabled via its name\n  *\n  * @param {string} name - name of feature/command\n  *\n  * @returns {Boolean}\n  */\n  isFeatureEnabled (name) {\n    // if we have explicitly denied this feature, return false immediately\n    if (this.denyInsecure && _.includes(this.denyInsecure, name)) {\n      return false;\n    }\n\n    // if we specifically have allowed the feature, return true\n    if (this.allowInsecure && _.includes(this.allowInsecure, name)) {\n      return true;\n    }\n\n    // otherwise, if we've globally allowed insecure features and not denied\n    // this one, return true\n    if (this.relaxedSecurityEnabled) {\n      return true;\n    }\n\n    // if we haven't allowed anything insecure, then reject\n    return false;\n  }\n\n  /**\n  * Assert that a given feature is enabled and throw a helpful error if it's\n  * not\n  *\n  * @param {string} name - name of feature/command\n  */\n  ensureFeatureEnabled (name) {\n    if (!this.isFeatureEnabled(name)) {\n      throw new Error(\n        `Potentially insecure feature '${name}' has not been ` +\n          `enabled. If you want to enable this feature and accept ` +\n          `the security ramifications, please do so by following ` +\n          `the documented instructions at https://github.com/appium` +\n          `/appium/blob/master/docs/en/writing-running-appium/security.md`,\n      );\n    }\n  }\n\n  /**\n  *\n  * @param {string} strategy\n  * @param {boolean} [webContext]\n  */\n  validateLocatorStrategy (strategy, webContext = false) {\n    let validStrategies = this.locatorStrategies;\n    this.log.debug(\n      `Valid locator strategies for this request: ${validStrategies.join(\n        ', ',\n      )}`,\n    );\n\n    if (webContext) {\n      validStrategies = validStrategies.concat(this.webLocatorStrategies);\n    }\n\n    if (!_.includes(validStrategies, strategy)) {\n      throw new errors.InvalidSelectorError(\n        `Locator Strategy '${strategy}' is not supported for this session`,\n      );\n    }\n  }\n\n  /**\n  *\n  * @param {string} [sessionId]\n  * @returns {boolean}\n  */\n  proxyActive (sessionId) {\n    return false;\n  }\n\n  /**\n  *\n  * @param {string} sessionId\n  * @returns {[string, RegExp][]}\n  */\n  getProxyAvoidList (sessionId) {\n    return [];\n  }\n\n  /**\n  *\n  * @param {string} [sessionId]\n  * @returns {boolean}\n  */\n  canProxy (sessionId) {\n    return false;\n  }\n\n  /**\n  * Whether a given command route (expressed as method and url) should not be\n  * proxied according to this driver\n  *\n  * @param {string} sessionId - the current sessionId (in case the driver runs\n  * multiple session ids and requires it). This is not used in this method but\n  * should be made available to overridden methods.\n  * @param {import('@appium/types').HTTPMethod} method - HTTP method of the route\n  * @param {string} url - url of the route\n  * @param {any} [body] - webdriver request body\n  *\n  * @returns {boolean} - whether the route should be avoided\n  */\n  proxyRouteIsAvoided (sessionId, method, url, body) {\n    for (let avoidSchema of this.getProxyAvoidList(sessionId)) {\n      if (!_.isArray(avoidSchema) || avoidSchema.length !== 2) {\n        throw new Error('Proxy avoidance must be a list of pairs');\n      }\n      let [avoidMethod, avoidPathRegex] = avoidSchema;\n      if (!_.includes(['GET', 'POST', 'DELETE'], avoidMethod)) {\n        throw new Error(`Unrecognized proxy avoidance method '${avoidMethod}'`);\n      }\n      if (!_.isRegExp(avoidPathRegex)) {\n        throw new Error('Proxy avoidance path must be a regular expression');\n      }\n      let normalizedUrl = url.replace(\n        new RegExp(`^${_.escapeRegExp(this.basePath)}`),\n        '',\n      );\n      if (avoidMethod === method && avoidPathRegex.test(normalizedUrl)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  /**\n  *\n  * @param {Driver} driver\n  */\n  addManagedDriver (driver) {\n    this.managedDrivers.push(driver);\n  }\n\n  getManagedDrivers () {\n    return this.managedDrivers;\n  }\n\n  async clearNewCommandTimeout () {\n    if (this.noCommandTimer) {\n      clearTimeout(this.noCommandTimer);\n      this.noCommandTimer = null;\n    }\n  }\n}\n\nexport {DriverCore};\n\n/**\n * @typedef {import('@appium/types').Capabilities} Capabilities\n * @typedef {import('@appium/types').W3CCapabilities} W3CCapabilities\n * @typedef {import('@appium/types').Driver} Driver\n * @typedef {import('@appium/types').Core} Core\n * @typedef {import('@appium/types').DriverOpts} DriverOpts\n * @typedef {import('@appium/types').EventHistory} EventHistory\n * @typedef {import('@appium/types').AppiumLogger} AppiumLogger\n */\n"]}
283
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/basedriver/core.js"],"names":["version","BASEDRIVER_VER","fs","readPackageJsonFrom","__dirname","NEW_COMMAND_TIMEOUT_MS","ON_UNEXPECTED_SHUTDOWN_EVENT","DriverCore","baseVersion","sessionId","opts","initialOpts","caps","originalCaps","helpers","basePath","DEFAULT_BASE_PATH","relaxedSecurityEnabled","allowInsecure","denyInsecure","newCommandTimeoutMs","implicitWaitMs","locatorStrategies","webLocatorStrategies","managedDrivers","noCommandTimer","_eventHistory","commands","_constraints","_","cloneDeep","desiredCapabilityConstraints","eventEmitter","EventEmitter","_log","shutdownUnexpectedly","shouldValidateCaps","commandsQueueGuard","AsyncLock","settings","DeviceSettings","constructor","logger","getLogger","generateDriverLogPrefix","tmpDir","process","env","APPIUM_TMP_DIR","os","tmpdir","log","onUnexpectedShutdown","handler","on","driverData","isCommandsQueueEnabled","eventHistory","logEvent","eventName","Error","ts","Date","now","logTime","toTimeString","push","debug","getStatus","desiredCapConstraints","constraints","Object","assign","value","toPairs","presence","allowEmpty","sessionExists","driverForSession","logExtraCaps","extraCaps","difference","keys","length","warn","cap","validateDesiredCaps","e","errorAndThrow","errors","SessionNotCreatedError","message","isMjsonwpProtocol","protocol","PROTOCOLS","MJSONWP","isW3CProtocol","W3C","setProtocolMJSONWP","setProtocolW3C","isFeatureEnabled","name","includes","ensureFeatureEnabled","validateLocatorStrategy","strategy","webContext","validStrategies","join","concat","InvalidSelectorError","proxyActive","getProxyAvoidList","canProxy","proxyRouteIsAvoided","method","url","body","avoidSchema","isArray","avoidMethod","avoidPathRegex","isRegExp","normalizedUrl","replace","RegExp","escapeRegExp","test","addManagedDriver","driver","getManagedDrivers","clearNewCommandTimeout","clearTimeout"],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable no-unused-vars */\n/* eslint-disable require-await */\n\nimport { fs, logger, node } from '@appium/support';\nimport AsyncLock from 'async-lock';\nimport { EventEmitter } from 'events';\nimport _ from 'lodash';\nimport os from 'os';\nimport { DEFAULT_BASE_PATH, PROTOCOLS } from '../constants';\nimport { errors } from '../protocol';\nimport { validateCaps } from './capabilities';\nimport { desiredCapabilityConstraints } from './desired-caps';\nimport DeviceSettings from './device-settings';\nimport helpers from './helpers';\n\n// for compat with running tests transpiled and in-place\nconst {version: BASEDRIVER_VER} = fs.readPackageJsonFrom(__dirname);\n\nconst NEW_COMMAND_TIMEOUT_MS = 60 * 1000;\n\nconst ON_UNEXPECTED_SHUTDOWN_EVENT = 'onUnexpectedShutdown';\n/**\n * @implements {Core}\n */\nclass DriverCore {\n\n  /**\n   * Make the basedriver version available so for any driver which inherits from this package, we\n   * know which version of basedriver it inherited from\n   */\n  static baseVersion = BASEDRIVER_VER;\n\n  /**\n  * @type {string?}\n  */\n  sessionId = null;\n\n  /**\n  * @type {DriverOpts & Capabilities}\n  */\n  opts;\n\n  /**\n  * @type {DriverOpts}\n  */\n  initialOpts;\n\n  /**\n  * @type {Capabilities}\n  */\n  caps;\n\n  /**\n  * @type {W3CCapabilities}\n  */\n  originalCaps;\n\n  helpers = helpers;\n\n  /**\n  * basePath is used for several purposes, for example in setting up\n  * proxying to other drivers, since we need to know what the base path\n  * of any incoming request might look like. We set it to the default\n  * initially but it is automatically updated during any actual program\n  * execution by the routeConfiguringFunction, which is necessarily run as\n  * the entrypoint for any Appium server\n  */\n  basePath = DEFAULT_BASE_PATH;\n\n  relaxedSecurityEnabled = false;\n\n  /** @type {string[]} */\n  allowInsecure = [];\n\n  /** @type {string[]} */\n  denyInsecure = [];\n\n  newCommandTimeoutMs = NEW_COMMAND_TIMEOUT_MS;\n\n  implicitWaitMs = 0;\n\n  /** @type {string[]} */\n  locatorStrategies = [];\n\n  /** @type {string[]} */\n  webLocatorStrategies = [];\n\n  /** @type {Driver[]} */\n  managedDrivers = [];\n\n  /** @type {NodeJS.Timeout?} */\n  noCommandTimer = null;\n\n  /** @type {EventHistory} */\n  _eventHistory = {commands: []};\n\n  _constraints = _.cloneDeep(desiredCapabilityConstraints);\n\n  // used to handle driver events\n  /** @type {NodeJS.EventEmitter} */\n  eventEmitter = new EventEmitter();\n\n  /**\n  * @type {AppiumLogger}\n  */\n  _log;\n\n  /**\n  * @protected\n  */\n  shutdownUnexpectedly = false;\n\n  /**\n  * @type {boolean}\n  * @protected\n  */\n  shouldValidateCaps;\n\n  /**\n  * @protected\n  */\n  commandsQueueGuard = new AsyncLock();\n\n  /**\n  * settings should be instantiated by drivers which extend BaseDriver, but\n  * we set it to an empty DeviceSettings instance here to make sure that the\n  * default settings are applied even if an extending driver doesn't utilize\n  * the settings functionality itself\n  */\n  settings = new DeviceSettings();\n\n  constructor (\n    opts = /** @type {DriverOpts} */ ({}),\n    shouldValidateCaps = true,\n  ) {\n    this._log = logger.getLogger(helpers.generateDriverLogPrefix(this));\n\n    // setup state\n    this.opts = opts;\n\n    // use a custom tmp dir to avoid losing data and app when computer is\n    // restarted\n    this.opts.tmpDir =\n      this.opts.tmpDir || process.env.APPIUM_TMP_DIR || os.tmpdir();\n\n    // base-driver internals\n    this.shouldValidateCaps = shouldValidateCaps;\n\n    // keeping track of initial opts\n    this.initialOpts = _.cloneDeep(this.opts);\n\n    this.sessionId = null;\n  }\n\n  get log () {\n    return this._log;\n  }\n\n  /**\n  * Set a callback handler if needed to execute a custom piece of code\n  * when the driver is shut down unexpectedly. Multiple calls to this method\n  * will cause the handler to be executed mutiple times\n  *\n  * @param {(...args: any[]) => void} handler The code to be executed on unexpected shutdown.\n  * The function may accept one argument, which is the actual error instance, which\n  * caused the driver to shut down.\n  */\n  onUnexpectedShutdown (handler) {\n    this.eventEmitter.on(ON_UNEXPECTED_SHUTDOWN_EVENT, handler);\n  }\n\n  /**\n  * This property is used by AppiumDriver to store the data of the\n  * specific driver sessions. This data can be later used to adjust\n  * properties for driver instances running in parallel.\n  * Override it in inherited driver classes if necessary.\n  *\n  * @return {Record<string,unknown>} Driver properties mapping\n  */\n  get driverData () {\n    return {};\n  }\n\n  /**\n  * This property controls the way {#executeCommand} method\n  * handles new driver commands received from the client.\n  * Override it for inherited classes only in special cases.\n  *\n  * @return {boolean} If the returned value is true (default) then all the commands\n  *   received by the particular driver instance are going to be put into the queue,\n  *   so each following command will not be executed until the previous command\n  *   execution is completed. False value disables that queue, so each driver command\n  *   is executed independently and does not wait for anything.\n  */\n  get isCommandsQueueEnabled () {\n    return true;\n  }\n\n  /*\n  * make eventHistory a property and return a cloned object so a consumer can't\n  * inadvertently change data outside of logEvent\n  */\n  get eventHistory () {\n    return _.cloneDeep(this._eventHistory);\n  }\n\n  /**\n  * API method for driver developers to log timings for important events\n  * @param {string} eventName\n  */\n  logEvent (eventName) {\n    if (eventName === 'commands') {\n      throw new Error('Cannot log commands directly');\n    }\n    if (typeof eventName !== 'string') {\n      throw new Error(`Invalid eventName ${eventName}`);\n    }\n    if (!this._eventHistory[eventName]) {\n      this._eventHistory[eventName] = [];\n    }\n    const ts = Date.now();\n    const logTime = new Date(ts).toTimeString();\n    this._eventHistory[eventName].push(ts);\n    this.log.debug(`Event '${eventName}' logged at ${ts} (${logTime})`);\n  }\n\n  /**\n  * Overridden in appium driver, but here so that individual drivers can be\n  * tested with clients that poll\n  */\n  async getStatus () {\n    return {};\n  }\n\n  // we only want subclasses to ever extend the contraints\n  set desiredCapConstraints (constraints) {\n    this._constraints = Object.assign(this._constraints, constraints);\n    // 'presence' means different things in different versions of the validator,\n    // when we say 'true' we mean that it should not be able to be empty\n    for (const [, value] of _.toPairs(this._constraints)) {\n      if (value && value.presence === true) {\n        value.presence = {\n          allowEmpty: false,\n        };\n      }\n    }\n  }\n\n  get desiredCapConstraints () {\n    return this._constraints;\n  }\n\n  /**\n  * method required by MJSONWP in order to determine whether it should\n  * respond with an invalid session response\n  * @param {string} [sessionId]\n  * @returns {boolean}\n  */\n  sessionExists (sessionId) {\n    if (!sessionId) return false; // eslint-disable-line curly\n    return sessionId === this.sessionId;\n  }\n\n  /**\n  * method required by MJSONWP in order to determine if the command should\n  * be proxied directly to the driver\n  * @param {string} sessionId\n  * @returns {this | import('@appium/types').Driver}\n  */\n  driverForSession (sessionId) {\n    return this;\n  }\n\n  /**\n  *\n  * @param {Capabilities} caps\n  */\n  logExtraCaps (caps) {\n    let extraCaps = _.difference(_.keys(caps), _.keys(this._constraints));\n    if (extraCaps.length) {\n      this.log.warn(\n        `The following capabilities were provided, but are not ` +\n          `recognized by Appium:`,\n      );\n      for (const cap of extraCaps) {\n        this.log.warn(`  ${cap}`);\n      }\n    }\n  }\n\n  /**\n  *\n  * @param {Capabilities} caps\n  * @returns {boolean}\n  */\n  validateDesiredCaps (caps) {\n    if (!this.shouldValidateCaps) {\n      return true;\n    }\n\n    try {\n      validateCaps(caps, this._constraints);\n    } catch (e) {\n      this.log.errorAndThrow(\n        new errors.SessionNotCreatedError(\n          `The desiredCapabilities object was not valid for the ` +\n            `following reason(s): ${e.message}`,\n        ),\n      );\n    }\n\n    this.logExtraCaps(caps);\n\n    return true;\n  }\n\n  isMjsonwpProtocol () {\n    return this.protocol === PROTOCOLS.MJSONWP;\n  }\n\n  isW3CProtocol () {\n    return this.protocol === PROTOCOLS.W3C;\n  }\n\n  setProtocolMJSONWP () {\n    this.protocol = PROTOCOLS.MJSONWP;\n  }\n\n  setProtocolW3C () {\n    this.protocol = PROTOCOLS.W3C;\n  }\n\n  /**\n  * Check whether a given feature is enabled via its name\n  *\n  * @param {string} name - name of feature/command\n  *\n  * @returns {Boolean}\n  */\n  isFeatureEnabled (name) {\n    // if we have explicitly denied this feature, return false immediately\n    if (this.denyInsecure && _.includes(this.denyInsecure, name)) {\n      return false;\n    }\n\n    // if we specifically have allowed the feature, return true\n    if (this.allowInsecure && _.includes(this.allowInsecure, name)) {\n      return true;\n    }\n\n    // otherwise, if we've globally allowed insecure features and not denied\n    // this one, return true\n    if (this.relaxedSecurityEnabled) {\n      return true;\n    }\n\n    // if we haven't allowed anything insecure, then reject\n    return false;\n  }\n\n  /**\n  * Assert that a given feature is enabled and throw a helpful error if it's\n  * not\n  *\n  * @param {string} name - name of feature/command\n  */\n  ensureFeatureEnabled (name) {\n    if (!this.isFeatureEnabled(name)) {\n      throw new Error(\n        `Potentially insecure feature '${name}' has not been ` +\n          `enabled. If you want to enable this feature and accept ` +\n          `the security ramifications, please do so by following ` +\n          `the documented instructions at https://github.com/appium` +\n          `/appium/blob/master/docs/en/writing-running-appium/security.md`,\n      );\n    }\n  }\n\n  /**\n  *\n  * @param {string} strategy\n  * @param {boolean} [webContext]\n  */\n  validateLocatorStrategy (strategy, webContext = false) {\n    let validStrategies = this.locatorStrategies;\n    this.log.debug(\n      `Valid locator strategies for this request: ${validStrategies.join(\n        ', ',\n      )}`,\n    );\n\n    if (webContext) {\n      validStrategies = validStrategies.concat(this.webLocatorStrategies);\n    }\n\n    if (!_.includes(validStrategies, strategy)) {\n      throw new errors.InvalidSelectorError(\n        `Locator Strategy '${strategy}' is not supported for this session`,\n      );\n    }\n  }\n\n  /**\n  *\n  * @param {string} [sessionId]\n  * @returns {boolean}\n  */\n  proxyActive (sessionId) {\n    return false;\n  }\n\n  /**\n  *\n  * @param {string} sessionId\n  * @returns {[string, RegExp][]}\n  */\n  getProxyAvoidList (sessionId) {\n    return [];\n  }\n\n  /**\n  *\n  * @param {string} [sessionId]\n  * @returns {boolean}\n  */\n  canProxy (sessionId) {\n    return false;\n  }\n\n  /**\n  * Whether a given command route (expressed as method and url) should not be\n  * proxied according to this driver\n  *\n  * @param {string} sessionId - the current sessionId (in case the driver runs\n  * multiple session ids and requires it). This is not used in this method but\n  * should be made available to overridden methods.\n  * @param {import('@appium/types').HTTPMethod} method - HTTP method of the route\n  * @param {string} url - url of the route\n  * @param {any} [body] - webdriver request body\n  *\n  * @returns {boolean} - whether the route should be avoided\n  */\n  proxyRouteIsAvoided (sessionId, method, url, body) {\n    for (let avoidSchema of this.getProxyAvoidList(sessionId)) {\n      if (!_.isArray(avoidSchema) || avoidSchema.length !== 2) {\n        throw new Error('Proxy avoidance must be a list of pairs');\n      }\n      let [avoidMethod, avoidPathRegex] = avoidSchema;\n      if (!_.includes(['GET', 'POST', 'DELETE'], avoidMethod)) {\n        throw new Error(`Unrecognized proxy avoidance method '${avoidMethod}'`);\n      }\n      if (!_.isRegExp(avoidPathRegex)) {\n        throw new Error('Proxy avoidance path must be a regular expression');\n      }\n      let normalizedUrl = url.replace(\n        new RegExp(`^${_.escapeRegExp(this.basePath)}`),\n        '',\n      );\n      if (avoidMethod === method && avoidPathRegex.test(normalizedUrl)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  /**\n  *\n  * @param {Driver} driver\n  */\n  addManagedDriver (driver) {\n    this.managedDrivers.push(driver);\n  }\n\n  getManagedDrivers () {\n    return this.managedDrivers;\n  }\n\n  async clearNewCommandTimeout () {\n    if (this.noCommandTimer) {\n      clearTimeout(this.noCommandTimer);\n      this.noCommandTimer = null;\n    }\n  }\n}\n\nexport {DriverCore};\n\n/**\n * @typedef {import('@appium/types').Capabilities} Capabilities\n * @typedef {import('@appium/types').W3CCapabilities} W3CCapabilities\n * @typedef {import('@appium/types').Driver} Driver\n * @typedef {import('@appium/types').Core} Core\n * @typedef {import('@appium/types').ServerArgs} DriverOpts\n * @typedef {import('@appium/types').EventHistory} EventHistory\n * @typedef {import('@appium/types').AppiumLogger} AppiumLogger\n */\n"]}
@@ -1,3 +1,7 @@
1
+ /**
2
+ * Maximum size (in bytes) of a given driver's settings object (which is internal to {@linkcode DriverSettings}).
3
+ */
4
+ export const MAX_SETTINGS_SIZE: number;
1
5
  export default DeviceSettings;
2
6
  export type IDeviceSettings<T> = import('@appium/types').DeviceSettings<T>;
3
7
  /**
@@ -6,8 +10,7 @@ export type IDeviceSettings<T> = import('@appium/types').DeviceSettings<T>;
6
10
  */
7
11
  export class DeviceSettings<T extends Record<string, unknown>> implements IDeviceSettings<T> {
8
12
  /**
9
- * `onSettingsUpdate` is _required_ if settings will ever be updated; otherwise
10
- * an error will occur at runtime.
13
+ * Creates a _shallow copy_ of the `defaultSettings` parameter!
11
14
  * @param {T} [defaultSettings]
12
15
  * @param {import('@appium/types').SettingsUpdateListener<T>} [onSettingsUpdate]
13
16
  */
@@ -19,9 +22,9 @@ export class DeviceSettings<T extends Record<string, unknown>> implements IDevic
19
22
  protected _settings: T;
20
23
  /**
21
24
  * @protected
22
- * @type {import('@appium/types').SettingsUpdateListener<T>|undefined}
25
+ * @type {import('@appium/types').SettingsUpdateListener<T>}
23
26
  */
24
- protected _onSettingsUpdate: import('@appium/types').SettingsUpdateListener<T> | undefined;
27
+ protected _onSettingsUpdate: import('@appium/types').SettingsUpdateListener<T>;
25
28
  /**
26
29
  * calls updateSettings from implementing driver every time a setting is changed.
27
30
  * @param {T} newSettings
@@ -1 +1 @@
1
- {"version":3,"file":"device-settings.d.ts","sourceRoot":"","sources":["../../../lib/basedriver/device-settings.js"],"names":[],"mappings":";iCAmFa,OAAO,eAAe,EAAE,cAAc,CAAC,CAAC,CAAC;AA1EtD;;;GAGG;AACH,0FAFgC,CAAC;IAgB/B;;;;;OAKG;IACH,+HAGC;IArBD;;;OAGG;IACH,qBAFU,CAAC,CAED;IAEV;;;OAGG;IACH,6BAFU,OAAO,eAAe,EAAE,sBAAsB,CAAC,CAAC,CAAC,GAAC,SAAS,CAEnD;IAalB;;;OAGG;IACH,oBAFW,CAAC,iBA+BX;IAED,iBAEC;CACF"}
1
+ {"version":3,"file":"device-settings.d.ts","sourceRoot":"","sources":["../../../lib/basedriver/device-settings.js"],"names":[],"mappings":"AAOA;;GAEG;AACH,uCAAkD;;iCAoErC,OAAO,eAAe,EAAE,cAAc,CAAC,CAAC,CAAC;AAlEtD;;;GAGG;AACH,0FAFgC,CAAC;IAgB/B;;;;OAIG;IACH,+HAGC;IApBD;;;OAGG;IACH,qBAFU,CAAC,CAED;IAEV;;;OAGG;IACH,6BAFU,OAAO,eAAe,EAAE,sBAAsB,CAAC,CAAC,CAAC,CAEzC;IAYlB;;;OAGG;IACH,oBAFW,CAAC,iBAwBX;IAED,iBAEC;CACF"}
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.default = exports.DeviceSettings = void 0;
8
+ exports.default = exports.MAX_SETTINGS_SIZE = exports.DeviceSettings = void 0;
9
9
 
10
10
  require("source-map-support/register");
11
11
 
@@ -18,6 +18,7 @@ var _support = require("@appium/support");
18
18
  var _errors = require("../protocol/errors");
19
19
 
20
20
  const MAX_SETTINGS_SIZE = 20 * 1024 * 1024;
21
+ exports.MAX_SETTINGS_SIZE = MAX_SETTINGS_SIZE;
21
22
 
22
23
  class DeviceSettings {
23
24
  _settings;
@@ -26,7 +27,7 @@ class DeviceSettings {
26
27
  constructor(defaultSettings, onSettingsUpdate) {
27
28
  this._settings = { ...(defaultSettings !== null && defaultSettings !== void 0 ? defaultSettings : {})
28
29
  };
29
- this._onSettingsUpdate = onSettingsUpdate;
30
+ this._onSettingsUpdate = onSettingsUpdate !== null && onSettingsUpdate !== void 0 ? onSettingsUpdate : async () => {};
30
31
  }
31
32
 
32
33
  async update(newSettings) {
@@ -40,12 +41,6 @@ class DeviceSettings {
40
41
  throw new _errors.errors.InvalidArgumentError(`New settings cannot be applied, because the overall ` + `object size exceeds the allowed limit of ${_support.util.toReadableSizeString(MAX_SETTINGS_SIZE)}`);
41
42
  }
42
43
 
43
- if (!_lodash.default.isFunction(this._onSettingsUpdate)) {
44
- _logger.default.errorAndThrow(`Unable to update settings; ` + `onSettingsUpdate method not found on '${this.constructor.name}'`);
45
-
46
- return;
47
- }
48
-
49
44
  const props = _lodash.default.keys(newSettings);
50
45
 
51
46
  for (const prop of props) {
@@ -71,4 +66,4 @@ class DeviceSettings {
71
66
  exports.DeviceSettings = DeviceSettings;
72
67
  var _default = DeviceSettings;
73
68
  exports.default = _default;
74
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9iYXNlZHJpdmVyL2RldmljZS1zZXR0aW5ncy5qcyJdLCJuYW1lcyI6WyJNQVhfU0VUVElOR1NfU0laRSIsIkRldmljZVNldHRpbmdzIiwiX3NldHRpbmdzIiwiX29uU2V0dGluZ3NVcGRhdGUiLCJjb25zdHJ1Y3RvciIsImRlZmF1bHRTZXR0aW5ncyIsIm9uU2V0dGluZ3NVcGRhdGUiLCJ1cGRhdGUiLCJuZXdTZXR0aW5ncyIsIl8iLCJpc1BsYWluT2JqZWN0IiwiZXJyb3JzIiwiSW52YWxpZEFyZ3VtZW50RXJyb3IiLCJKU09OIiwic3RyaW5naWZ5Iiwibm9kZSIsImdldE9iamVjdFNpemUiLCJ1dGlsIiwidG9SZWFkYWJsZVNpemVTdHJpbmciLCJpc0Z1bmN0aW9uIiwibG9nIiwiZXJyb3JBbmRUaHJvdyIsIm5hbWUiLCJwcm9wcyIsImtleXMiLCJwcm9wIiwiaXNVbmRlZmluZWQiLCJkZWJ1ZyIsImdldFNldHRpbmdzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUVBOztBQUNBOztBQUNBOztBQUNBOztBQUVBLE1BQU1BLGlCQUFpQixHQUFHLEtBQUssSUFBTCxHQUFZLElBQXRDOztBQU1BLE1BQU1DLGNBQU4sQ0FBcUI7QUFNbkJDLEVBQUFBLFNBQVM7QUFNVEMsRUFBQUEsaUJBQWlCOztBQVFqQkMsRUFBQUEsV0FBVyxDQUFFQyxlQUFGLEVBQW1CQyxnQkFBbkIsRUFBcUM7QUFDOUMsU0FBS0osU0FBTCxHQUFrQyxFQUFDLElBQUlHLGVBQUosYUFBSUEsZUFBSixjQUFJQSxlQUFKLEdBQXVCLEVBQXZCO0FBQUQsS0FBbEM7QUFDQSxTQUFLRixpQkFBTCxHQUF5QkcsZ0JBQXpCO0FBQ0Q7O0FBTVcsUUFBTkMsTUFBTSxDQUFFQyxXQUFGLEVBQWU7QUFDekIsUUFBSSxDQUFDQyxnQkFBRUMsYUFBRixDQUFnQkYsV0FBaEIsQ0FBTCxFQUFtQztBQUNqQyxZQUFNLElBQUlHLGVBQU9DLG9CQUFYLENBQWlDLHdEQUFELEdBQ25DLEdBQUVDLElBQUksQ0FBQ0MsU0FBTCxDQUFlTixXQUFmLENBQTRCLFVBRDNCLENBQU47QUFFRDs7QUFFRCxRQUFJTyxjQUFLQyxhQUFMLENBQW1CLEVBQUMsR0FBRyxLQUFLZCxTQUFUO0FBQW9CLFNBQUdNO0FBQXZCLEtBQW5CLEtBQTJEUixpQkFBL0QsRUFBa0Y7QUFDaEYsWUFBTSxJQUFJVyxlQUFPQyxvQkFBWCxDQUFpQyxzREFBRCxHQUNuQyw0Q0FBMkNLLGNBQUtDLG9CQUFMLENBQTBCbEIsaUJBQTFCLENBQTZDLEVBRHJGLENBQU47QUFFRDs7QUFFRCxRQUFJLENBQUNTLGdCQUFFVSxVQUFGLENBQWEsS0FBS2hCLGlCQUFsQixDQUFMLEVBQTJDO0FBQ3pDaUIsc0JBQUlDLGFBQUosQ0FBbUIsNkJBQUQsR0FDakIseUNBQXdDLEtBQUtqQixXQUFMLENBQWlCa0IsSUFBSyxHQUQvRDs7QUFFQTtBQUNEOztBQUVELFVBQU1DLEtBQUssR0FBdUNkLGdCQUFFZSxJQUFGLENBQU9oQixXQUFQLENBQWxEOztBQUNBLFNBQUssTUFBTWlCLElBQVgsSUFBbUJGLEtBQW5CLEVBQTBCO0FBQ3hCLFVBQUksQ0FBQ2QsZ0JBQUVpQixXQUFGLENBQWMsS0FBS3hCLFNBQUwsQ0FBZXVCLElBQWYsQ0FBZCxDQUFMLEVBQTBDO0FBQ3hDLFlBQUksS0FBS3ZCLFNBQUwsQ0FBZXVCLElBQWYsTUFBeUJqQixXQUFXLENBQUNpQixJQUFELENBQXhDLEVBQWdEO0FBQzlDTCwwQkFBSU8sS0FBSixDQUFXLGlCQUFnQkYsSUFBSyxzREFBaEM7O0FBQ0E7QUFDRDtBQUNGOztBQUVELFlBQU0sS0FBS3RCLGlCQUFMLENBQXVCc0IsSUFBdkIsRUFBNkJqQixXQUFXLENBQUNpQixJQUFELENBQXhDLEVBQWdELEtBQUt2QixTQUFMLENBQWV1QixJQUFmLENBQWhELENBQU47QUFDQSxXQUFLdkIsU0FBTCxDQUFldUIsSUFBZixJQUF1QmpCLFdBQVcsQ0FBQ2lCLElBQUQsQ0FBbEM7QUFDRDtBQUNGOztBQUVERyxFQUFBQSxXQUFXLEdBQUk7QUFDYixXQUFPLEtBQUsxQixTQUFaO0FBQ0Q7O0FBOURrQjs7O2VBaUVORCxjIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgbG9nIGZyb20gJy4vbG9nZ2VyJztcbmltcG9ydCB7IG5vZGUsIHV0aWwgfSBmcm9tICdAYXBwaXVtL3N1cHBvcnQnO1xuaW1wb3J0IHsgZXJyb3JzIH0gZnJvbSAnLi4vcHJvdG9jb2wvZXJyb3JzJztcblxuY29uc3QgTUFYX1NFVFRJTkdTX1NJWkUgPSAyMCAqIDEwMjQgKiAxMDI0OyAvLyAyMCBNQlxuXG4vKipcbiAqIEB0ZW1wbGF0ZSB7UmVjb3JkPHN0cmluZyx1bmtub3duPn0gVFxuICogQGltcGxlbWVudHMge0lEZXZpY2VTZXR0aW5nczxUPn1cbiAqL1xuY2xhc3MgRGV2aWNlU2V0dGluZ3Mge1xuXG4gIC8qKlxuICAgKiBAcHJvdGVjdGVkXG4gICAqIEB0eXBlIHtUfVxuICAgKi9cbiAgX3NldHRpbmdzO1xuXG4gIC8qKlxuICAgKiBAcHJvdGVjdGVkXG4gICAqIEB0eXBlIHtpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5TZXR0aW5nc1VwZGF0ZUxpc3RlbmVyPFQ+fHVuZGVmaW5lZH1cbiAgICovXG4gIF9vblNldHRpbmdzVXBkYXRlO1xuXG4gIC8qKlxuICAgKiBgb25TZXR0aW5nc1VwZGF0ZWAgaXMgX3JlcXVpcmVkXyBpZiBzZXR0aW5ncyB3aWxsIGV2ZXIgYmUgdXBkYXRlZDsgb3RoZXJ3aXNlXG4gICAqIGFuIGVycm9yIHdpbGwgb2NjdXIgYXQgcnVudGltZS5cbiAgICogQHBhcmFtIHtUfSBbZGVmYXVsdFNldHRpbmdzXVxuICAgKiBAcGFyYW0ge2ltcG9ydCgnQGFwcGl1bS90eXBlcycpLlNldHRpbmdzVXBkYXRlTGlzdGVuZXI8VD59IFtvblNldHRpbmdzVXBkYXRlXVxuICAgKi9cbiAgY29uc3RydWN0b3IgKGRlZmF1bHRTZXR0aW5ncywgb25TZXR0aW5nc1VwZGF0ZSkge1xuICAgIHRoaXMuX3NldHRpbmdzID0gLyoqIEB0eXBlIHtUfSAqLyh7Li4uKGRlZmF1bHRTZXR0aW5ncyA/PyB7fSl9KTtcbiAgICB0aGlzLl9vblNldHRpbmdzVXBkYXRlID0gb25TZXR0aW5nc1VwZGF0ZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBjYWxscyB1cGRhdGVTZXR0aW5ncyBmcm9tIGltcGxlbWVudGluZyBkcml2ZXIgZXZlcnkgdGltZSBhIHNldHRpbmcgaXMgY2hhbmdlZC5cbiAgICogQHBhcmFtIHtUfSBuZXdTZXR0aW5nc1xuICAgKi9cbiAgYXN5bmMgdXBkYXRlIChuZXdTZXR0aW5ncykge1xuICAgIGlmICghXy5pc1BsYWluT2JqZWN0KG5ld1NldHRpbmdzKSkge1xuICAgICAgdGhyb3cgbmV3IGVycm9ycy5JbnZhbGlkQXJndW1lbnRFcnJvcihgU2V0dGluZ3MgdXBkYXRlIHNob3VsZCBiZSBjYWxsZWQgd2l0aCB2YWxpZCBKU09OLiBHb3QgYCArXG4gICAgICAgIGAke0pTT04uc3RyaW5naWZ5KG5ld1NldHRpbmdzKX0gaW5zdGVhZGApO1xuICAgIH1cblxuICAgIGlmIChub2RlLmdldE9iamVjdFNpemUoey4uLnRoaXMuX3NldHRpbmdzLCAuLi5uZXdTZXR0aW5nc30pID49IE1BWF9TRVRUSU5HU19TSVpFKSB7XG4gICAgICB0aHJvdyBuZXcgZXJyb3JzLkludmFsaWRBcmd1bWVudEVycm9yKGBOZXcgc2V0dGluZ3MgY2Fubm90IGJlIGFwcGxpZWQsIGJlY2F1c2UgdGhlIG92ZXJhbGwgYCArXG4gICAgICAgIGBvYmplY3Qgc2l6ZSBleGNlZWRzIHRoZSBhbGxvd2VkIGxpbWl0IG9mICR7dXRpbC50b1JlYWRhYmxlU2l6ZVN0cmluZyhNQVhfU0VUVElOR1NfU0laRSl9YCk7XG4gICAgfVxuXG4gICAgaWYgKCFfLmlzRnVuY3Rpb24odGhpcy5fb25TZXR0aW5nc1VwZGF0ZSkpIHtcbiAgICAgIGxvZy5lcnJvckFuZFRocm93KGBVbmFibGUgdG8gdXBkYXRlIHNldHRpbmdzOyBgICtcbiAgICAgIGBvblNldHRpbmdzVXBkYXRlIG1ldGhvZCBub3QgZm91bmQgb24gJyR7dGhpcy5jb25zdHJ1Y3Rvci5uYW1lfSdgKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBwcm9wcyA9IC8qKiBAdHlwZSB7KGtleW9mIFQgJiBzdHJpbmcpW119ICovKF8ua2V5cyhuZXdTZXR0aW5ncykpO1xuICAgIGZvciAoY29uc3QgcHJvcCBvZiBwcm9wcykge1xuICAgICAgaWYgKCFfLmlzVW5kZWZpbmVkKHRoaXMuX3NldHRpbmdzW3Byb3BdKSkge1xuICAgICAgICBpZiAodGhpcy5fc2V0dGluZ3NbcHJvcF0gPT09IG5ld1NldHRpbmdzW3Byb3BdKSB7XG4gICAgICAgICAgbG9nLmRlYnVnKGBUaGUgdmFsdWUgb2YgJyR7cHJvcH0nIHNldHRpbmcgZGlkIG5vdCBjaGFuZ2UuIFNraXBwaW5nIHRoZSB1cGRhdGUgZm9yIGl0YCk7XG4gICAgICAgICAgY29udGludWU7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIC8vIHVwZGF0ZSBzZXR0aW5nIG9ubHkgd2hlbiB0aGVyZSBpcyB1cGRhdGVTZXR0aW5ncyBkZWZpbmVkLlxuICAgICAgYXdhaXQgdGhpcy5fb25TZXR0aW5nc1VwZGF0ZShwcm9wLCBuZXdTZXR0aW5nc1twcm9wXSwgdGhpcy5fc2V0dGluZ3NbcHJvcF0pO1xuICAgICAgdGhpcy5fc2V0dGluZ3NbcHJvcF0gPSBuZXdTZXR0aW5nc1twcm9wXTtcbiAgICB9XG4gIH1cblxuICBnZXRTZXR0aW5ncyAoKSB7XG4gICAgcmV0dXJuIHRoaXMuX3NldHRpbmdzO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IERldmljZVNldHRpbmdzO1xuZXhwb3J0IHsgRGV2aWNlU2V0dGluZ3MgfTtcblxuLyoqXG4gKiBAdGVtcGxhdGUgVFxuICogQHR5cGVkZWYge2ltcG9ydCgnQGFwcGl1bS90eXBlcycpLkRldmljZVNldHRpbmdzPFQ+fSBJRGV2aWNlU2V0dGluZ3NcbiAqL1xuIl19
69
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9iYXNlZHJpdmVyL2RldmljZS1zZXR0aW5ncy5qcyJdLCJuYW1lcyI6WyJNQVhfU0VUVElOR1NfU0laRSIsIkRldmljZVNldHRpbmdzIiwiX3NldHRpbmdzIiwiX29uU2V0dGluZ3NVcGRhdGUiLCJjb25zdHJ1Y3RvciIsImRlZmF1bHRTZXR0aW5ncyIsIm9uU2V0dGluZ3NVcGRhdGUiLCJ1cGRhdGUiLCJuZXdTZXR0aW5ncyIsIl8iLCJpc1BsYWluT2JqZWN0IiwiZXJyb3JzIiwiSW52YWxpZEFyZ3VtZW50RXJyb3IiLCJKU09OIiwic3RyaW5naWZ5Iiwibm9kZSIsImdldE9iamVjdFNpemUiLCJ1dGlsIiwidG9SZWFkYWJsZVNpemVTdHJpbmciLCJwcm9wcyIsImtleXMiLCJwcm9wIiwiaXNVbmRlZmluZWQiLCJsb2ciLCJkZWJ1ZyIsImdldFNldHRpbmdzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUVBOztBQUNBOztBQUNBOztBQUNBOztBQUtPLE1BQU1BLGlCQUFpQixHQUFHLEtBQUssSUFBTCxHQUFZLElBQXRDOzs7QUFNUCxNQUFNQyxjQUFOLENBQXFCO0FBTW5CQyxFQUFBQSxTQUFTO0FBTVRDLEVBQUFBLGlCQUFpQjs7QUFPakJDLEVBQUFBLFdBQVcsQ0FBRUMsZUFBRixFQUFtQkMsZ0JBQW5CLEVBQXFDO0FBQzlDLFNBQUtKLFNBQUwsR0FBa0MsRUFBQyxJQUFJRyxlQUFKLGFBQUlBLGVBQUosY0FBSUEsZUFBSixHQUF1QixFQUF2QjtBQUFELEtBQWxDO0FBQ0EsU0FBS0YsaUJBQUwsR0FBeUJHLGdCQUF6QixhQUF5QkEsZ0JBQXpCLGNBQXlCQSxnQkFBekIsR0FBOEMsWUFBWSxDQUFFLENBQTVEO0FBQ0Q7O0FBTVcsUUFBTkMsTUFBTSxDQUFFQyxXQUFGLEVBQWU7QUFDekIsUUFBSSxDQUFDQyxnQkFBRUMsYUFBRixDQUFnQkYsV0FBaEIsQ0FBTCxFQUFtQztBQUNqQyxZQUFNLElBQUlHLGVBQU9DLG9CQUFYLENBQWlDLHdEQUFELEdBQ25DLEdBQUVDLElBQUksQ0FBQ0MsU0FBTCxDQUFlTixXQUFmLENBQTRCLFVBRDNCLENBQU47QUFFRDs7QUFFRCxRQUFJTyxjQUFLQyxhQUFMLENBQW1CLEVBQUMsR0FBRyxLQUFLZCxTQUFUO0FBQW9CLFNBQUdNO0FBQXZCLEtBQW5CLEtBQTJEUixpQkFBL0QsRUFBa0Y7QUFDaEYsWUFBTSxJQUFJVyxlQUFPQyxvQkFBWCxDQUFpQyxzREFBRCxHQUNuQyw0Q0FBMkNLLGNBQUtDLG9CQUFMLENBQTBCbEIsaUJBQTFCLENBQTZDLEVBRHJGLENBQU47QUFFRDs7QUFFRCxVQUFNbUIsS0FBSyxHQUF1Q1YsZ0JBQUVXLElBQUYsQ0FBT1osV0FBUCxDQUFsRDs7QUFDQSxTQUFLLE1BQU1hLElBQVgsSUFBbUJGLEtBQW5CLEVBQTBCO0FBQ3hCLFVBQUksQ0FBQ1YsZ0JBQUVhLFdBQUYsQ0FBYyxLQUFLcEIsU0FBTCxDQUFlbUIsSUFBZixDQUFkLENBQUwsRUFBMEM7QUFDeEMsWUFBSSxLQUFLbkIsU0FBTCxDQUFlbUIsSUFBZixNQUF5QmIsV0FBVyxDQUFDYSxJQUFELENBQXhDLEVBQWdEO0FBQzlDRSwwQkFBSUMsS0FBSixDQUFXLGlCQUFnQkgsSUFBSyxzREFBaEM7O0FBQ0E7QUFDRDtBQUNGOztBQUNELFlBQU0sS0FBS2xCLGlCQUFMLENBQXVCa0IsSUFBdkIsRUFBNkJiLFdBQVcsQ0FBQ2EsSUFBRCxDQUF4QyxFQUFnRCxLQUFLbkIsU0FBTCxDQUFlbUIsSUFBZixDQUFoRCxDQUFOO0FBQ0EsV0FBS25CLFNBQUwsQ0FBZW1CLElBQWYsSUFBdUJiLFdBQVcsQ0FBQ2EsSUFBRCxDQUFsQztBQUNEO0FBQ0Y7O0FBRURJLEVBQUFBLFdBQVcsR0FBSTtBQUNiLFdBQU8sS0FBS3ZCLFNBQVo7QUFDRDs7QUF0RGtCOzs7ZUF5RE5ELGMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAdHMtY2hlY2tcblxuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCBsb2cgZnJvbSAnLi9sb2dnZXInO1xuaW1wb3J0IHsgbm9kZSwgdXRpbCB9IGZyb20gJ0BhcHBpdW0vc3VwcG9ydCc7XG5pbXBvcnQgeyBlcnJvcnMgfSBmcm9tICcuLi9wcm90b2NvbC9lcnJvcnMnO1xuXG4vKipcbiAqIE1heGltdW0gc2l6ZSAoaW4gYnl0ZXMpIG9mIGEgZ2l2ZW4gZHJpdmVyJ3Mgc2V0dGluZ3Mgb2JqZWN0ICh3aGljaCBpcyBpbnRlcm5hbCB0byB7QGxpbmtjb2RlIERyaXZlclNldHRpbmdzfSkuXG4gKi9cbmV4cG9ydCBjb25zdCBNQVhfU0VUVElOR1NfU0laRSA9IDIwICogMTAyNCAqIDEwMjQ7IC8vIDIwIE1CXG5cbi8qKlxuICogQHRlbXBsYXRlIHtSZWNvcmQ8c3RyaW5nLHVua25vd24+fSBUXG4gKiBAaW1wbGVtZW50cyB7SURldmljZVNldHRpbmdzPFQ+fVxuICovXG5jbGFzcyBEZXZpY2VTZXR0aW5ncyB7XG5cbiAgLyoqXG4gICAqIEBwcm90ZWN0ZWRcbiAgICogQHR5cGUge1R9XG4gICAqL1xuICBfc2V0dGluZ3M7XG5cbiAgLyoqXG4gICAqIEBwcm90ZWN0ZWRcbiAgICogQHR5cGUge2ltcG9ydCgnQGFwcGl1bS90eXBlcycpLlNldHRpbmdzVXBkYXRlTGlzdGVuZXI8VD59XG4gICAqL1xuICBfb25TZXR0aW5nc1VwZGF0ZTtcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIF9zaGFsbG93IGNvcHlfIG9mIHRoZSBgZGVmYXVsdFNldHRpbmdzYCBwYXJhbWV0ZXIhXG4gICAqIEBwYXJhbSB7VH0gW2RlZmF1bHRTZXR0aW5nc11cbiAgICogQHBhcmFtIHtpbXBvcnQoJ0BhcHBpdW0vdHlwZXMnKS5TZXR0aW5nc1VwZGF0ZUxpc3RlbmVyPFQ+fSBbb25TZXR0aW5nc1VwZGF0ZV1cbiAgICovXG4gIGNvbnN0cnVjdG9yIChkZWZhdWx0U2V0dGluZ3MsIG9uU2V0dGluZ3NVcGRhdGUpIHtcbiAgICB0aGlzLl9zZXR0aW5ncyA9IC8qKiBAdHlwZSB7VH0gKi8oey4uLihkZWZhdWx0U2V0dGluZ3MgPz8ge30pfSk7XG4gICAgdGhpcy5fb25TZXR0aW5nc1VwZGF0ZSA9IG9uU2V0dGluZ3NVcGRhdGUgPz8gKGFzeW5jICgpID0+IHt9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBjYWxscyB1cGRhdGVTZXR0aW5ncyBmcm9tIGltcGxlbWVudGluZyBkcml2ZXIgZXZlcnkgdGltZSBhIHNldHRpbmcgaXMgY2hhbmdlZC5cbiAgICogQHBhcmFtIHtUfSBuZXdTZXR0aW5nc1xuICAgKi9cbiAgYXN5bmMgdXBkYXRlIChuZXdTZXR0aW5ncykge1xuICAgIGlmICghXy5pc1BsYWluT2JqZWN0KG5ld1NldHRpbmdzKSkge1xuICAgICAgdGhyb3cgbmV3IGVycm9ycy5JbnZhbGlkQXJndW1lbnRFcnJvcihgU2V0dGluZ3MgdXBkYXRlIHNob3VsZCBiZSBjYWxsZWQgd2l0aCB2YWxpZCBKU09OLiBHb3QgYCArXG4gICAgICAgIGAke0pTT04uc3RyaW5naWZ5KG5ld1NldHRpbmdzKX0gaW5zdGVhZGApO1xuICAgIH1cblxuICAgIGlmIChub2RlLmdldE9iamVjdFNpemUoey4uLnRoaXMuX3NldHRpbmdzLCAuLi5uZXdTZXR0aW5nc30pID49IE1BWF9TRVRUSU5HU19TSVpFKSB7XG4gICAgICB0aHJvdyBuZXcgZXJyb3JzLkludmFsaWRBcmd1bWVudEVycm9yKGBOZXcgc2V0dGluZ3MgY2Fubm90IGJlIGFwcGxpZWQsIGJlY2F1c2UgdGhlIG92ZXJhbGwgYCArXG4gICAgICAgIGBvYmplY3Qgc2l6ZSBleGNlZWRzIHRoZSBhbGxvd2VkIGxpbWl0IG9mICR7dXRpbC50b1JlYWRhYmxlU2l6ZVN0cmluZyhNQVhfU0VUVElOR1NfU0laRSl9YCk7XG4gICAgfVxuXG4gICAgY29uc3QgcHJvcHMgPSAvKiogQHR5cGUgeyhrZXlvZiBUICYgc3RyaW5nKVtdfSAqLyhfLmtleXMobmV3U2V0dGluZ3MpKTtcbiAgICBmb3IgKGNvbnN0IHByb3Agb2YgcHJvcHMpIHtcbiAgICAgIGlmICghXy5pc1VuZGVmaW5lZCh0aGlzLl9zZXR0aW5nc1twcm9wXSkpIHtcbiAgICAgICAgaWYgKHRoaXMuX3NldHRpbmdzW3Byb3BdID09PSBuZXdTZXR0aW5nc1twcm9wXSkge1xuICAgICAgICAgIGxvZy5kZWJ1ZyhgVGhlIHZhbHVlIG9mICcke3Byb3B9JyBzZXR0aW5nIGRpZCBub3QgY2hhbmdlLiBTa2lwcGluZyB0aGUgdXBkYXRlIGZvciBpdGApO1xuICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBhd2FpdCB0aGlzLl9vblNldHRpbmdzVXBkYXRlKHByb3AsIG5ld1NldHRpbmdzW3Byb3BdLCB0aGlzLl9zZXR0aW5nc1twcm9wXSk7XG4gICAgICB0aGlzLl9zZXR0aW5nc1twcm9wXSA9IG5ld1NldHRpbmdzW3Byb3BdO1xuICAgIH1cbiAgfVxuXG4gIGdldFNldHRpbmdzICgpIHtcbiAgICByZXR1cm4gdGhpcy5fc2V0dGluZ3M7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgRGV2aWNlU2V0dGluZ3M7XG5leHBvcnQgeyBEZXZpY2VTZXR0aW5ncyB9O1xuXG4vKipcbiAqIEB0ZW1wbGF0ZSBUXG4gKiBAdHlwZWRlZiB7aW1wb3J0KCdAYXBwaXVtL3R5cGVzJykuRGV2aWNlU2V0dGluZ3M8VD59IElEZXZpY2VTZXR0aW5nc1xuICovXG4iXX0=
@@ -247,7 +247,7 @@ async function configureApp(app, options = {}) {
247
247
 
248
248
  _logger.default.info(`The application at '${cachedPath}' does not exist anymore ` + `or its integrity has been damaged. Deleting it from the internal cache`);
249
249
 
250
- APPLICATIONS_CACHE.del(app);
250
+ APPLICATIONS_CACHE.delete(app);
251
251
  }
252
252
 
253
253
  let fileName = null;
@@ -348,7 +348,7 @@ async function configureApp(app, options = {}) {
348
348
 
349
349
  _logger.default.info(`The application at '${fullPath}' does not exist anymore ` + `or its integrity has been damaged. Deleting it from the cache`);
350
350
 
351
- APPLICATIONS_CACHE.del(app);
351
+ APPLICATIONS_CACHE.delete(app);
352
352
  }
353
353
 
354
354
  const tmpRoot = await _support.tempDir.openDir();
@@ -545,4 +545,4 @@ var _default = {
545
545
  generateDriverLogPrefix
546
546
  };
547
547
  exports.default = _default;
548
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/basedriver/helpers.js"],"names":["IPA_EXT","ZIP_EXTS","ZIP_MIME_TYPES","CACHED_APPS_MAX_AGE","MAX_CACHED_APPS","APPLICATIONS_CACHE","LRU","max","ttl","updateAgeOnGet","dispose","app","fullPath","logger","info","fs","rimraf","noDisposeOnSet","APPLICATIONS_CACHE_GUARD","AsyncLock","SANITIZE_REPLACEMENT","DEFAULT_BASENAME","APP_DOWNLOAD_TIMEOUT_MS","process","on","size","appPaths","values","map","debug","length","util","pluralize","appPath","rimrafSync","e","warn","message","retrieveHeaders","link","url","method","timeout","headers","getCachedApplicationPath","currentAppProps","cachedAppInfo","refresh","_","isPlainObject","lastModified","currentModified","immutable","currentImmutable","maxAge","currentMaxAge","timestamp","getTime","msLeft","Date","now","path","basename","verifyAppExtension","supportedAppExtensions","toLower","includes","extname","Error","calculateFolderIntegrity","folderPath","glob","cwd","strict","nosort","calculateFileIntegrity","filePath","hash","isAppIntegrityOk","currentPath","expectedIntegrity","exists","stat","isDirectory","folder","file","configureApp","options","isString","onPostProcess","isArray","supportedExtensions","isEmpty","newApp","shouldUnzipApp","packageHash","remoteAppProps","protocol","pathname","parse","isUrl","get","acquire","test","maxAgeMatch","exec","parseInt","cachedPath","integrity","del","fileName","sanitizeName","decodeURIComponent","replacement","ct","some","mimeType","RegExp","escapeRegExp","match","resultingName","substring","resultingExt","first","targetPath","tempDir","prefix","suffix","downloadApp","errorMessage","isPackageAFile","isFile","isFunction","archivePath","tmpRoot","openDir","unzipApp","isAbsolute","resolve","storeAppInCache","appPathToCache","cachedFullPath","set","result","clone","Boolean","href","net","downloadFile","err","zipPath","dstRoot","zip","assertValidZip","timer","timing","Timer","start","useSystemUnzipEnv","env","APPIUM_PREFER_SYSTEM_UNZIP","useSystemUnzip","extractionOpts","fileNamesEncoding","extractAllTo","globPattern","ext","replace","join","sortedBundleItems","sort","a","b","split","sep","errorAndThrow","Math","round","getDuration","asMilliSeconds","matchedBundle","dstPath","mv","mkdirp","isPackageOrBundle","duplicateKeys","input","firstKey","secondKey","item","resultObj","key","value","toPairs","recursivelyCalledValue","parseCapsArray","cap","parsedCaps","JSON","ign","generateDriverLogPrefix","obj","sessionId","instanceName","constructor","name","node","getObjectId"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport path from 'path';\nimport url from 'url';\nimport logger from './logger';\nimport { tempDir, fs, util, zip, net, timing, node } from '@appium/support';\nimport LRU from 'lru-cache';\nimport AsyncLock from 'async-lock';\nimport axios from 'axios';\n\nconst IPA_EXT = '.ipa';\nconst ZIP_EXTS = ['.zip', IPA_EXT];\nconst ZIP_MIME_TYPES = [\n  'application/zip',\n  'application/x-zip-compressed',\n  'multipart/x-zip',\n];\nconst CACHED_APPS_MAX_AGE = 1000 * 60 * 60 * 24; // ms\nconst MAX_CACHED_APPS = 1024;\nconst APPLICATIONS_CACHE = new LRU({\n  max: MAX_CACHED_APPS,\n  ttl: CACHED_APPS_MAX_AGE, // expire after 24 hours\n  updateAgeOnGet: true,\n  dispose: (app, {fullPath}) => {\n    logger.info(`The application '${app}' cached at '${fullPath}' has ` +\n      `expired after ${CACHED_APPS_MAX_AGE}ms`);\n    if (fullPath) {\n      fs.rimraf(fullPath);\n    }\n  },\n  noDisposeOnSet: true,\n});\nconst APPLICATIONS_CACHE_GUARD = new AsyncLock();\nconst SANITIZE_REPLACEMENT = '-';\nconst DEFAULT_BASENAME = 'appium-app';\nconst APP_DOWNLOAD_TIMEOUT_MS = 120 * 1000;\n\nprocess.on('exit', () => {\n  if (APPLICATIONS_CACHE.size === 0) {\n    return;\n  }\n\n  const appPaths = [...APPLICATIONS_CACHE.values()]\n    .map(({fullPath}) => fullPath);\n  logger.debug(`Performing cleanup of ${appPaths.length} cached ` +\n    util.pluralize('application', appPaths.length));\n  for (const appPath of appPaths) {\n    try {\n      // Asynchronous calls are not supported in onExit handler\n      fs.rimrafSync(appPath);\n    } catch (e) {\n      logger.warn(e.message);\n    }\n  }\n});\n\n\nasync function retrieveHeaders (link) {\n  try {\n    return (await axios({\n      url: link,\n      method: 'HEAD',\n      timeout: 5000,\n    })).headers;\n  } catch (e) {\n    logger.info(`Cannot send HEAD request to '${link}'. Original error: ${e.message}`);\n  }\n  return {};\n}\n\nfunction getCachedApplicationPath (link, currentAppProps = {}, cachedAppInfo = {}) {\n  const refresh = () => {\n    logger.debug(`A fresh copy of the application is going to be downloaded from ${link}`);\n    return null;\n  };\n\n  if (!_.isPlainObject(cachedAppInfo) || !_.isPlainObject(currentAppProps)) {\n    // if an invalid arg is passed then assume cache miss\n    return refresh();\n  }\n\n  const {\n    lastModified: currentModified,\n    immutable: currentImmutable,\n    // maxAge is in seconds\n    maxAge: currentMaxAge,\n  } = currentAppProps;\n  const {\n    // Date instance\n    lastModified,\n    // boolean\n    immutable,\n    // Unix time in milliseconds\n    timestamp,\n    fullPath,\n  } = cachedAppInfo;\n  if (lastModified && currentModified) {\n    if (currentModified.getTime() <= lastModified.getTime()) {\n      logger.debug(`The application at ${link} has not been modified since ${lastModified}`);\n      return fullPath;\n    }\n    logger.debug(`The application at ${link} has been modified since ${lastModified}`);\n    return refresh();\n  }\n  if (immutable && currentImmutable) {\n    logger.debug(`The application at ${link} is immutable`);\n    return fullPath;\n  }\n  if (currentMaxAge && timestamp) {\n    const msLeft = timestamp + currentMaxAge * 1000 - Date.now();\n    if (msLeft > 0) {\n      logger.debug(`The cached application '${path.basename(fullPath)}' will expire in ${msLeft / 1000}s`);\n      return fullPath;\n    }\n    logger.debug(`The cached application '${path.basename(fullPath)}' has expired`);\n  }\n  return refresh();\n}\n\nfunction verifyAppExtension (app, supportedAppExtensions) {\n  if (supportedAppExtensions.map(_.toLower).includes(_.toLower(path.extname(app)))) {\n    return app;\n  }\n  throw new Error(`New app path '${app}' did not have ` +\n    `${util.pluralize('extension', supportedAppExtensions.length, false)}: ` +\n    supportedAppExtensions);\n}\n\nasync function calculateFolderIntegrity (folderPath) {\n  return (await fs.glob('**/*', {cwd: folderPath, strict: false, nosort: true})).length;\n}\n\nasync function calculateFileIntegrity (filePath) {\n  return await fs.hash(filePath);\n}\n\nasync function isAppIntegrityOk (currentPath, expectedIntegrity = {}) {\n  if (!await fs.exists(currentPath)) {\n    return false;\n  }\n\n  // Folder integrity check is simple:\n  // Verify the previous amount of files is not greater than the current one.\n  // We don't want to use equality comparison because of an assumption that the OS might\n  // create some unwanted service files/cached inside of that folder or its subfolders.\n  // Ofc, validating the hash sum of each file (or at least of file path) would be much\n  // more precise, but we don't need to be very precise here and also don't want to\n  // overuse RAM and have a performance drop.\n  return (await fs.stat(currentPath)).isDirectory()\n    ? await calculateFolderIntegrity(currentPath) >= expectedIntegrity?.folder\n    : await calculateFileIntegrity(currentPath) === expectedIntegrity?.file;\n}\n\n/**\n * @typedef PostProcessOptions\n * @property {?Object} cachedAppInfo The information about the previously cached app instance (if exists):\n *    - packageHash: SHA1 hash of the package if it is a file and not a folder\n *    - lastModified: Optional Date instance, the value of file's `Last-Modified` header\n *    - immutable: Optional boolean value. Contains true if the file has an `immutable` mark\n *                 in `Cache-control` header\n *    - maxAge: Optional integer representation of `maxAge` parameter in `Cache-control` header\n *    - timestamp: The timestamp this item has been added to the cache (measured in Unix epoch\n *                 milliseconds)\n *    - integrity: An object containing either `file` property with SHA1 hash of the file\n *                 or `folder` property with total amount of cached files and subfolders\n *    - fullPath: the full path to the cached app\n * @property {boolean} isUrl Whether the app has been downloaded from a remote URL\n * @property {?Object} headers Optional headers object. Only present if `isUrl` is true and if the server\n * responds to HEAD requests. All header names are normalized to lowercase.\n * @property {string} appPath A string containing full path to the preprocessed application package (either\n * downloaded or a local one)\n */\n\n/**\n * @typedef PostProcessResult\n * @property {string} appPath The full past to the post-processed application package on the\n * local file system (might be a file or a folder path)\n */\n\n/**\n * @typedef ConfigureAppOptions\n * @property {(obj: PostProcessOptions) => (Promise<PostProcessResult|undefined>|PostProcessResult|undefined)} onPostProcess\n * Optional function, which should be applied\n * to the application after it is downloaded/preprocessed. This function may be async\n * and is expected to accept single object parameter.\n * The function is expected to either return a falsy value, which means the app must not be\n * cached and a fresh copy of it is downloaded each time. If this function returns an object\n * containing `appPath` property then the integrity of it will be verified and stored into\n * the cache.\n * @property {string[]} supportedExtensions List of supported application extensions (\n * including starting dots). This property is mandatory and must not be empty.\n */\n\n/**\n * Prepares an app to be used in an automated test. The app gets cached automatically\n * if it is an archive or if it is downloaded from an URL.\n * If the downloaded app has `.zip` extension, this method will unzip it.\n * The unzip does not work when `onPostProcess` is provided.\n *\n * @param {string} app Either a full path to the app or a remote URL\n * @param {string|string[]|ConfigureAppOptions} options\n * @returns The full path to the resulting application bundle\n */\nasync function configureApp (app, options = {}) {\n  if (!_.isString(app)) {\n    // immediately shortcircuit if not given an app\n    return;\n  }\n\n  let supportedAppExtensions;\n  const {\n    onPostProcess,\n  } = _.isPlainObject(options) ? options : {};\n  if (_.isString(options)) {\n    supportedAppExtensions = [options];\n  } else if (_.isArray(options)) {\n    supportedAppExtensions = options;\n  } else if (_.isPlainObject(options)) {\n    supportedAppExtensions = options.supportedExtensions;\n  }\n  if (_.isEmpty(supportedAppExtensions)) {\n    throw new Error(`One or more supported app extensions must be provided`);\n  }\n\n  let newApp = app;\n  let shouldUnzipApp = false;\n  let packageHash = null;\n  let headers = null;\n  const remoteAppProps = {\n    lastModified: null,\n    immutable: false,\n    maxAge: null,\n  };\n  const {protocol, pathname} = url.parse(newApp);\n  const isUrl = ['http:', 'https:'].includes(protocol);\n\n  const cachedAppInfo = APPLICATIONS_CACHE.get(app);\n\n  return await APPLICATIONS_CACHE_GUARD.acquire(app, async () => {\n    if (isUrl) {\n      // Use the app from remote URL\n      logger.info(`Using downloadable app '${newApp}'`);\n      headers = await retrieveHeaders(newApp);\n      if (!_.isEmpty(headers)) {\n        if (headers['last-modified']) {\n          remoteAppProps.lastModified = new Date(headers['last-modified']);\n        }\n        logger.debug(`Last-Modified: ${headers['last-modified']}`);\n        if (headers['cache-control']) {\n          remoteAppProps.immutable = /\\bimmutable\\b/i.test(headers['cache-control']);\n          const maxAgeMatch = /\\bmax-age=(\\d+)\\b/i.exec(headers['cache-control']);\n          if (maxAgeMatch) {\n            remoteAppProps.maxAge = parseInt(maxAgeMatch[1], 10);\n          }\n        }\n        logger.debug(`Cache-Control: ${headers['cache-control']}`);\n      }\n      const cachedPath = getCachedApplicationPath(app, remoteAppProps, cachedAppInfo);\n      if (cachedPath) {\n        if (await isAppIntegrityOk(cachedPath, cachedAppInfo?.integrity)) {\n          logger.info(`Reusing previously downloaded application at '${cachedPath}'`);\n          return verifyAppExtension(cachedPath, supportedAppExtensions);\n        }\n        logger.info(`The application at '${cachedPath}' does not exist anymore ` +\n          `or its integrity has been damaged. Deleting it from the internal cache`);\n        APPLICATIONS_CACHE.del(app);\n      }\n\n      let fileName = null;\n      const basename = fs.sanitizeName(path.basename(decodeURIComponent(pathname)), {\n        replacement: SANITIZE_REPLACEMENT\n      });\n      const extname = path.extname(basename);\n      // to determine if we need to unzip the app, we have a number of places\n      // to look: content type, content disposition, or the file extension\n      if (ZIP_EXTS.includes(extname)) {\n        fileName = basename;\n        shouldUnzipApp = true;\n      }\n      if (headers['content-type']) {\n        const ct = headers['content-type'];\n        logger.debug(`Content-Type: ${ct}`);\n        // the filetype may not be obvious for certain urls, so check the mime type too\n        if (ZIP_MIME_TYPES.some((mimeType) => new RegExp(`\\\\b${_.escapeRegExp(mimeType)}\\\\b`).test(ct))) {\n          if (!fileName) {\n            fileName = `${DEFAULT_BASENAME}.zip`;\n          }\n          shouldUnzipApp = true;\n        }\n      }\n      if (headers['content-disposition'] && /^attachment/i.test(headers['content-disposition'])) {\n        logger.debug(`Content-Disposition: ${headers['content-disposition']}`);\n        const match = /filename=\"([^\"]+)/i.exec(headers['content-disposition']);\n        if (match) {\n          fileName = fs.sanitizeName(match[1], {\n            replacement: SANITIZE_REPLACEMENT\n          });\n          shouldUnzipApp = shouldUnzipApp || ZIP_EXTS.includes(path.extname(fileName));\n        }\n      }\n      if (!fileName) {\n        // assign the default file name and the extension if none has been detected\n        const resultingName = basename\n          ? basename.substring(0, basename.length - extname.length)\n          : DEFAULT_BASENAME;\n        let resultingExt = extname;\n        if (!supportedAppExtensions.includes(resultingExt)) {\n          logger.info(`The current file extension '${resultingExt}' is not supported. ` +\n            `Defaulting to '${_.first(supportedAppExtensions)}'`);\n          resultingExt = _.first(supportedAppExtensions);\n        }\n        fileName = `${resultingName}${resultingExt}`;\n      }\n      const targetPath = await tempDir.path({\n        prefix: fileName,\n        suffix: '',\n      });\n      newApp = await downloadApp(newApp, targetPath);\n    } else if (await fs.exists(newApp)) {\n      // Use the local app\n      logger.info(`Using local app '${newApp}'`);\n      shouldUnzipApp = ZIP_EXTS.includes(path.extname(newApp));\n    } else {\n      let errorMessage = `The application at '${newApp}' does not exist or is not accessible`;\n      // protocol value for 'C:\\\\temp' is 'c:', so we check the length as well\n      if (_.isString(protocol) && protocol.length > 2) {\n        errorMessage = `The protocol '${protocol}' used in '${newApp}' is not supported. ` +\n          `Only http: and https: protocols are supported`;\n      }\n      throw new Error(errorMessage);\n    }\n\n    const isPackageAFile = (await fs.stat(newApp)).isFile();\n    if (isPackageAFile) {\n      packageHash = await calculateFileIntegrity(newApp);\n    }\n\n    if (isPackageAFile && shouldUnzipApp && !_.isFunction(onPostProcess)) {\n      const archivePath = newApp;\n      if (packageHash === cachedAppInfo?.packageHash) {\n        const {fullPath} = cachedAppInfo;\n        if (await isAppIntegrityOk(fullPath, cachedAppInfo?.integrity)) {\n          if (archivePath !== app) {\n            await fs.rimraf(archivePath);\n          }\n          logger.info(`Will reuse previously cached application at '${fullPath}'`);\n          return verifyAppExtension(fullPath, supportedAppExtensions);\n        }\n        logger.info(`The application at '${fullPath}' does not exist anymore ` +\n          `or its integrity has been damaged. Deleting it from the cache`);\n        APPLICATIONS_CACHE.del(app);\n      }\n      const tmpRoot = await tempDir.openDir();\n      try {\n        newApp = await unzipApp(archivePath, tmpRoot, supportedAppExtensions);\n      } finally {\n        if (newApp !== archivePath && archivePath !== app) {\n          await fs.rimraf(archivePath);\n        }\n      }\n      logger.info(`Unzipped local app to '${newApp}'`);\n    } else if (!path.isAbsolute(newApp)) {\n      newApp = path.resolve(process.cwd(), newApp);\n      logger.warn(`The current application path '${app}' is not absolute ` +\n        `and has been rewritten to '${newApp}'. Consider using absolute paths rather than relative`);\n      app = newApp;\n    }\n\n    const storeAppInCache = async (appPathToCache) => {\n      const cachedFullPath = cachedAppInfo?.fullPath;\n      if (cachedFullPath && cachedFullPath !== appPathToCache) {\n        await fs.rimraf(cachedFullPath);\n      }\n      const integrity = {};\n      if ((await fs.stat(appPathToCache)).isDirectory()) {\n        integrity.folder = await calculateFolderIntegrity(appPathToCache);\n      } else {\n        integrity.file = await calculateFileIntegrity(appPathToCache);\n      }\n      APPLICATIONS_CACHE.set(app, {\n        ...remoteAppProps,\n        timestamp: Date.now(),\n        packageHash,\n        integrity,\n        fullPath: appPathToCache,\n      });\n      return appPathToCache;\n    };\n\n    if (_.isFunction(onPostProcess)) {\n      const result = await onPostProcess({\n        cachedAppInfo: _.clone(cachedAppInfo),\n        isUrl,\n        headers: _.clone(headers),\n        appPath: newApp,\n      });\n      return (!result?.appPath || app === result?.appPath || !await fs.exists(result?.appPath))\n        ? newApp\n        : await storeAppInCache(result.appPath);\n    }\n\n    verifyAppExtension(newApp, supportedAppExtensions);\n    return (app !== newApp && (packageHash || _.values(remoteAppProps).some(Boolean)))\n      ? await storeAppInCache(newApp)\n      : newApp;\n  });\n}\n\nasync function downloadApp (app, targetPath) {\n  const {href} = url.parse(app);\n  try {\n    await net.downloadFile(href, targetPath, {\n      timeout: APP_DOWNLOAD_TIMEOUT_MS,\n    });\n  } catch (err) {\n    throw new Error(`Unable to download the app: ${err.message}`);\n  }\n  return targetPath;\n}\n\n/**\n * Extracts the bundle from an archive into the given folder\n *\n * @param {string} zipPath Full path to the archive containing the bundle\n * @param {string} dstRoot Full path to the folder where the extracted bundle\n * should be placed\n * @param {Array<string>|string} supportedAppExtensions The list of extensions\n * the target application bundle supports, for example ['.apk', '.apks'] for\n * Android packages\n * @returns {string} Full path to the bundle in the destination folder\n * @throws {Error} If the given archive is invalid or no application bundles\n * have been found inside\n */\nasync function unzipApp (zipPath, dstRoot, supportedAppExtensions) {\n  await zip.assertValidZip(zipPath);\n\n  if (!_.isArray(supportedAppExtensions)) {\n    supportedAppExtensions = [supportedAppExtensions];\n  }\n\n  const tmpRoot = await tempDir.openDir();\n  try {\n    logger.debug(`Unzipping '${zipPath}'`);\n    const timer = new timing.Timer().start();\n    const useSystemUnzipEnv = process.env.APPIUM_PREFER_SYSTEM_UNZIP;\n    const useSystemUnzip = _.isEmpty(useSystemUnzipEnv)\n      || !['0', 'false'].includes(_.toLower(useSystemUnzipEnv));\n    /**\n     * Attempt to use use the system `unzip` (e.g., `/usr/bin/unzip`) due\n     * to the significant performance improvement it provides over the native\n     * JS \"unzip\" implementation.\n     * @type {import('@appium/support/lib/zip').ExtractAllOptions}\n     */\n    const extractionOpts = {useSystemUnzip};\n    // https://github.com/appium/appium/issues/14100\n    if (path.extname(zipPath) === IPA_EXT) {\n      logger.debug(`Enforcing UTF-8 encoding on the extracted file names for '${path.basename(zipPath)}'`);\n      extractionOpts.fileNamesEncoding = 'utf8';\n    }\n    await zip.extractAllTo(zipPath, tmpRoot, extractionOpts);\n    const globPattern = `**/*.+(${supportedAppExtensions.map((ext) => ext.replace(/^\\./, '')).join('|')})`;\n    const sortedBundleItems = (await fs.glob(globPattern, {\n      cwd: tmpRoot,\n      strict: false,\n    // Get the top level match\n    })).sort((a, b) => a.split(path.sep).length - b.split(path.sep).length);\n    if (_.isEmpty(sortedBundleItems)) {\n      logger.errorAndThrow(`App unzipped OK, but we could not find any '${supportedAppExtensions}' ` +\n        util.pluralize('bundle', supportedAppExtensions.length, false) +\n        ` in it. Make sure your archive contains at least one package having ` +\n        `'${supportedAppExtensions}' ${util.pluralize('extension', supportedAppExtensions.length, false)}`);\n    }\n    logger.debug(`Extracted ${util.pluralize('bundle item', sortedBundleItems.length, true)} ` +\n      `from '${zipPath}' in ${Math.round(timer.getDuration().asMilliSeconds)}ms: ${sortedBundleItems}`);\n    const matchedBundle = _.first(sortedBundleItems);\n    logger.info(`Assuming '${matchedBundle}' is the correct bundle`);\n    const dstPath = path.resolve(dstRoot, path.basename(matchedBundle));\n    await fs.mv(path.resolve(tmpRoot, matchedBundle), dstPath, {mkdirp: true});\n    return dstPath;\n  } finally {\n    await fs.rimraf(tmpRoot);\n  }\n}\n\nfunction isPackageOrBundle (app) {\n  return (/^([a-zA-Z0-9\\-_]+\\.[a-zA-Z0-9\\-_]+)+$/).test(app);\n}\n\n/**\n * Finds all instances 'firstKey' and create a duplicate with the key 'secondKey',\n * Do the same thing in reverse. If we find 'secondKey', create a duplicate with the key 'firstKey'.\n *\n * This will cause keys to be overwritten if the object contains 'firstKey' and 'secondKey'.\n\n * @param {*} input Any type of input\n * @param {String} firstKey The first key to duplicate\n * @param {String} secondKey The second key to duplicate\n */\nfunction duplicateKeys (input, firstKey, secondKey) {\n  // If array provided, recursively call on all elements\n  if (_.isArray(input)) {\n    return input.map((item) => duplicateKeys(item, firstKey, secondKey));\n  }\n\n  // If object, create duplicates for keys and then recursively call on values\n  if (_.isPlainObject(input)) {\n    const resultObj = {};\n    for (let [key, value] of _.toPairs(input)) {\n      const recursivelyCalledValue = duplicateKeys(value, firstKey, secondKey);\n      if (key === firstKey) {\n        resultObj[secondKey] = recursivelyCalledValue;\n      } else if (key === secondKey) {\n        resultObj[firstKey] = recursivelyCalledValue;\n      }\n      resultObj[key] = recursivelyCalledValue;\n    }\n    return resultObj;\n  }\n\n  // Base case. Return primitives without doing anything.\n  return input;\n}\n\n/**\n * Takes a desired capability and tries to JSON.parse it as an array,\n * and either returns the parsed array or a singleton array.\n *\n * @param {string|Array<String>} cap A desired capability\n */\nfunction parseCapsArray (cap) {\n  if (_.isArray(cap)) {\n    return cap;\n  }\n\n  let parsedCaps;\n  try {\n    parsedCaps = JSON.parse(cap);\n    if (_.isArray(parsedCaps)) {\n      return parsedCaps;\n    }\n  } catch (ign) {\n    logger.warn(`Failed to parse capability as JSON array`);\n  }\n  if (_.isString(cap)) {\n    return [cap];\n  }\n  throw new Error(`must provide a string or JSON Array; received ${cap}`);\n}\n\n/**\n * Generate a string that uniquely describes driver instance\n *\n * @param {import('@appium/types').Core} obj driver instance\n * @param {string?} sessionId session identifier (if exists)\n * @returns {string}\n */\nfunction generateDriverLogPrefix (obj, sessionId = null) {\n  const instanceName = `${obj.constructor.name}@${node.getObjectId(obj).substring(0, 4)}`;\n  return sessionId ? `${instanceName} (${sessionId.substring(0, 8)})` : instanceName;\n}\n\n/** @type {import('@appium/types').DriverHelpers} */\nexport default {\n  configureApp, isPackageOrBundle, duplicateKeys, parseCapsArray, generateDriverLogPrefix\n};\nexport {\n  configureApp, isPackageOrBundle, duplicateKeys, parseCapsArray, generateDriverLogPrefix\n};\n"]}
548
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/basedriver/helpers.js"],"names":["IPA_EXT","ZIP_EXTS","ZIP_MIME_TYPES","CACHED_APPS_MAX_AGE","MAX_CACHED_APPS","APPLICATIONS_CACHE","LRU","max","ttl","updateAgeOnGet","dispose","app","fullPath","logger","info","fs","rimraf","noDisposeOnSet","APPLICATIONS_CACHE_GUARD","AsyncLock","SANITIZE_REPLACEMENT","DEFAULT_BASENAME","APP_DOWNLOAD_TIMEOUT_MS","process","on","size","appPaths","values","map","debug","length","util","pluralize","appPath","rimrafSync","e","warn","message","retrieveHeaders","link","url","method","timeout","headers","getCachedApplicationPath","currentAppProps","cachedAppInfo","refresh","_","isPlainObject","lastModified","currentModified","immutable","currentImmutable","maxAge","currentMaxAge","timestamp","getTime","msLeft","Date","now","path","basename","verifyAppExtension","supportedAppExtensions","toLower","includes","extname","Error","calculateFolderIntegrity","folderPath","glob","cwd","strict","nosort","calculateFileIntegrity","filePath","hash","isAppIntegrityOk","currentPath","expectedIntegrity","exists","stat","isDirectory","folder","file","configureApp","options","isString","onPostProcess","isArray","supportedExtensions","isEmpty","newApp","shouldUnzipApp","packageHash","remoteAppProps","protocol","pathname","parse","isUrl","get","acquire","test","maxAgeMatch","exec","parseInt","cachedPath","integrity","delete","fileName","sanitizeName","decodeURIComponent","replacement","ct","some","mimeType","RegExp","escapeRegExp","match","resultingName","substring","resultingExt","first","targetPath","tempDir","prefix","suffix","downloadApp","errorMessage","isPackageAFile","isFile","isFunction","archivePath","tmpRoot","openDir","unzipApp","isAbsolute","resolve","storeAppInCache","appPathToCache","cachedFullPath","set","result","clone","Boolean","href","net","downloadFile","err","zipPath","dstRoot","zip","assertValidZip","timer","timing","Timer","start","useSystemUnzipEnv","env","APPIUM_PREFER_SYSTEM_UNZIP","useSystemUnzip","extractionOpts","fileNamesEncoding","extractAllTo","globPattern","ext","replace","join","sortedBundleItems","sort","a","b","split","sep","errorAndThrow","Math","round","getDuration","asMilliSeconds","matchedBundle","dstPath","mv","mkdirp","isPackageOrBundle","duplicateKeys","input","firstKey","secondKey","item","resultObj","key","value","toPairs","recursivelyCalledValue","parseCapsArray","cap","parsedCaps","JSON","ign","generateDriverLogPrefix","obj","sessionId","instanceName","constructor","name","node","getObjectId"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport path from 'path';\nimport url from 'url';\nimport logger from './logger';\nimport { tempDir, fs, util, zip, net, timing, node } from '@appium/support';\nimport LRU from 'lru-cache';\nimport AsyncLock from 'async-lock';\nimport axios from 'axios';\n\nconst IPA_EXT = '.ipa';\nconst ZIP_EXTS = ['.zip', IPA_EXT];\nconst ZIP_MIME_TYPES = [\n  'application/zip',\n  'application/x-zip-compressed',\n  'multipart/x-zip',\n];\nconst CACHED_APPS_MAX_AGE = 1000 * 60 * 60 * 24; // ms\nconst MAX_CACHED_APPS = 1024;\nconst APPLICATIONS_CACHE = new LRU({\n  max: MAX_CACHED_APPS,\n  ttl: CACHED_APPS_MAX_AGE, // expire after 24 hours\n  updateAgeOnGet: true,\n  dispose: (app, {fullPath}) => {\n    logger.info(`The application '${app}' cached at '${fullPath}' has ` +\n      `expired after ${CACHED_APPS_MAX_AGE}ms`);\n    if (fullPath) {\n      fs.rimraf(fullPath);\n    }\n  },\n  noDisposeOnSet: true,\n});\nconst APPLICATIONS_CACHE_GUARD = new AsyncLock();\nconst SANITIZE_REPLACEMENT = '-';\nconst DEFAULT_BASENAME = 'appium-app';\nconst APP_DOWNLOAD_TIMEOUT_MS = 120 * 1000;\n\nprocess.on('exit', () => {\n  if (APPLICATIONS_CACHE.size === 0) {\n    return;\n  }\n\n  const appPaths = [...APPLICATIONS_CACHE.values()]\n    .map(({fullPath}) => fullPath);\n  logger.debug(`Performing cleanup of ${appPaths.length} cached ` +\n    util.pluralize('application', appPaths.length));\n  for (const appPath of appPaths) {\n    try {\n      // Asynchronous calls are not supported in onExit handler\n      fs.rimrafSync(appPath);\n    } catch (e) {\n      logger.warn(e.message);\n    }\n  }\n});\n\n\nasync function retrieveHeaders (link) {\n  try {\n    return (await axios({\n      url: link,\n      method: 'HEAD',\n      timeout: 5000,\n    })).headers;\n  } catch (e) {\n    logger.info(`Cannot send HEAD request to '${link}'. Original error: ${e.message}`);\n  }\n  return {};\n}\n\nfunction getCachedApplicationPath (link, currentAppProps = {}, cachedAppInfo = {}) {\n  const refresh = () => {\n    logger.debug(`A fresh copy of the application is going to be downloaded from ${link}`);\n    return null;\n  };\n\n  if (!_.isPlainObject(cachedAppInfo) || !_.isPlainObject(currentAppProps)) {\n    // if an invalid arg is passed then assume cache miss\n    return refresh();\n  }\n\n  const {\n    lastModified: currentModified,\n    immutable: currentImmutable,\n    // maxAge is in seconds\n    maxAge: currentMaxAge,\n  } = currentAppProps;\n  const {\n    // Date instance\n    lastModified,\n    // boolean\n    immutable,\n    // Unix time in milliseconds\n    timestamp,\n    fullPath,\n  } = cachedAppInfo;\n  if (lastModified && currentModified) {\n    if (currentModified.getTime() <= lastModified.getTime()) {\n      logger.debug(`The application at ${link} has not been modified since ${lastModified}`);\n      return fullPath;\n    }\n    logger.debug(`The application at ${link} has been modified since ${lastModified}`);\n    return refresh();\n  }\n  if (immutable && currentImmutable) {\n    logger.debug(`The application at ${link} is immutable`);\n    return fullPath;\n  }\n  if (currentMaxAge && timestamp) {\n    const msLeft = timestamp + currentMaxAge * 1000 - Date.now();\n    if (msLeft > 0) {\n      logger.debug(`The cached application '${path.basename(fullPath)}' will expire in ${msLeft / 1000}s`);\n      return fullPath;\n    }\n    logger.debug(`The cached application '${path.basename(fullPath)}' has expired`);\n  }\n  return refresh();\n}\n\nfunction verifyAppExtension (app, supportedAppExtensions) {\n  if (supportedAppExtensions.map(_.toLower).includes(_.toLower(path.extname(app)))) {\n    return app;\n  }\n  throw new Error(`New app path '${app}' did not have ` +\n    `${util.pluralize('extension', supportedAppExtensions.length, false)}: ` +\n    supportedAppExtensions);\n}\n\nasync function calculateFolderIntegrity (folderPath) {\n  return (await fs.glob('**/*', {cwd: folderPath, strict: false, nosort: true})).length;\n}\n\nasync function calculateFileIntegrity (filePath) {\n  return await fs.hash(filePath);\n}\n\nasync function isAppIntegrityOk (currentPath, expectedIntegrity = {}) {\n  if (!await fs.exists(currentPath)) {\n    return false;\n  }\n\n  // Folder integrity check is simple:\n  // Verify the previous amount of files is not greater than the current one.\n  // We don't want to use equality comparison because of an assumption that the OS might\n  // create some unwanted service files/cached inside of that folder or its subfolders.\n  // Ofc, validating the hash sum of each file (or at least of file path) would be much\n  // more precise, but we don't need to be very precise here and also don't want to\n  // overuse RAM and have a performance drop.\n  return (await fs.stat(currentPath)).isDirectory()\n    ? await calculateFolderIntegrity(currentPath) >= expectedIntegrity?.folder\n    : await calculateFileIntegrity(currentPath) === expectedIntegrity?.file;\n}\n\n/**\n * @typedef PostProcessOptions\n * @property {?Object} cachedAppInfo The information about the previously cached app instance (if exists):\n *    - packageHash: SHA1 hash of the package if it is a file and not a folder\n *    - lastModified: Optional Date instance, the value of file's `Last-Modified` header\n *    - immutable: Optional boolean value. Contains true if the file has an `immutable` mark\n *                 in `Cache-control` header\n *    - maxAge: Optional integer representation of `maxAge` parameter in `Cache-control` header\n *    - timestamp: The timestamp this item has been added to the cache (measured in Unix epoch\n *                 milliseconds)\n *    - integrity: An object containing either `file` property with SHA1 hash of the file\n *                 or `folder` property with total amount of cached files and subfolders\n *    - fullPath: the full path to the cached app\n * @property {boolean} isUrl Whether the app has been downloaded from a remote URL\n * @property {?Object} headers Optional headers object. Only present if `isUrl` is true and if the server\n * responds to HEAD requests. All header names are normalized to lowercase.\n * @property {string} appPath A string containing full path to the preprocessed application package (either\n * downloaded or a local one)\n */\n\n/**\n * @typedef PostProcessResult\n * @property {string} appPath The full past to the post-processed application package on the\n * local file system (might be a file or a folder path)\n */\n\n/**\n * @typedef ConfigureAppOptions\n * @property {(obj: PostProcessOptions) => (Promise<PostProcessResult|undefined>|PostProcessResult|undefined)} onPostProcess\n * Optional function, which should be applied\n * to the application after it is downloaded/preprocessed. This function may be async\n * and is expected to accept single object parameter.\n * The function is expected to either return a falsy value, which means the app must not be\n * cached and a fresh copy of it is downloaded each time. If this function returns an object\n * containing `appPath` property then the integrity of it will be verified and stored into\n * the cache.\n * @property {string[]} supportedExtensions List of supported application extensions (\n * including starting dots). This property is mandatory and must not be empty.\n */\n\n/**\n * Prepares an app to be used in an automated test. The app gets cached automatically\n * if it is an archive or if it is downloaded from an URL.\n * If the downloaded app has `.zip` extension, this method will unzip it.\n * The unzip does not work when `onPostProcess` is provided.\n *\n * @param {string} app Either a full path to the app or a remote URL\n * @param {string|string[]|ConfigureAppOptions} options\n * @returns The full path to the resulting application bundle\n */\nasync function configureApp (app, options = {}) {\n  if (!_.isString(app)) {\n    // immediately shortcircuit if not given an app\n    return;\n  }\n\n  let supportedAppExtensions;\n  const {\n    onPostProcess,\n  } = _.isPlainObject(options) ? options : {};\n  if (_.isString(options)) {\n    supportedAppExtensions = [options];\n  } else if (_.isArray(options)) {\n    supportedAppExtensions = options;\n  } else if (_.isPlainObject(options)) {\n    supportedAppExtensions = options.supportedExtensions;\n  }\n  if (_.isEmpty(supportedAppExtensions)) {\n    throw new Error(`One or more supported app extensions must be provided`);\n  }\n\n  let newApp = app;\n  let shouldUnzipApp = false;\n  let packageHash = null;\n  let headers = null;\n  const remoteAppProps = {\n    lastModified: null,\n    immutable: false,\n    maxAge: null,\n  };\n  const {protocol, pathname} = url.parse(newApp);\n  const isUrl = ['http:', 'https:'].includes(protocol);\n\n  const cachedAppInfo = APPLICATIONS_CACHE.get(app);\n\n  return await APPLICATIONS_CACHE_GUARD.acquire(app, async () => {\n    if (isUrl) {\n      // Use the app from remote URL\n      logger.info(`Using downloadable app '${newApp}'`);\n      headers = await retrieveHeaders(newApp);\n      if (!_.isEmpty(headers)) {\n        if (headers['last-modified']) {\n          remoteAppProps.lastModified = new Date(headers['last-modified']);\n        }\n        logger.debug(`Last-Modified: ${headers['last-modified']}`);\n        if (headers['cache-control']) {\n          remoteAppProps.immutable = /\\bimmutable\\b/i.test(headers['cache-control']);\n          const maxAgeMatch = /\\bmax-age=(\\d+)\\b/i.exec(headers['cache-control']);\n          if (maxAgeMatch) {\n            remoteAppProps.maxAge = parseInt(maxAgeMatch[1], 10);\n          }\n        }\n        logger.debug(`Cache-Control: ${headers['cache-control']}`);\n      }\n      const cachedPath = getCachedApplicationPath(app, remoteAppProps, cachedAppInfo);\n      if (cachedPath) {\n        if (await isAppIntegrityOk(cachedPath, cachedAppInfo?.integrity)) {\n          logger.info(`Reusing previously downloaded application at '${cachedPath}'`);\n          return verifyAppExtension(cachedPath, supportedAppExtensions);\n        }\n        logger.info(`The application at '${cachedPath}' does not exist anymore ` +\n          `or its integrity has been damaged. Deleting it from the internal cache`);\n        APPLICATIONS_CACHE.delete(app);\n      }\n\n      let fileName = null;\n      const basename = fs.sanitizeName(path.basename(decodeURIComponent(pathname)), {\n        replacement: SANITIZE_REPLACEMENT\n      });\n      const extname = path.extname(basename);\n      // to determine if we need to unzip the app, we have a number of places\n      // to look: content type, content disposition, or the file extension\n      if (ZIP_EXTS.includes(extname)) {\n        fileName = basename;\n        shouldUnzipApp = true;\n      }\n      if (headers['content-type']) {\n        const ct = headers['content-type'];\n        logger.debug(`Content-Type: ${ct}`);\n        // the filetype may not be obvious for certain urls, so check the mime type too\n        if (ZIP_MIME_TYPES.some((mimeType) => new RegExp(`\\\\b${_.escapeRegExp(mimeType)}\\\\b`).test(ct))) {\n          if (!fileName) {\n            fileName = `${DEFAULT_BASENAME}.zip`;\n          }\n          shouldUnzipApp = true;\n        }\n      }\n      if (headers['content-disposition'] && /^attachment/i.test(headers['content-disposition'])) {\n        logger.debug(`Content-Disposition: ${headers['content-disposition']}`);\n        const match = /filename=\"([^\"]+)/i.exec(headers['content-disposition']);\n        if (match) {\n          fileName = fs.sanitizeName(match[1], {\n            replacement: SANITIZE_REPLACEMENT\n          });\n          shouldUnzipApp = shouldUnzipApp || ZIP_EXTS.includes(path.extname(fileName));\n        }\n      }\n      if (!fileName) {\n        // assign the default file name and the extension if none has been detected\n        const resultingName = basename\n          ? basename.substring(0, basename.length - extname.length)\n          : DEFAULT_BASENAME;\n        let resultingExt = extname;\n        if (!supportedAppExtensions.includes(resultingExt)) {\n          logger.info(`The current file extension '${resultingExt}' is not supported. ` +\n            `Defaulting to '${_.first(supportedAppExtensions)}'`);\n          resultingExt = _.first(supportedAppExtensions);\n        }\n        fileName = `${resultingName}${resultingExt}`;\n      }\n      const targetPath = await tempDir.path({\n        prefix: fileName,\n        suffix: '',\n      });\n      newApp = await downloadApp(newApp, targetPath);\n    } else if (await fs.exists(newApp)) {\n      // Use the local app\n      logger.info(`Using local app '${newApp}'`);\n      shouldUnzipApp = ZIP_EXTS.includes(path.extname(newApp));\n    } else {\n      let errorMessage = `The application at '${newApp}' does not exist or is not accessible`;\n      // protocol value for 'C:\\\\temp' is 'c:', so we check the length as well\n      if (_.isString(protocol) && protocol.length > 2) {\n        errorMessage = `The protocol '${protocol}' used in '${newApp}' is not supported. ` +\n          `Only http: and https: protocols are supported`;\n      }\n      throw new Error(errorMessage);\n    }\n\n    const isPackageAFile = (await fs.stat(newApp)).isFile();\n    if (isPackageAFile) {\n      packageHash = await calculateFileIntegrity(newApp);\n    }\n\n    if (isPackageAFile && shouldUnzipApp && !_.isFunction(onPostProcess)) {\n      const archivePath = newApp;\n      if (packageHash === cachedAppInfo?.packageHash) {\n        const {fullPath} = cachedAppInfo;\n        if (await isAppIntegrityOk(fullPath, cachedAppInfo?.integrity)) {\n          if (archivePath !== app) {\n            await fs.rimraf(archivePath);\n          }\n          logger.info(`Will reuse previously cached application at '${fullPath}'`);\n          return verifyAppExtension(fullPath, supportedAppExtensions);\n        }\n        logger.info(`The application at '${fullPath}' does not exist anymore ` +\n          `or its integrity has been damaged. Deleting it from the cache`);\n        APPLICATIONS_CACHE.delete(app);\n      }\n      const tmpRoot = await tempDir.openDir();\n      try {\n        newApp = await unzipApp(archivePath, tmpRoot, supportedAppExtensions);\n      } finally {\n        if (newApp !== archivePath && archivePath !== app) {\n          await fs.rimraf(archivePath);\n        }\n      }\n      logger.info(`Unzipped local app to '${newApp}'`);\n    } else if (!path.isAbsolute(newApp)) {\n      newApp = path.resolve(process.cwd(), newApp);\n      logger.warn(`The current application path '${app}' is not absolute ` +\n        `and has been rewritten to '${newApp}'. Consider using absolute paths rather than relative`);\n      app = newApp;\n    }\n\n    const storeAppInCache = async (appPathToCache) => {\n      const cachedFullPath = cachedAppInfo?.fullPath;\n      if (cachedFullPath && cachedFullPath !== appPathToCache) {\n        await fs.rimraf(cachedFullPath);\n      }\n      const integrity = {};\n      if ((await fs.stat(appPathToCache)).isDirectory()) {\n        integrity.folder = await calculateFolderIntegrity(appPathToCache);\n      } else {\n        integrity.file = await calculateFileIntegrity(appPathToCache);\n      }\n      APPLICATIONS_CACHE.set(app, {\n        ...remoteAppProps,\n        timestamp: Date.now(),\n        packageHash,\n        integrity,\n        fullPath: appPathToCache,\n      });\n      return appPathToCache;\n    };\n\n    if (_.isFunction(onPostProcess)) {\n      const result = await onPostProcess({\n        cachedAppInfo: _.clone(cachedAppInfo),\n        isUrl,\n        headers: _.clone(headers),\n        appPath: newApp,\n      });\n      return (!result?.appPath || app === result?.appPath || !await fs.exists(result?.appPath))\n        ? newApp\n        : await storeAppInCache(result.appPath);\n    }\n\n    verifyAppExtension(newApp, supportedAppExtensions);\n    return (app !== newApp && (packageHash || _.values(remoteAppProps).some(Boolean)))\n      ? await storeAppInCache(newApp)\n      : newApp;\n  });\n}\n\nasync function downloadApp (app, targetPath) {\n  const {href} = url.parse(app);\n  try {\n    await net.downloadFile(href, targetPath, {\n      timeout: APP_DOWNLOAD_TIMEOUT_MS,\n    });\n  } catch (err) {\n    throw new Error(`Unable to download the app: ${err.message}`);\n  }\n  return targetPath;\n}\n\n/**\n * Extracts the bundle from an archive into the given folder\n *\n * @param {string} zipPath Full path to the archive containing the bundle\n * @param {string} dstRoot Full path to the folder where the extracted bundle\n * should be placed\n * @param {Array<string>|string} supportedAppExtensions The list of extensions\n * the target application bundle supports, for example ['.apk', '.apks'] for\n * Android packages\n * @returns {string} Full path to the bundle in the destination folder\n * @throws {Error} If the given archive is invalid or no application bundles\n * have been found inside\n */\nasync function unzipApp (zipPath, dstRoot, supportedAppExtensions) {\n  await zip.assertValidZip(zipPath);\n\n  if (!_.isArray(supportedAppExtensions)) {\n    supportedAppExtensions = [supportedAppExtensions];\n  }\n\n  const tmpRoot = await tempDir.openDir();\n  try {\n    logger.debug(`Unzipping '${zipPath}'`);\n    const timer = new timing.Timer().start();\n    const useSystemUnzipEnv = process.env.APPIUM_PREFER_SYSTEM_UNZIP;\n    const useSystemUnzip = _.isEmpty(useSystemUnzipEnv)\n      || !['0', 'false'].includes(_.toLower(useSystemUnzipEnv));\n    /**\n     * Attempt to use use the system `unzip` (e.g., `/usr/bin/unzip`) due\n     * to the significant performance improvement it provides over the native\n     * JS \"unzip\" implementation.\n     * @type {import('@appium/support/lib/zip').ExtractAllOptions}\n     */\n    const extractionOpts = {useSystemUnzip};\n    // https://github.com/appium/appium/issues/14100\n    if (path.extname(zipPath) === IPA_EXT) {\n      logger.debug(`Enforcing UTF-8 encoding on the extracted file names for '${path.basename(zipPath)}'`);\n      extractionOpts.fileNamesEncoding = 'utf8';\n    }\n    await zip.extractAllTo(zipPath, tmpRoot, extractionOpts);\n    const globPattern = `**/*.+(${supportedAppExtensions.map((ext) => ext.replace(/^\\./, '')).join('|')})`;\n    const sortedBundleItems = (await fs.glob(globPattern, {\n      cwd: tmpRoot,\n      strict: false,\n    // Get the top level match\n    })).sort((a, b) => a.split(path.sep).length - b.split(path.sep).length);\n    if (_.isEmpty(sortedBundleItems)) {\n      logger.errorAndThrow(`App unzipped OK, but we could not find any '${supportedAppExtensions}' ` +\n        util.pluralize('bundle', supportedAppExtensions.length, false) +\n        ` in it. Make sure your archive contains at least one package having ` +\n        `'${supportedAppExtensions}' ${util.pluralize('extension', supportedAppExtensions.length, false)}`);\n    }\n    logger.debug(`Extracted ${util.pluralize('bundle item', sortedBundleItems.length, true)} ` +\n      `from '${zipPath}' in ${Math.round(timer.getDuration().asMilliSeconds)}ms: ${sortedBundleItems}`);\n    const matchedBundle = _.first(sortedBundleItems);\n    logger.info(`Assuming '${matchedBundle}' is the correct bundle`);\n    const dstPath = path.resolve(dstRoot, path.basename(matchedBundle));\n    await fs.mv(path.resolve(tmpRoot, matchedBundle), dstPath, {mkdirp: true});\n    return dstPath;\n  } finally {\n    await fs.rimraf(tmpRoot);\n  }\n}\n\nfunction isPackageOrBundle (app) {\n  return (/^([a-zA-Z0-9\\-_]+\\.[a-zA-Z0-9\\-_]+)+$/).test(app);\n}\n\n/**\n * Finds all instances 'firstKey' and create a duplicate with the key 'secondKey',\n * Do the same thing in reverse. If we find 'secondKey', create a duplicate with the key 'firstKey'.\n *\n * This will cause keys to be overwritten if the object contains 'firstKey' and 'secondKey'.\n\n * @param {*} input Any type of input\n * @param {String} firstKey The first key to duplicate\n * @param {String} secondKey The second key to duplicate\n */\nfunction duplicateKeys (input, firstKey, secondKey) {\n  // If array provided, recursively call on all elements\n  if (_.isArray(input)) {\n    return input.map((item) => duplicateKeys(item, firstKey, secondKey));\n  }\n\n  // If object, create duplicates for keys and then recursively call on values\n  if (_.isPlainObject(input)) {\n    const resultObj = {};\n    for (let [key, value] of _.toPairs(input)) {\n      const recursivelyCalledValue = duplicateKeys(value, firstKey, secondKey);\n      if (key === firstKey) {\n        resultObj[secondKey] = recursivelyCalledValue;\n      } else if (key === secondKey) {\n        resultObj[firstKey] = recursivelyCalledValue;\n      }\n      resultObj[key] = recursivelyCalledValue;\n    }\n    return resultObj;\n  }\n\n  // Base case. Return primitives without doing anything.\n  return input;\n}\n\n/**\n * Takes a desired capability and tries to JSON.parse it as an array,\n * and either returns the parsed array or a singleton array.\n *\n * @param {string|Array<String>} cap A desired capability\n */\nfunction parseCapsArray (cap) {\n  if (_.isArray(cap)) {\n    return cap;\n  }\n\n  let parsedCaps;\n  try {\n    parsedCaps = JSON.parse(cap);\n    if (_.isArray(parsedCaps)) {\n      return parsedCaps;\n    }\n  } catch (ign) {\n    logger.warn(`Failed to parse capability as JSON array`);\n  }\n  if (_.isString(cap)) {\n    return [cap];\n  }\n  throw new Error(`must provide a string or JSON Array; received ${cap}`);\n}\n\n/**\n * Generate a string that uniquely describes driver instance\n *\n * @param {import('@appium/types').Core} obj driver instance\n * @param {string?} sessionId session identifier (if exists)\n * @returns {string}\n */\nfunction generateDriverLogPrefix (obj, sessionId = null) {\n  const instanceName = `${obj.constructor.name}@${node.getObjectId(obj).substring(0, 4)}`;\n  return sessionId ? `${instanceName} (${sessionId.substring(0, 8)})` : instanceName;\n}\n\n/** @type {import('@appium/types').DriverHelpers} */\nexport default {\n  configureApp, isPackageOrBundle, duplicateKeys, parseCapsArray, generateDriverLogPrefix\n};\nexport {\n  configureApp, isPackageOrBundle, duplicateKeys, parseCapsArray, generateDriverLogPrefix\n};\n"]}