appium 2.0.0-beta.2 → 2.0.0-beta.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/README.md +9 -9
  2. package/build/lib/appium-config.schema.json +0 -0
  3. package/build/lib/appium.js +157 -53
  4. package/build/lib/cli/argparse-actions.js +104 -0
  5. package/build/lib/cli/args.js +115 -279
  6. package/build/lib/cli/driver-command.js +11 -1
  7. package/build/lib/cli/extension-command.js +60 -8
  8. package/build/lib/cli/extension.js +30 -7
  9. package/build/lib/cli/npm.js +17 -14
  10. package/build/lib/cli/parser.js +152 -89
  11. package/build/lib/cli/plugin-command.js +11 -1
  12. package/build/lib/cli/utils.js +29 -3
  13. package/build/lib/config-file.js +141 -0
  14. package/build/lib/config.js +76 -61
  15. package/build/lib/driver-config.js +42 -19
  16. package/build/lib/drivers.js +8 -4
  17. package/build/lib/ext-config-io.js +165 -0
  18. package/build/lib/extension-config.js +130 -61
  19. package/build/lib/grid-register.js +22 -24
  20. package/build/lib/logger.js +3 -3
  21. package/build/lib/logsink.js +11 -13
  22. package/build/lib/main.js +197 -77
  23. package/build/lib/plugin-config.js +20 -10
  24. package/build/lib/plugins.js +4 -2
  25. package/build/lib/schema/appium-config-schema.js +252 -0
  26. package/build/lib/schema/arg-spec.js +120 -0
  27. package/build/lib/schema/cli-args.js +173 -0
  28. package/build/lib/schema/cli-transformers.js +76 -0
  29. package/build/lib/schema/index.js +36 -0
  30. package/build/lib/schema/keywords.js +62 -0
  31. package/build/lib/schema/schema.js +357 -0
  32. package/build/lib/utils.js +44 -99
  33. package/lib/appium-config.schema.json +277 -0
  34. package/lib/appium.js +201 -65
  35. package/lib/cli/argparse-actions.js +77 -0
  36. package/lib/cli/args.js +174 -375
  37. package/lib/cli/driver-command.js +4 -0
  38. package/lib/cli/extension-command.js +70 -5
  39. package/lib/cli/extension.js +25 -5
  40. package/lib/cli/npm.js +18 -12
  41. package/lib/cli/parser.js +254 -79
  42. package/lib/cli/plugin-command.js +4 -0
  43. package/lib/cli/utils.js +21 -1
  44. package/lib/config-file.js +227 -0
  45. package/lib/config.js +109 -62
  46. package/lib/driver-config.js +66 -11
  47. package/lib/drivers.js +4 -1
  48. package/lib/ext-config-io.js +287 -0
  49. package/lib/extension-config.js +225 -67
  50. package/lib/grid-register.js +27 -24
  51. package/lib/logger.js +1 -1
  52. package/lib/logsink.js +10 -7
  53. package/lib/main.js +211 -77
  54. package/lib/plugin-config.js +34 -5
  55. package/lib/plugins.js +1 -0
  56. package/lib/schema/appium-config-schema.js +286 -0
  57. package/lib/schema/arg-spec.js +218 -0
  58. package/lib/schema/cli-args.js +273 -0
  59. package/lib/schema/cli-transformers.js +123 -0
  60. package/lib/schema/index.js +2 -0
  61. package/lib/schema/keywords.js +119 -0
  62. package/lib/schema/schema.js +577 -0
  63. package/lib/utils.js +42 -88
  64. package/package.json +55 -80
  65. package/postinstall.js +71 -0
  66. package/types/appium-config.d.ts +197 -0
  67. package/types/types.d.ts +201 -0
  68. package/CHANGELOG.md +0 -3515
  69. package/build/lib/cli/parser-helpers.js +0 -82
  70. package/lib/cli/parser-helpers.js +0 -79
@@ -5,25 +5,22 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.getBuildInfo = getBuildInfo;
9
- exports.validateServerArgs = validateServerArgs;
8
+ exports.APPIUM_VER = void 0;
10
9
  exports.checkNodeOk = checkNodeOk;
11
- exports.showConfig = showConfig;
12
- exports.warnNodeDeprecations = warnNodeDeprecations;
13
- exports.validateTmpDir = validateTmpDir;
14
- exports.getNonDefaultArgs = getNonDefaultArgs;
10
+ exports.getBuildInfo = getBuildInfo;
11
+ exports.getDeprecatedArgs = getDeprecatedArgs;
15
12
  exports.getGitRev = getGitRev;
16
- exports.checkValidPort = checkValidPort;
13
+ exports.getNonDefaultServerArgs = getNonDefaultServerArgs;
14
+ exports.showConfig = showConfig;
17
15
  exports.updateBuildInfo = updateBuildInfo;
18
- exports.APPIUM_VER = void 0;
16
+ exports.validateTmpDir = validateTmpDir;
17
+ exports.warnNodeDeprecations = warnNodeDeprecations;
19
18
 
20
19
  require("source-map-support/register");
21
20
 
22
21
  var _lodash = _interopRequireDefault(require("lodash"));
23
22
 
24
- var _path = _interopRequireDefault(require("path"));
25
-
26
- var _appiumSupport = require("appium-support");
23
+ var _support = require("@appium/support");
27
24
 
28
25
  var _axios = _interopRequireDefault(require("axios"));
29
26
 
@@ -35,13 +32,19 @@ var _logger = _interopRequireDefault(require("./logger"));
35
32
 
36
33
  var _semver = _interopRequireDefault(require("semver"));
37
34
 
38
- const npmPackage = require(_path.default.resolve(_utils.rootDir, 'package.json'));
35
+ var _argparseActions = require("./cli/argparse-actions");
36
+
37
+ var _findUp = _interopRequireDefault(require("find-up"));
38
+
39
+ var _schema = require("./schema/schema");
40
+
41
+ const npmPackage = _support.fs.readPackageJsonFrom(__dirname);
39
42
 
40
43
  const APPIUM_VER = npmPackage.version;
41
44
  exports.APPIUM_VER = APPIUM_VER;
42
45
  const MIN_NODE_VERSION = npmPackage.engines.node;
43
46
  const GIT_META_ROOT = '.git';
44
- const GIT_BINARY = `git${_appiumSupport.system.isWindows() ? '.exe' : ''}`;
47
+ const GIT_BINARY = `git${_support.system.isWindows() ? '.exe' : ''}`;
45
48
  const GITHUB_API = 'https://api.github.com/repos/appium/appium';
46
49
  const BUILD_INFO = {
47
50
  version: APPIUM_VER
@@ -51,6 +54,10 @@ function getNodeVersion() {
51
54
  return _semver.default.coerce(process.version);
52
55
  }
53
56
 
57
+ function isSubClass(candidateClass, superClass) {
58
+ return _lodash.default.isFunction(superClass) && _lodash.default.isFunction(candidateClass) && (candidateClass.prototype instanceof superClass || candidateClass === superClass);
59
+ }
60
+
54
61
  async function updateBuildInfo(useGithubApiFallback = false) {
55
62
  const sha = await getGitRev(useGithubApiFallback);
56
63
 
@@ -66,13 +73,22 @@ async function updateBuildInfo(useGithubApiFallback = false) {
66
73
  }
67
74
  }
68
75
 
76
+ async function findGitRoot() {
77
+ return await (0, _findUp.default)(GIT_META_ROOT, {
78
+ cwd: _utils.rootDir,
79
+ type: 'directory'
80
+ });
81
+ }
82
+
69
83
  async function getGitRev(useGithubApiFallback = false) {
70
- if (await _appiumSupport.fs.exists(_path.default.resolve(_utils.rootDir, GIT_META_ROOT))) {
84
+ const gitRoot = await findGitRoot();
85
+
86
+ if (gitRoot) {
71
87
  try {
72
88
  const {
73
89
  stdout
74
90
  } = await (0, _teen_process.exec)(GIT_BINARY, ['rev-parse', 'HEAD'], {
75
- cwd: _utils.rootDir
91
+ cwd: gitRoot
76
92
  });
77
93
  return stdout.trim();
78
94
  } catch (ign) {}
@@ -105,12 +121,14 @@ async function getGitRev(useGithubApiFallback = false) {
105
121
  }
106
122
 
107
123
  async function getGitTimestamp(commitSha, useGithubApiFallback = false) {
108
- if (await _appiumSupport.fs.exists(_path.default.resolve(_utils.rootDir, GIT_META_ROOT))) {
124
+ const gitRoot = await findGitRoot();
125
+
126
+ if (gitRoot) {
109
127
  try {
110
128
  const {
111
129
  stdout
112
130
  } = await (0, _teen_process.exec)(GIT_BINARY, ['show', '-s', '--format=%ci', commitSha], {
113
- cwd: _utils.rootDir
131
+ cwd: gitRoot
114
132
  });
115
133
  return stdout.trim();
116
134
  } catch (ign) {}
@@ -160,71 +178,68 @@ async function showConfig() {
160
178
  console.log(JSON.stringify(getBuildInfo()));
161
179
  }
162
180
 
163
- function getNonDefaultArgs(parser, args) {
164
- let nonDefaults = {};
181
+ function getNonDefaultServerArgs(parser, args) {
182
+ function typesDiffer(dest) {
183
+ return typeof args[dest] !== typeof defaultsFromSchema[dest];
184
+ }
165
185
 
166
- for (let rawArg of parser.rawArgs) {
167
- let arg = rawArg[1].dest;
186
+ function defaultValueIsArray(dest) {
187
+ return _lodash.default.isArray(defaultsFromSchema[dest]);
188
+ }
168
189
 
169
- if (args[arg] && args[arg] !== rawArg[1].defaultValue) {
170
- nonDefaults[arg] = args[arg];
171
- }
190
+ function argsValueIsArray(dest) {
191
+ return _lodash.default.isArray(args[dest]);
172
192
  }
173
193
 
174
- return nonDefaults;
175
- }
194
+ function arraysDiffer(dest) {
195
+ return _lodash.default.difference(args[dest], defaultsFromSchema[dest]).length > 0;
196
+ }
176
197
 
177
- function checkValidPort(port, portName) {
178
- if (port > 0 && port < 65536) return true;
198
+ function valuesUnequal(dest) {
199
+ return args[dest] !== defaultsFromSchema[dest];
200
+ }
179
201
 
180
- _logger.default.error(`Port '${portName}' must be greater than 0 and less than 65536. Currently ${port}`);
202
+ function defaultIsDefined(dest) {
203
+ return !_lodash.default.isUndefined(defaultsFromSchema[dest]);
204
+ }
181
205
 
182
- return false;
183
- }
206
+ const argValueNotArrayOrArraysDiffer = _lodash.default.overSome([_lodash.default.negate(argsValueIsArray), arraysDiffer]);
184
207
 
185
- function validateServerArgs(parser, args) {
186
- let exclusives = [['noReset', 'fullReset'], ['ipa', 'safari'], ['app', 'safari'], ['forceIphone', 'forceIpad'], ['deviceName', 'defaultDevice']];
208
+ const defaultValueNotArrayAndValuesUnequal = _lodash.default.overEvery([_lodash.default.negate(defaultValueIsArray), valuesUnequal]);
187
209
 
188
- for (let exSet of exclusives) {
189
- let numFoundInArgs = 0;
210
+ const isNotDefault = _lodash.default.overEvery([defaultIsDefined, _lodash.default.overSome([typesDiffer, _lodash.default.overEvery([defaultValueIsArray, argValueNotArrayOrArraysDiffer]), defaultValueNotArrayAndValuesUnequal])]);
190
211
 
191
- for (let opt of exSet) {
192
- if (_lodash.default.has(args, opt) && args[opt]) {
193
- numFoundInArgs++;
194
- }
195
- }
212
+ const defaultsFromSchema = (0, _schema.getDefaultsFromSchema)();
213
+ return _lodash.default.pickBy(args, (__, key) => isNotDefault(key));
214
+ }
196
215
 
197
- if (numFoundInArgs > 1) {
198
- throw new Error(`You can't pass in more than one argument from the ` + `set ${JSON.stringify(exSet)}, since they are ` + `mutually exclusive`);
216
+ function getDeprecatedArgs(parser, args) {
217
+ return parser.rawArgs.reduce((acc, [[name], {
218
+ dest,
219
+ default: defaultValue,
220
+ action
221
+ }]) => {
222
+ if (!args[dest] || args[dest] === defaultValue) {
223
+ return acc;
199
224
  }
200
- }
201
225
 
202
- const validations = {
203
- port: checkValidPort,
204
- callbackPort: checkValidPort,
205
- bootstrapPort: checkValidPort,
206
- chromedriverPort: checkValidPort,
207
- robotPort: checkValidPort,
208
- backendRetries: r => r >= 0
209
- };
210
- const nonDefaultArgs = getNonDefaultArgs(parser, args);
211
-
212
- for (let [arg, validator] of _lodash.default.toPairs(validations)) {
213
- if (_lodash.default.has(nonDefaultArgs, arg)) {
214
- if (!validator(args[arg], arg)) {
215
- throw new Error(`Invalid argument for param ${arg}: ${args[arg]}`);
216
- }
226
+ if (action !== null && action !== void 0 && action.deprecated_for) {
227
+ acc[name] = action.deprecated_for;
228
+ } else if (isSubClass(action, _argparseActions.StoreDeprecatedDefaultCapabilityAction)) {
229
+ acc[name] = _argparseActions.DEFAULT_CAPS_ARG;
217
230
  }
218
- }
231
+
232
+ return acc;
233
+ }, {});
219
234
  }
220
235
 
221
236
  async function validateTmpDir(tmpDir) {
222
237
  try {
223
- await (0, _appiumSupport.mkdirp)(tmpDir);
238
+ await (0, _support.mkdirp)(tmpDir);
224
239
  } catch (e) {
225
240
  throw new Error(`We could not ensure that the temp dir you specified ` + `(${tmpDir}) exists. Please make sure it's writeable.`);
226
241
  }
227
242
  }require('source-map-support').install();
228
243
 
229
244
 
230
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/config.js"],"names":["npmPackage","require","path","resolve","rootDir","APPIUM_VER","version","MIN_NODE_VERSION","engines","node","GIT_META_ROOT","GIT_BINARY","system","isWindows","GITHUB_API","BUILD_INFO","getNodeVersion","semver","coerce","process","updateBuildInfo","useGithubApiFallback","sha","getGitRev","built","getGitTimestamp","_","isEmpty","fs","exists","stdout","cwd","trim","ign","resBodyObj","axios","get","headers","data","isArray","name","commit","commitSha","committer","date","author","getBuildInfo","checkNodeOk","satisfies","logger","errorAndThrow","warnNodeDeprecations","showConfig","console","log","JSON","stringify","getNonDefaultArgs","parser","args","nonDefaults","rawArg","rawArgs","arg","dest","defaultValue","checkValidPort","port","portName","error","validateServerArgs","exclusives","exSet","numFoundInArgs","opt","has","Error","validations","callbackPort","bootstrapPort","chromedriverPort","robotPort","backendRetries","r","nonDefaultArgs","validator","toPairs","validateTmpDir","tmpDir","e"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport path from 'path';\nimport { mkdirp, fs, system } from 'appium-support';\nimport axios from 'axios';\nimport { exec } from 'teen_process';\nimport { rootDir } from './utils';\nimport logger from './logger';\nimport semver from 'semver';\n\n\nconst npmPackage = require(path.resolve(rootDir, 'package.json'));\nconst APPIUM_VER = npmPackage.version;\nconst MIN_NODE_VERSION = npmPackage.engines.node;\n\nconst GIT_META_ROOT = '.git';\nconst GIT_BINARY = `git${system.isWindows() ? '.exe' : ''}`;\nconst GITHUB_API = 'https://api.github.com/repos/appium/appium';\n\nconst BUILD_INFO = {\n  version: APPIUM_VER,\n};\n\nfunction getNodeVersion () {\n  return semver.coerce(process.version);\n}\n\nasync function updateBuildInfo (useGithubApiFallback = false) {\n  const sha = await getGitRev(useGithubApiFallback);\n  if (!sha) {\n    return;\n  }\n  BUILD_INFO['git-sha'] = sha;\n  const built = await getGitTimestamp(sha, useGithubApiFallback);\n  if (!_.isEmpty(built)) {\n    BUILD_INFO.built = built;\n  }\n}\n\nasync function getGitRev (useGithubApiFallback = false) {\n  if (await fs.exists(path.resolve(rootDir, GIT_META_ROOT))) {\n    try {\n      const {stdout} = await exec(GIT_BINARY, ['rev-parse', 'HEAD'], {\n        cwd: rootDir\n      });\n      return stdout.trim();\n    } catch (ign) {}\n  }\n\n  if (!useGithubApiFallback) {\n    return null;\n  }\n\n  try {\n    const resBodyObj = (await axios.get(`${GITHUB_API}/tags`, {\n      headers: {\n        'User-Agent': `Appium ${APPIUM_VER}`\n      }\n    })).data;\n    if (_.isArray(resBodyObj)) {\n      for (const {name, commit} of resBodyObj) {\n        if (name === `v${APPIUM_VER}` && commit && commit.sha) {\n          return commit.sha;\n        }\n      }\n    }\n  } catch (ign) {}\n  return null;\n}\n\nasync function getGitTimestamp (commitSha, useGithubApiFallback = false) {\n  if (await fs.exists(path.resolve(rootDir, GIT_META_ROOT))) {\n    try {\n      const {stdout} = await exec(GIT_BINARY, ['show', '-s', '--format=%ci', commitSha], {\n        cwd: rootDir\n      });\n      return stdout.trim();\n    } catch (ign) {}\n  }\n\n  if (!useGithubApiFallback) {\n    return null;\n  }\n\n  try {\n    const resBodyObj = (await axios.get(`${GITHUB_API}/commits/${commitSha}`, {\n      headers: {\n        'User-Agent': `Appium ${APPIUM_VER}`\n      }\n    })).data;\n    if (resBodyObj && resBodyObj.commit) {\n      if (resBodyObj.commit.committer && resBodyObj.commit.committer.date) {\n        return resBodyObj.commit.committer.date;\n      }\n      if (resBodyObj.commit.author && resBodyObj.commit.author.date) {\n        return resBodyObj.commit.author.date;\n      }\n    }\n  } catch (ign) {}\n  return null;\n}\n\n/**\n * @return Mutable object containing Appium build information. By default it\n * only contains the Appium version, but is updated with the build timestamp\n * and git commit hash asynchronously as soon as `updateBuildInfo` is called\n * and succeeds.\n */\nfunction getBuildInfo () {\n  return BUILD_INFO;\n}\n\nfunction checkNodeOk () {\n  const version = getNodeVersion();\n  if (!semver.satisfies(version, MIN_NODE_VERSION)) {\n    logger.errorAndThrow(`Node version must be ${MIN_NODE_VERSION}. Currently ${version.version}`);\n  }\n}\n\nfunction warnNodeDeprecations () {\n  /**\n   * Uncomment this section to get node version deprecation warnings\n   * Also add test cases to config-specs.js to cover the cases added\n   **/\n\n  // const version = getNodeVersion();\n  // if (version.major < 8) {\n  //   logger.warn(`Appium support for versions of node < ${version.major} has been ` +\n  //               'deprecated and will be removed in a future version. Please ' +\n  //               'upgrade!');\n  // }\n}\n\nasync function showConfig () {\n  await updateBuildInfo(true);\n  console.log(JSON.stringify(getBuildInfo())); // eslint-disable-line no-console\n}\n\nfunction getNonDefaultArgs (parser, args) {\n  let nonDefaults = {};\n  for (let rawArg of parser.rawArgs) {\n    let arg = rawArg[1].dest;\n    if (args[arg] && args[arg] !== rawArg[1].defaultValue) {\n      nonDefaults[arg] = args[arg];\n    }\n  }\n  return nonDefaults;\n}\n\nfunction checkValidPort (port, portName) {\n  if (port > 0 && port < 65536) return true; // eslint-disable-line curly\n  logger.error(`Port '${portName}' must be greater than 0 and less than 65536. Currently ${port}`);\n  return false;\n}\n\nfunction validateServerArgs (parser, args) {\n  // arguments that cannot both be set\n  let exclusives = [\n    ['noReset', 'fullReset'],\n    ['ipa', 'safari'],\n    ['app', 'safari'],\n    ['forceIphone', 'forceIpad'],\n    ['deviceName', 'defaultDevice']\n  ];\n\n  for (let exSet of exclusives) {\n    let numFoundInArgs = 0;\n    for (let opt of exSet) {\n      if (_.has(args, opt) && args[opt]) {\n        numFoundInArgs++;\n      }\n    }\n    if (numFoundInArgs > 1) {\n      throw new Error(`You can't pass in more than one argument from the ` +\n                      `set ${JSON.stringify(exSet)}, since they are ` +\n                      `mutually exclusive`);\n    }\n  }\n\n  const validations = {\n    port: checkValidPort,\n    callbackPort: checkValidPort,\n    bootstrapPort: checkValidPort,\n    chromedriverPort: checkValidPort,\n    robotPort: checkValidPort,\n    backendRetries: (r) => r >= 0\n  };\n\n  const nonDefaultArgs = getNonDefaultArgs(parser, args);\n\n  for (let [arg, validator] of _.toPairs(validations)) {\n    if (_.has(nonDefaultArgs, arg)) {\n      if (!validator(args[arg], arg)) {\n        throw new Error(`Invalid argument for param ${arg}: ${args[arg]}`);\n      }\n    }\n  }\n}\n\nasync function validateTmpDir (tmpDir) {\n  try {\n    await mkdirp(tmpDir);\n  } catch (e) {\n    throw new Error(`We could not ensure that the temp dir you specified ` +\n                    `(${tmpDir}) exists. Please make sure it's writeable.`);\n  }\n}\n\nexport {\n  getBuildInfo, validateServerArgs, checkNodeOk, showConfig,\n  warnNodeDeprecations, validateTmpDir, getNonDefaultArgs,\n  getGitRev, checkValidPort, APPIUM_VER, updateBuildInfo,\n};\n"],"file":"lib/config.js","sourceRoot":"../.."}
245
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/config.js"],"names":["npmPackage","fs","readPackageJsonFrom","__dirname","APPIUM_VER","version","MIN_NODE_VERSION","engines","node","GIT_META_ROOT","GIT_BINARY","system","isWindows","GITHUB_API","BUILD_INFO","getNodeVersion","semver","coerce","process","isSubClass","candidateClass","superClass","_","isFunction","prototype","updateBuildInfo","useGithubApiFallback","sha","getGitRev","built","getGitTimestamp","isEmpty","findGitRoot","cwd","rootDir","type","gitRoot","stdout","trim","ign","resBodyObj","axios","get","headers","data","isArray","name","commit","commitSha","committer","date","author","getBuildInfo","checkNodeOk","satisfies","logger","errorAndThrow","warnNodeDeprecations","showConfig","console","log","JSON","stringify","getNonDefaultServerArgs","parser","args","typesDiffer","dest","defaultsFromSchema","defaultValueIsArray","argsValueIsArray","arraysDiffer","difference","length","valuesUnequal","defaultIsDefined","isUndefined","argValueNotArrayOrArraysDiffer","overSome","negate","defaultValueNotArrayAndValuesUnequal","overEvery","isNotDefault","pickBy","__","key","getDeprecatedArgs","rawArgs","reduce","acc","default","defaultValue","action","deprecated_for","StoreDeprecatedDefaultCapabilityAction","DEFAULT_CAPS_ARG","validateTmpDir","tmpDir","e","Error"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AAEA,MAAMA,UAAU,GAAGC,YAAGC,mBAAH,CAAuBC,SAAvB,CAAnB;;AAEA,MAAMC,UAAU,GAAGJ,UAAU,CAACK,OAA9B;;AACA,MAAMC,gBAAgB,GAAGN,UAAU,CAACO,OAAX,CAAmBC,IAA5C;AAEA,MAAMC,aAAa,GAAG,MAAtB;AACA,MAAMC,UAAU,GAAI,MAAKC,gBAAOC,SAAP,KAAqB,MAArB,GAA8B,EAAG,EAA1D;AACA,MAAMC,UAAU,GAAG,4CAAnB;AAEA,MAAMC,UAAU,GAAG;AACjBT,EAAAA,OAAO,EAAED;AADQ,CAAnB;;AAIA,SAASW,cAAT,GAA2B;AACzB,SAAOC,gBAAOC,MAAP,CAAcC,OAAO,CAACb,OAAtB,CAAP;AACD;;AAED,SAASc,UAAT,CAAqBC,cAArB,EAAqCC,UAArC,EAAiD;AAC/C,SAAOC,gBAAEC,UAAF,CAAaF,UAAb,KAA4BC,gBAAEC,UAAF,CAAaH,cAAb,CAA5B,KACDA,cAAc,CAACI,SAAf,YAAoCH,UAApC,IAAkDD,cAAc,KAAKC,UADpE,CAAP;AAED;;AAED,eAAeI,eAAf,CAAgCC,oBAAoB,GAAG,KAAvD,EAA8D;AAC5D,QAAMC,GAAG,GAAG,MAAMC,SAAS,CAACF,oBAAD,CAA3B;;AACA,MAAI,CAACC,GAAL,EAAU;AACR;AACD;;AACDb,EAAAA,UAAU,CAAC,SAAD,CAAV,GAAwBa,GAAxB;AACA,QAAME,KAAK,GAAG,MAAMC,eAAe,CAACH,GAAD,EAAMD,oBAAN,CAAnC;;AACA,MAAI,CAACJ,gBAAES,OAAF,CAAUF,KAAV,CAAL,EAAuB;AACrBf,IAAAA,UAAU,CAACe,KAAX,GAAmBA,KAAnB;AACD;AACF;;AASD,eAAeG,WAAf,GAA8B;AAC5B,SAAO,MAAM,qBAAOvB,aAAP,EAAsB;AAACwB,IAAAA,GAAG,EAAEC,cAAN;AAAeC,IAAAA,IAAI,EAAE;AAArB,GAAtB,CAAb;AACD;;AAED,eAAeP,SAAf,CAA0BF,oBAAoB,GAAG,KAAjD,EAAwD;AACtD,QAAMU,OAAO,GAAG,MAAMJ,WAAW,EAAjC;;AACA,MAAII,OAAJ,EAAa;AACX,QAAI;AACF,YAAM;AAACC,QAAAA;AAAD,UAAW,MAAM,wBAAK3B,UAAL,EAAiB,CAAC,WAAD,EAAc,MAAd,CAAjB,EAAwC;AAC7DuB,QAAAA,GAAG,EAAEG;AADwD,OAAxC,CAAvB;AAGA,aAAOC,MAAM,CAACC,IAAP,EAAP;AACD,KALD,CAKE,OAAOC,GAAP,EAAY,CAAE;AACjB;;AAED,MAAI,CAACb,oBAAL,EAA2B;AACzB,WAAO,IAAP;AACD;;AAED,MAAI;AACF,UAAMc,UAAU,GAAG,CAAC,MAAMC,eAAMC,GAAN,CAAW,GAAE7B,UAAW,OAAxB,EAAgC;AACxD8B,MAAAA,OAAO,EAAE;AACP,sBAAe,UAASvC,UAAW;AAD5B;AAD+C,KAAhC,CAAP,EAIfwC,IAJJ;;AAKA,QAAItB,gBAAEuB,OAAF,CAAUL,UAAV,CAAJ,EAA2B;AACzB,WAAK,MAAM;AAACM,QAAAA,IAAD;AAAOC,QAAAA;AAAP,OAAX,IAA6BP,UAA7B,EAAyC;AACvC,YAAIM,IAAI,KAAM,IAAG1C,UAAW,EAAxB,IAA6B2C,MAA7B,IAAuCA,MAAM,CAACpB,GAAlD,EAAuD;AACrD,iBAAOoB,MAAM,CAACpB,GAAd;AACD;AACF;AACF;AACF,GAbD,CAaE,OAAOY,GAAP,EAAY,CAAE;;AAChB,SAAO,IAAP;AACD;;AAED,eAAeT,eAAf,CAAgCkB,SAAhC,EAA2CtB,oBAAoB,GAAG,KAAlE,EAAyE;AACvE,QAAMU,OAAO,GAAG,MAAMJ,WAAW,EAAjC;;AACA,MAAII,OAAJ,EAAa;AACX,QAAI;AACF,YAAM;AAACC,QAAAA;AAAD,UAAW,MAAM,wBAAK3B,UAAL,EAAiB,CAAC,MAAD,EAAS,IAAT,EAAe,cAAf,EAA+BsC,SAA/B,CAAjB,EAA4D;AACjFf,QAAAA,GAAG,EAAEG;AAD4E,OAA5D,CAAvB;AAGA,aAAOC,MAAM,CAACC,IAAP,EAAP;AACD,KALD,CAKE,OAAOC,GAAP,EAAY,CAAE;AACjB;;AAED,MAAI,CAACb,oBAAL,EAA2B;AACzB,WAAO,IAAP;AACD;;AAED,MAAI;AACF,UAAMc,UAAU,GAAG,CAAC,MAAMC,eAAMC,GAAN,CAAW,GAAE7B,UAAW,YAAWmC,SAAU,EAA7C,EAAgD;AACxEL,MAAAA,OAAO,EAAE;AACP,sBAAe,UAASvC,UAAW;AAD5B;AAD+D,KAAhD,CAAP,EAIfwC,IAJJ;;AAKA,QAAIJ,UAAU,IAAIA,UAAU,CAACO,MAA7B,EAAqC;AACnC,UAAIP,UAAU,CAACO,MAAX,CAAkBE,SAAlB,IAA+BT,UAAU,CAACO,MAAX,CAAkBE,SAAlB,CAA4BC,IAA/D,EAAqE;AACnE,eAAOV,UAAU,CAACO,MAAX,CAAkBE,SAAlB,CAA4BC,IAAnC;AACD;;AACD,UAAIV,UAAU,CAACO,MAAX,CAAkBI,MAAlB,IAA4BX,UAAU,CAACO,MAAX,CAAkBI,MAAlB,CAAyBD,IAAzD,EAA+D;AAC7D,eAAOV,UAAU,CAACO,MAAX,CAAkBI,MAAlB,CAAyBD,IAAhC;AACD;AACF;AACF,GAdD,CAcE,OAAOX,GAAP,EAAY,CAAE;;AAChB,SAAO,IAAP;AACD;;AAQD,SAASa,YAAT,GAAyB;AACvB,SAAOtC,UAAP;AACD;;AAED,SAASuC,WAAT,GAAwB;AACtB,QAAMhD,OAAO,GAAGU,cAAc,EAA9B;;AACA,MAAI,CAACC,gBAAOsC,SAAP,CAAiBjD,OAAjB,EAA0BC,gBAA1B,CAAL,EAAkD;AAChDiD,oBAAOC,aAAP,CAAsB,wBAAuBlD,gBAAiB,eAAcD,OAAO,CAACA,OAAQ,EAA5F;AACD;AACF;;AAED,SAASoD,oBAAT,GAAiC,CAYhC;;AAED,eAAeC,UAAf,GAA6B;AAC3B,QAAMjC,eAAe,CAAC,IAAD,CAArB;AACAkC,EAAAA,OAAO,CAACC,GAAR,CAAYC,IAAI,CAACC,SAAL,CAAeV,YAAY,EAA3B,CAAZ;AACD;;AAED,SAASW,uBAAT,CAAkCC,MAAlC,EAA0CC,IAA1C,EAAgD;AAG9C,WAASC,WAAT,CAAsBC,IAAtB,EAA4B;AAC1B,WAAO,OAAOF,IAAI,CAACE,IAAD,CAAX,KAAsB,OAAOC,kBAAkB,CAACD,IAAD,CAAtD;AACD;;AAED,WAASE,mBAAT,CAA8BF,IAA9B,EAAoC;AAClC,WAAO7C,gBAAEuB,OAAF,CAAUuB,kBAAkB,CAACD,IAAD,CAA5B,CAAP;AACD;;AAED,WAASG,gBAAT,CAA2BH,IAA3B,EAAiC;AAC/B,WAAO7C,gBAAEuB,OAAF,CAAUoB,IAAI,CAACE,IAAD,CAAd,CAAP;AACD;;AAED,WAASI,YAAT,CAAuBJ,IAAvB,EAA6B;AAC3B,WAAO7C,gBAAEkD,UAAF,CAAaP,IAAI,CAACE,IAAD,CAAjB,EAAyBC,kBAAkB,CAACD,IAAD,CAA3C,EAAmDM,MAAnD,GAA4D,CAAnE;AACD;;AAED,WAASC,aAAT,CAAwBP,IAAxB,EAA8B;AAC5B,WAAOF,IAAI,CAACE,IAAD,CAAJ,KAAeC,kBAAkB,CAACD,IAAD,CAAxC;AACD;;AAED,WAASQ,gBAAT,CAA2BR,IAA3B,EAAiC;AAC/B,WAAO,CAAC7C,gBAAEsD,WAAF,CAAcR,kBAAkB,CAACD,IAAD,CAAhC,CAAR;AACD;;AAID,QAAMU,8BAA8B,GAAGvD,gBAAEwD,QAAF,CAAW,CAChDxD,gBAAEyD,MAAF,CAAST,gBAAT,CADgD,EAEhDC,YAFgD,CAAX,CAAvC;;AAKA,QAAMS,oCAAoC,GAAG1D,gBAAE2D,SAAF,CAAY,CACvD3D,gBAAEyD,MAAF,CAASV,mBAAT,CADuD,EACxBK,aADwB,CAAZ,CAA7C;;AAiBA,QAAMQ,YAAY,GAAG5D,gBAAE2D,SAAF,CAAY,CAC/BN,gBAD+B,EAE/BrD,gBAAEwD,QAAF,CAAW,CACTZ,WADS,EAET5C,gBAAE2D,SAAF,CAAY,CACVZ,mBADU,EAEVQ,8BAFU,CAAZ,CAFS,EAMTG,oCANS,CAAX,CAF+B,CAAZ,CAArB;;AAYA,QAAMZ,kBAAkB,GAAG,oCAA3B;AAEA,SAAO9C,gBAAE6D,MAAF,CAASlB,IAAT,EAAe,CAACmB,EAAD,EAAKC,GAAL,KAAaH,YAAY,CAACG,GAAD,CAAxC,CAAP;AACD;;AAED,SAASC,iBAAT,CAA4BtB,MAA5B,EAAoCC,IAApC,EAA0C;AAGxC,SAAOD,MAAM,CAACuB,OAAP,CAAeC,MAAf,CAAsB,CAACC,GAAD,EAAM,CAAC,CAAC3C,IAAD,CAAD,EAAS;AAACqB,IAAAA,IAAD;AAAOuB,IAAAA,OAAO,EAAEC,YAAhB;AAA8BC,IAAAA;AAA9B,GAAT,CAAN,KAA0D;AACrF,QAAI,CAAC3B,IAAI,CAACE,IAAD,CAAL,IAAeF,IAAI,CAACE,IAAD,CAAJ,KAAewB,YAAlC,EAAgD;AAC9C,aAAOF,GAAP;AACD;;AAED,QAAIG,MAAJ,aAAIA,MAAJ,eAAIA,MAAM,CAAEC,cAAZ,EAA4B;AAC1BJ,MAAAA,GAAG,CAAC3C,IAAD,CAAH,GAAY8C,MAAM,CAACC,cAAnB;AACD,KAFD,MAEO,IAAI1E,UAAU,CAACyE,MAAD,EAASE,uDAAT,CAAd,EAAgE;AACrEL,MAAAA,GAAG,CAAC3C,IAAD,CAAH,GAAYiD,iCAAZ;AACD;;AACD,WAAON,GAAP;AACD,GAXM,EAWJ,EAXI,CAAP;AAYD;;AAED,eAAeO,cAAf,CAA+BC,MAA/B,EAAuC;AACrC,MAAI;AACF,UAAM,qBAAOA,MAAP,CAAN;AACD,GAFD,CAEE,OAAOC,CAAP,EAAU;AACV,UAAM,IAAIC,KAAJ,CAAW,sDAAD,GACC,IAAGF,MAAO,4CADrB,CAAN;AAED;AACF","sourcesContent":["import _ from 'lodash';\nimport { mkdirp, system, fs } from '@appium/support';\nimport axios from 'axios';\nimport { exec } from 'teen_process';\nimport { rootDir } from './utils';\nimport logger from './logger';\nimport semver from 'semver';\nimport {\n  StoreDeprecatedDefaultCapabilityAction, DEFAULT_CAPS_ARG,\n} from './cli/argparse-actions';\nimport findUp from 'find-up';\nimport { getDefaultsFromSchema } from './schema/schema';\n\nconst npmPackage = fs.readPackageJsonFrom(__dirname);\n\nconst APPIUM_VER = npmPackage.version;\nconst MIN_NODE_VERSION = npmPackage.engines.node;\n\nconst GIT_META_ROOT = '.git';\nconst GIT_BINARY = `git${system.isWindows() ? '.exe' : ''}`;\nconst GITHUB_API = 'https://api.github.com/repos/appium/appium';\n\nconst BUILD_INFO = {\n  version: APPIUM_VER,\n};\n\nfunction getNodeVersion () {\n  return semver.coerce(process.version);\n}\n\nfunction isSubClass (candidateClass, superClass) {\n  return _.isFunction(superClass) && _.isFunction(candidateClass)\n    && (candidateClass.prototype instanceof superClass || candidateClass === superClass);\n}\n\nasync function updateBuildInfo (useGithubApiFallback = false) {\n  const sha = await getGitRev(useGithubApiFallback);\n  if (!sha) {\n    return;\n  }\n  BUILD_INFO['git-sha'] = sha;\n  const built = await getGitTimestamp(sha, useGithubApiFallback);\n  if (!_.isEmpty(built)) {\n    BUILD_INFO.built = built;\n  }\n}\n\n/**\n * Finds the Git metadata dir (see `GIT_META_ROOT`)\n *\n * This is needed because Appium cannot assume `package.json` and `.git` are in the same\n * directory.  Monorepos, see?\n * @returns {string|void} Path to dir or `undefined` if not found\n */\nasync function findGitRoot () {\n  return await findUp(GIT_META_ROOT, {cwd: rootDir, type: 'directory'});\n}\n\nasync function getGitRev (useGithubApiFallback = false) {\n  const gitRoot = await findGitRoot();\n  if (gitRoot) {\n    try {\n      const {stdout} = await exec(GIT_BINARY, ['rev-parse', 'HEAD'], {\n        cwd: gitRoot\n      });\n      return stdout.trim();\n    } catch (ign) {}\n  }\n\n  if (!useGithubApiFallback) {\n    return null;\n  }\n\n  try {\n    const resBodyObj = (await axios.get(`${GITHUB_API}/tags`, {\n      headers: {\n        'User-Agent': `Appium ${APPIUM_VER}`\n      }\n    })).data;\n    if (_.isArray(resBodyObj)) {\n      for (const {name, commit} of resBodyObj) {\n        if (name === `v${APPIUM_VER}` && commit && commit.sha) {\n          return commit.sha;\n        }\n      }\n    }\n  } catch (ign) {}\n  return null;\n}\n\nasync function getGitTimestamp (commitSha, useGithubApiFallback = false) {\n  const gitRoot = await findGitRoot();\n  if (gitRoot) {\n    try {\n      const {stdout} = await exec(GIT_BINARY, ['show', '-s', '--format=%ci', commitSha], {\n        cwd: gitRoot\n      });\n      return stdout.trim();\n    } catch (ign) {}\n  }\n\n  if (!useGithubApiFallback) {\n    return null;\n  }\n\n  try {\n    const resBodyObj = (await axios.get(`${GITHUB_API}/commits/${commitSha}`, {\n      headers: {\n        'User-Agent': `Appium ${APPIUM_VER}`\n      }\n    })).data;\n    if (resBodyObj && resBodyObj.commit) {\n      if (resBodyObj.commit.committer && resBodyObj.commit.committer.date) {\n        return resBodyObj.commit.committer.date;\n      }\n      if (resBodyObj.commit.author && resBodyObj.commit.author.date) {\n        return resBodyObj.commit.author.date;\n      }\n    }\n  } catch (ign) {}\n  return null;\n}\n\n/**\n * @return Mutable object containing Appium build information. By default it\n * only contains the Appium version, but is updated with the build timestamp\n * and git commit hash asynchronously as soon as `updateBuildInfo` is called\n * and succeeds.\n */\nfunction getBuildInfo () {\n  return BUILD_INFO;\n}\n\nfunction checkNodeOk () {\n  const version = getNodeVersion();\n  if (!semver.satisfies(version, MIN_NODE_VERSION)) {\n    logger.errorAndThrow(`Node version must be ${MIN_NODE_VERSION}. Currently ${version.version}`);\n  }\n}\n\nfunction warnNodeDeprecations () {\n  /**\n   * Uncomment this section to get node version deprecation warnings\n   * Also add test cases to config-specs.js to cover the cases added\n   **/\n\n  // const version = getNodeVersion();\n  // if (version.major < 8) {\n  //   logger.warn(`Appium support for versions of node < ${version.major} has been ` +\n  //               'deprecated and will be removed in a future version. Please ' +\n  //               'upgrade!');\n  // }\n}\n\nasync function showConfig () {\n  await updateBuildInfo(true);\n  console.log(JSON.stringify(getBuildInfo())); // eslint-disable-line no-console\n}\n\nfunction getNonDefaultServerArgs (parser, args) {\n  // hopefully these function names are descriptive enough\n\n  function typesDiffer (dest) {\n    return typeof args[dest] !== typeof defaultsFromSchema[dest];\n  }\n\n  function defaultValueIsArray (dest) {\n    return _.isArray(defaultsFromSchema[dest]);\n  }\n\n  function argsValueIsArray (dest) {\n    return _.isArray(args[dest]);\n  }\n\n  function arraysDiffer (dest) {\n    return _.difference(args[dest], defaultsFromSchema[dest]).length > 0;\n  }\n\n  function valuesUnequal (dest) {\n    return args[dest] !== defaultsFromSchema[dest];\n  }\n\n  function defaultIsDefined (dest) {\n    return !_.isUndefined(defaultsFromSchema[dest]);\n  }\n\n  // note that `_.overEvery` is like an \"AND\", and `_.overSome` is like an \"OR\"\n\n  const argValueNotArrayOrArraysDiffer = _.overSome([\n    _.negate(argsValueIsArray),\n    arraysDiffer\n  ]);\n\n  const defaultValueNotArrayAndValuesUnequal = _.overEvery([\n    _.negate(defaultValueIsArray), valuesUnequal\n  ]);\n\n  /**\n   * This used to be a hideous conditional, but it's broken up into a hideous function instead.\n   * hopefully this makes things a little more understandable.\n   * - checks if the default value is defined\n   * - if so, and the default is not an array:\n   *   - ensures the types are the same\n   *   - ensures the values are equal\n   * - if so, and the default is an array:\n   *   - ensures the args value is an array\n   *   - ensures the args values do not differ from the default values\n   * @param {string} dest - argument name (`dest` value)\n   * @returns {boolean}\n   */\n  const isNotDefault = _.overEvery([\n    defaultIsDefined,\n    _.overSome([\n      typesDiffer,\n      _.overEvery([\n        defaultValueIsArray,\n        argValueNotArrayOrArraysDiffer\n      ]),\n      defaultValueNotArrayAndValuesUnequal\n    ])\n  ]);\n\n  const defaultsFromSchema = getDefaultsFromSchema();\n\n  return _.pickBy(args, (__, key) => isNotDefault(key));\n}\n\nfunction getDeprecatedArgs (parser, args) {\n  // go through the server command line arguments and figure\n  // out which of the ones used are deprecated\n  return parser.rawArgs.reduce((acc, [[name], {dest, default: defaultValue, action}]) => {\n    if (!args[dest] || args[dest] === defaultValue) {\n      return acc;\n    }\n\n    if (action?.deprecated_for) {\n      acc[name] = action.deprecated_for;\n    } else if (isSubClass(action, StoreDeprecatedDefaultCapabilityAction)) {\n      acc[name] = DEFAULT_CAPS_ARG;\n    }\n    return acc;\n  }, {});\n}\n\nasync function validateTmpDir (tmpDir) {\n  try {\n    await mkdirp(tmpDir);\n  } catch (e) {\n    throw new Error(`We could not ensure that the temp dir you specified ` +\n                    `(${tmpDir}) exists. Please make sure it's writeable.`);\n  }\n}\n\nexport {\n  getBuildInfo, checkNodeOk, showConfig,\n  warnNodeDeprecations, validateTmpDir, getNonDefaultServerArgs,\n  getGitRev, APPIUM_VER, updateBuildInfo,\n  getDeprecatedArgs\n};\n"],"file":"lib/config.js","sourceRoot":"../.."}
@@ -1,7 +1,5 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
4
 
7
5
  Object.defineProperty(exports, "__esModule", {
@@ -9,37 +7,61 @@ Object.defineProperty(exports, "__esModule", {
9
7
  });
10
8
  exports.default = void 0;
11
9
 
10
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
+
12
12
  require("source-map-support/register");
13
13
 
14
14
  var _lodash = _interopRequireDefault(require("lodash"));
15
15
 
16
- var _extensionConfig = _interopRequireWildcard(require("./extension-config"));
16
+ var _extensionConfig = _interopRequireDefault(require("./extension-config"));
17
+
18
+ var _extConfigIo = require("./ext-config-io");
17
19
 
18
20
  class DriverConfig extends _extensionConfig.default {
19
- constructor(appiumHome, logFn = null) {
20
- super(appiumHome, _extensionConfig.DRIVER_TYPE, logFn);
21
+ constructor(appiumHome, logFn) {
22
+ super(appiumHome, _extConfigIo.DRIVER_TYPE, logFn);
23
+ this.knownAutomationNames = new Set();
24
+ }
25
+
26
+ async read() {
27
+ this.knownAutomationNames.clear();
28
+ return await super.read();
29
+ }
30
+
31
+ static getInstance(appiumHome, logFn) {
32
+ var _DriverConfig$_instan;
33
+
34
+ const instance = (_DriverConfig$_instan = DriverConfig._instances[appiumHome]) !== null && _DriverConfig$_instan !== void 0 ? _DriverConfig$_instan : new DriverConfig(appiumHome, logFn);
35
+ DriverConfig._instances[appiumHome] = instance;
36
+ return instance;
21
37
  }
22
38
 
23
- getConfigProblems(driver) {
39
+ getConfigProblems(extData, extName) {
24
40
  const problems = [];
25
- const automationNames = [];
26
41
  const {
27
42
  platformNames,
28
43
  automationName
29
- } = driver;
44
+ } = extData;
30
45
 
31
46
  if (!_lodash.default.isArray(platformNames)) {
32
47
  problems.push({
33
- err: 'Missing or incorrect supported platformName list.',
48
+ err: 'Missing or incorrect supported platformNames list.',
34
49
  val: platformNames
35
50
  });
36
51
  } else {
37
- for (const pName of platformNames) {
38
- if (!_lodash.default.isString(pName)) {
39
- problems.push({
40
- err: 'Incorrectly formatted platformName.',
41
- val: pName
42
- });
52
+ if (_lodash.default.isEmpty(platformNames)) {
53
+ problems.push({
54
+ err: 'Empty platformNames list.',
55
+ val: platformNames
56
+ });
57
+ } else {
58
+ for (const pName of platformNames) {
59
+ if (!_lodash.default.isString(pName)) {
60
+ problems.push({
61
+ err: 'Incorrectly formatted platformName.',
62
+ val: pName
63
+ });
64
+ }
43
65
  }
44
66
  }
45
67
  }
@@ -51,14 +73,14 @@ class DriverConfig extends _extensionConfig.default {
51
73
  });
52
74
  }
53
75
 
54
- if (_lodash.default.includes(automationNames, automationName)) {
76
+ if (this.knownAutomationNames.has(automationName)) {
55
77
  problems.push({
56
78
  err: 'Multiple drivers claim support for the same automationName',
57
79
  val: automationName
58
80
  });
59
81
  }
60
82
 
61
- automationNames.push(automationName);
83
+ this.knownAutomationNames.add(automationName);
62
84
  return problems;
63
85
  }
64
86
 
@@ -71,7 +93,8 @@ class DriverConfig extends _extensionConfig.default {
71
93
 
72
94
  }
73
95
 
74
- exports.default = DriverConfig;require('source-map-support').install();
96
+ exports.default = DriverConfig;
97
+ (0, _defineProperty2.default)(DriverConfig, "_instances", {});require('source-map-support').install();
75
98
 
76
99
 
77
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kcml2ZXItY29uZmlnLmpzIl0sIm5hbWVzIjpbIkRyaXZlckNvbmZpZyIsIkV4dGVuc2lvbkNvbmZpZyIsImNvbnN0cnVjdG9yIiwiYXBwaXVtSG9tZSIsImxvZ0ZuIiwiRFJJVkVSX1RZUEUiLCJnZXRDb25maWdQcm9ibGVtcyIsImRyaXZlciIsInByb2JsZW1zIiwiYXV0b21hdGlvbk5hbWVzIiwicGxhdGZvcm1OYW1lcyIsImF1dG9tYXRpb25OYW1lIiwiXyIsImlzQXJyYXkiLCJwdXNoIiwiZXJyIiwidmFsIiwicE5hbWUiLCJpc1N0cmluZyIsImluY2x1ZGVzIiwiZXh0ZW5zaW9uRGVzYyIsImRyaXZlck5hbWUiLCJ2ZXJzaW9uIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBRWUsTUFBTUEsWUFBTixTQUEyQkMsd0JBQTNCLENBQTJDO0FBQ3hEQyxFQUFBQSxXQUFXLENBQUVDLFVBQUYsRUFBY0MsS0FBSyxHQUFHLElBQXRCLEVBQTRCO0FBQ3JDLFVBQU1ELFVBQU4sRUFBa0JFLDRCQUFsQixFQUErQkQsS0FBL0I7QUFDRDs7QUFFREUsRUFBQUEsaUJBQWlCLENBQUVDLE1BQUYsRUFBVTtBQUN6QixVQUFNQyxRQUFRLEdBQUcsRUFBakI7QUFDQSxVQUFNQyxlQUFlLEdBQUcsRUFBeEI7QUFDQSxVQUFNO0FBQUNDLE1BQUFBLGFBQUQ7QUFBZ0JDLE1BQUFBO0FBQWhCLFFBQWtDSixNQUF4Qzs7QUFFQSxRQUFJLENBQUNLLGdCQUFFQyxPQUFGLENBQVVILGFBQVYsQ0FBTCxFQUErQjtBQUM3QkYsTUFBQUEsUUFBUSxDQUFDTSxJQUFULENBQWM7QUFDWkMsUUFBQUEsR0FBRyxFQUFFLG1EQURPO0FBRVpDLFFBQUFBLEdBQUcsRUFBRU47QUFGTyxPQUFkO0FBSUQsS0FMRCxNQUtPO0FBQ0wsV0FBSyxNQUFNTyxLQUFYLElBQW9CUCxhQUFwQixFQUFtQztBQUNqQyxZQUFJLENBQUNFLGdCQUFFTSxRQUFGLENBQVdELEtBQVgsQ0FBTCxFQUF3QjtBQUN0QlQsVUFBQUEsUUFBUSxDQUFDTSxJQUFULENBQWM7QUFBQ0MsWUFBQUEsR0FBRyxFQUFFLHFDQUFOO0FBQTZDQyxZQUFBQSxHQUFHLEVBQUVDO0FBQWxELFdBQWQ7QUFDRDtBQUNGO0FBQ0Y7O0FBRUQsUUFBSSxDQUFDTCxnQkFBRU0sUUFBRixDQUFXUCxjQUFYLENBQUwsRUFBaUM7QUFDL0JILE1BQUFBLFFBQVEsQ0FBQ00sSUFBVCxDQUFjO0FBQUNDLFFBQUFBLEdBQUcsRUFBRSxxQ0FBTjtBQUE2Q0MsUUFBQUEsR0FBRyxFQUFFTDtBQUFsRCxPQUFkO0FBQ0Q7O0FBRUQsUUFBSUMsZ0JBQUVPLFFBQUYsQ0FBV1YsZUFBWCxFQUE0QkUsY0FBNUIsQ0FBSixFQUFpRDtBQUMvQ0gsTUFBQUEsUUFBUSxDQUFDTSxJQUFULENBQWM7QUFDWkMsUUFBQUEsR0FBRyxFQUFFLDREQURPO0FBRVpDLFFBQUFBLEdBQUcsRUFBRUw7QUFGTyxPQUFkO0FBSUQ7O0FBQ0RGLElBQUFBLGVBQWUsQ0FBQ0ssSUFBaEIsQ0FBcUJILGNBQXJCO0FBRUEsV0FBT0gsUUFBUDtBQUNEOztBQUVEWSxFQUFBQSxhQUFhLENBQUVDLFVBQUYsRUFBYztBQUFDQyxJQUFBQSxPQUFEO0FBQVVYLElBQUFBO0FBQVYsR0FBZCxFQUF5QztBQUNwRCxXQUFRLEdBQUVVLFVBQVcsSUFBR0MsT0FBUSxxQkFBb0JYLGNBQWUsSUFBbkU7QUFDRDs7QUF4Q3VEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCBFeHRlbnNpb25Db25maWcsIHsgRFJJVkVSX1RZUEUgfSBmcm9tICcuL2V4dGVuc2lvbi1jb25maWcnO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBEcml2ZXJDb25maWcgZXh0ZW5kcyBFeHRlbnNpb25Db25maWcge1xuICBjb25zdHJ1Y3RvciAoYXBwaXVtSG9tZSwgbG9nRm4gPSBudWxsKSB7XG4gICAgc3VwZXIoYXBwaXVtSG9tZSwgRFJJVkVSX1RZUEUsIGxvZ0ZuKTtcbiAgfVxuXG4gIGdldENvbmZpZ1Byb2JsZW1zIChkcml2ZXIpIHtcbiAgICBjb25zdCBwcm9ibGVtcyA9IFtdO1xuICAgIGNvbnN0IGF1dG9tYXRpb25OYW1lcyA9IFtdO1xuICAgIGNvbnN0IHtwbGF0Zm9ybU5hbWVzLCBhdXRvbWF0aW9uTmFtZX0gPSBkcml2ZXI7XG5cbiAgICBpZiAoIV8uaXNBcnJheShwbGF0Zm9ybU5hbWVzKSkge1xuICAgICAgcHJvYmxlbXMucHVzaCh7XG4gICAgICAgIGVycjogJ01pc3Npbmcgb3IgaW5jb3JyZWN0IHN1cHBvcnRlZCBwbGF0Zm9ybU5hbWUgbGlzdC4nLFxuICAgICAgICB2YWw6IHBsYXRmb3JtTmFtZXNcbiAgICAgIH0pO1xuICAgIH0gZWxzZSB7XG4gICAgICBmb3IgKGNvbnN0IHBOYW1lIG9mIHBsYXRmb3JtTmFtZXMpIHtcbiAgICAgICAgaWYgKCFfLmlzU3RyaW5nKHBOYW1lKSkge1xuICAgICAgICAgIHByb2JsZW1zLnB1c2goe2VycjogJ0luY29ycmVjdGx5IGZvcm1hdHRlZCBwbGF0Zm9ybU5hbWUuJywgdmFsOiBwTmFtZX0pO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKCFfLmlzU3RyaW5nKGF1dG9tYXRpb25OYW1lKSkge1xuICAgICAgcHJvYmxlbXMucHVzaCh7ZXJyOiAnTWlzc2luZyBvciBpbmNvcnJlY3QgYXV0b21hdGlvbk5hbWUnLCB2YWw6IGF1dG9tYXRpb25OYW1lfSk7XG4gICAgfVxuXG4gICAgaWYgKF8uaW5jbHVkZXMoYXV0b21hdGlvbk5hbWVzLCBhdXRvbWF0aW9uTmFtZSkpIHtcbiAgICAgIHByb2JsZW1zLnB1c2goe1xuICAgICAgICBlcnI6ICdNdWx0aXBsZSBkcml2ZXJzIGNsYWltIHN1cHBvcnQgZm9yIHRoZSBzYW1lIGF1dG9tYXRpb25OYW1lJyxcbiAgICAgICAgdmFsOiBhdXRvbWF0aW9uTmFtZVxuICAgICAgfSk7XG4gICAgfVxuICAgIGF1dG9tYXRpb25OYW1lcy5wdXNoKGF1dG9tYXRpb25OYW1lKTtcblxuICAgIHJldHVybiBwcm9ibGVtcztcbiAgfVxuXG4gIGV4dGVuc2lvbkRlc2MgKGRyaXZlck5hbWUsIHt2ZXJzaW9uLCBhdXRvbWF0aW9uTmFtZX0pIHtcbiAgICByZXR1cm4gYCR7ZHJpdmVyTmFtZX1AJHt2ZXJzaW9ufSAoYXV0b21hdGlvbk5hbWUgJyR7YXV0b21hdGlvbk5hbWV9JylgO1xuICB9XG59XG5cbiJdLCJmaWxlIjoibGliL2RyaXZlci1jb25maWcuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
100
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kcml2ZXItY29uZmlnLmpzIl0sIm5hbWVzIjpbIkRyaXZlckNvbmZpZyIsIkV4dGVuc2lvbkNvbmZpZyIsImNvbnN0cnVjdG9yIiwiYXBwaXVtSG9tZSIsImxvZ0ZuIiwiRFJJVkVSX1RZUEUiLCJrbm93bkF1dG9tYXRpb25OYW1lcyIsIlNldCIsInJlYWQiLCJjbGVhciIsImdldEluc3RhbmNlIiwiaW5zdGFuY2UiLCJfaW5zdGFuY2VzIiwiZ2V0Q29uZmlnUHJvYmxlbXMiLCJleHREYXRhIiwiZXh0TmFtZSIsInByb2JsZW1zIiwicGxhdGZvcm1OYW1lcyIsImF1dG9tYXRpb25OYW1lIiwiXyIsImlzQXJyYXkiLCJwdXNoIiwiZXJyIiwidmFsIiwiaXNFbXB0eSIsInBOYW1lIiwiaXNTdHJpbmciLCJoYXMiLCJhZGQiLCJleHRlbnNpb25EZXNjIiwiZHJpdmVyTmFtZSIsInZlcnNpb24iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7QUFFQTs7QUFDQTs7QUFDQTs7QUFFZSxNQUFNQSxZQUFOLFNBQTJCQyx3QkFBM0IsQ0FBMkM7QUFleERDLEVBQUFBLFdBQVcsQ0FBRUMsVUFBRixFQUFjQyxLQUFkLEVBQXFCO0FBQzlCLFVBQU1ELFVBQU4sRUFBa0JFLHdCQUFsQixFQUErQkQsS0FBL0I7QUFFQSxTQUFLRSxvQkFBTCxHQUE0QixJQUFJQyxHQUFKLEVBQTVCO0FBQ0Q7O0FBRVMsUUFBSkMsSUFBSSxHQUFJO0FBQ1osU0FBS0Ysb0JBQUwsQ0FBMEJHLEtBQTFCO0FBQ0EsV0FBTyxNQUFNLE1BQU1ELElBQU4sRUFBYjtBQUNEOztBQVFpQixTQUFYRSxXQUFXLENBQUVQLFVBQUYsRUFBY0MsS0FBZCxFQUFxQjtBQUFBOztBQUNyQyxVQUFNTyxRQUFRLDRCQUFHWCxZQUFZLENBQUNZLFVBQWIsQ0FBd0JULFVBQXhCLENBQUgseUVBQTBDLElBQUlILFlBQUosQ0FBaUJHLFVBQWpCLEVBQTZCQyxLQUE3QixDQUF4RDtBQUNBSixJQUFBQSxZQUFZLENBQUNZLFVBQWIsQ0FBd0JULFVBQXhCLElBQXNDUSxRQUF0QztBQUNBLFdBQU9BLFFBQVA7QUFDRDs7QUFTREUsRUFBQUEsaUJBQWlCLENBQUVDLE9BQUYsRUFBV0MsT0FBWCxFQUFvQjtBQUNuQyxVQUFNQyxRQUFRLEdBQUcsRUFBakI7QUFDQSxVQUFNO0FBQUNDLE1BQUFBLGFBQUQ7QUFBZ0JDLE1BQUFBO0FBQWhCLFFBQWtDSixPQUF4Qzs7QUFFQSxRQUFJLENBQUNLLGdCQUFFQyxPQUFGLENBQVVILGFBQVYsQ0FBTCxFQUErQjtBQUM3QkQsTUFBQUEsUUFBUSxDQUFDSyxJQUFULENBQWM7QUFDWkMsUUFBQUEsR0FBRyxFQUFFLG9EQURPO0FBRVpDLFFBQUFBLEdBQUcsRUFBRU47QUFGTyxPQUFkO0FBSUQsS0FMRCxNQUtPO0FBQ0wsVUFBSUUsZ0JBQUVLLE9BQUYsQ0FBVVAsYUFBVixDQUFKLEVBQThCO0FBQzVCRCxRQUFBQSxRQUFRLENBQUNLLElBQVQsQ0FBYztBQUNaQyxVQUFBQSxHQUFHLEVBQUUsMkJBRE87QUFFWkMsVUFBQUEsR0FBRyxFQUFFTjtBQUZPLFNBQWQ7QUFJRCxPQUxELE1BS087QUFDTCxhQUFLLE1BQU1RLEtBQVgsSUFBb0JSLGFBQXBCLEVBQW1DO0FBQ2pDLGNBQUksQ0FBQ0UsZ0JBQUVPLFFBQUYsQ0FBV0QsS0FBWCxDQUFMLEVBQXdCO0FBQ3RCVCxZQUFBQSxRQUFRLENBQUNLLElBQVQsQ0FBYztBQUFDQyxjQUFBQSxHQUFHLEVBQUUscUNBQU47QUFBNkNDLGNBQUFBLEdBQUcsRUFBRUU7QUFBbEQsYUFBZDtBQUNEO0FBQ0Y7QUFDRjtBQUNGOztBQUVELFFBQUksQ0FBQ04sZ0JBQUVPLFFBQUYsQ0FBV1IsY0FBWCxDQUFMLEVBQWlDO0FBQy9CRixNQUFBQSxRQUFRLENBQUNLLElBQVQsQ0FBYztBQUFDQyxRQUFBQSxHQUFHLEVBQUUscUNBQU47QUFBNkNDLFFBQUFBLEdBQUcsRUFBRUw7QUFBbEQsT0FBZDtBQUNEOztBQUVELFFBQUksS0FBS1osb0JBQUwsQ0FBMEJxQixHQUExQixDQUE4QlQsY0FBOUIsQ0FBSixFQUFtRDtBQUNqREYsTUFBQUEsUUFBUSxDQUFDSyxJQUFULENBQWM7QUFDWkMsUUFBQUEsR0FBRyxFQUFFLDREQURPO0FBRVpDLFFBQUFBLEdBQUcsRUFBRUw7QUFGTyxPQUFkO0FBSUQ7O0FBR0QsU0FBS1osb0JBQUwsQ0FBMEJzQixHQUExQixDQUE4QlYsY0FBOUI7QUFFQSxXQUFPRixRQUFQO0FBQ0Q7O0FBTURhLEVBQUFBLGFBQWEsQ0FBRUMsVUFBRixFQUFjO0FBQUNDLElBQUFBLE9BQUQ7QUFBVWIsSUFBQUE7QUFBVixHQUFkLEVBQXlDO0FBQ3BELFdBQVEsR0FBRVksVUFBVyxJQUFHQyxPQUFRLHFCQUFvQmIsY0FBZSxJQUFuRTtBQUNEOztBQTVGdUQ7Ozs4QkFBckNsQixZLGdCQU9DLEUiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAdHMtY2hlY2tcblxuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCBFeHRlbnNpb25Db25maWcgZnJvbSAnLi9leHRlbnNpb24tY29uZmlnJztcbmltcG9ydCB7IERSSVZFUl9UWVBFIH0gZnJvbSAnLi9leHQtY29uZmlnLWlvJztcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgRHJpdmVyQ29uZmlnIGV4dGVuZHMgRXh0ZW5zaW9uQ29uZmlnIHtcbiAgLyoqXG4gICAqIEEgbWFwcGluZyBvZiBgQVBQSVVNX0hPTUVgIHZhbHVlcyB0byB7QGxpbmsgRHJpdmVyQ29uZmlnfSBpbnN0YW5jZXMuXG4gICAqIEVhY2ggYEFQUElVTV9IT01FYCBzaG91bGQgb25seSBoYXZlIG9uZSBhc3NvY2lhdGVkIGBEcml2ZXJDb25maWdgIGluc3RhbmNlLlxuICAgKiBAdHlwZSB7UmVjb3JkPHN0cmluZyxEcml2ZXJDb25maWc+fVxuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgc3RhdGljIF9pbnN0YW5jZXMgPSB7fTtcblxuICAvKipcbiAgICogQ2FsbCB7QGxpbmsgRHJpdmVyQ29uZmlnLmdldEluc3RhbmNlfSBpbnN0ZWFkLlxuICAgKiBAcHJpdmF0ZVxuICAgKiBAcGFyYW0ge3N0cmluZ30gYXBwaXVtSG9tZVxuICAgKiBAcGFyYW0geyguLi5hcmdzOiBhbnlbXSkgPT4gdm9pZH0gW2xvZ0ZuXVxuICAgKi9cbiAgY29uc3RydWN0b3IgKGFwcGl1bUhvbWUsIGxvZ0ZuKSB7XG4gICAgc3VwZXIoYXBwaXVtSG9tZSwgRFJJVkVSX1RZUEUsIGxvZ0ZuKTtcbiAgICAvKiogQHR5cGUge1NldDxzdHJpbmc+fSAqL1xuICAgIHRoaXMua25vd25BdXRvbWF0aW9uTmFtZXMgPSBuZXcgU2V0KCk7XG4gIH1cblxuICBhc3luYyByZWFkICgpIHtcbiAgICB0aGlzLmtub3duQXV0b21hdGlvbk5hbWVzLmNsZWFyKCk7XG4gICAgcmV0dXJuIGF3YWl0IHN1cGVyLnJlYWQoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIG9yIGdldHMgYW4gaW5zdGFuY2Ugb2Yge0BsaW5rIERyaXZlckNvbmZpZ30gYmFzZWQgdmFsdWUgb2YgYGFwcGl1bUhvbWVgXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBhcHBpdW1Ib21lIC0gYEFQUElVTV9IT01FYCBwYXRoXG4gICAqIEBwYXJhbSB7KC4uLmFyZ3M6IGFueVtdKSA9PiB2b2lkfSBbbG9nRm5dIC0gT3B0aW9uYWwgbG9nZ2luZyBmdW5jdGlvblxuICAgKiBAcmV0dXJucyB7RHJpdmVyQ29uZmlnfVxuICAgKi9cbiAgc3RhdGljIGdldEluc3RhbmNlIChhcHBpdW1Ib21lLCBsb2dGbikge1xuICAgIGNvbnN0IGluc3RhbmNlID0gRHJpdmVyQ29uZmlnLl9pbnN0YW5jZXNbYXBwaXVtSG9tZV0gPz8gbmV3IERyaXZlckNvbmZpZyhhcHBpdW1Ib21lLCBsb2dGbik7XG4gICAgRHJpdmVyQ29uZmlnLl9pbnN0YW5jZXNbYXBwaXVtSG9tZV0gPSBpbnN0YW5jZTtcbiAgICByZXR1cm4gaW5zdGFuY2U7XG4gIH1cblxuICAvKipcbiAgICpcbiAgICogQHBhcmFtIHtvYmplY3R9IGV4dERhdGFcbiAgICogQHBhcmFtIHtzdHJpbmd9IGV4dE5hbWVcbiAgICogQHJldHVybnMge2ltcG9ydCgnLi9leHRlbnNpb24tY29uZmlnJykuUHJvYmxlbVtdfVxuICAgKi9cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXVudXNlZC12YXJzXG4gIGdldENvbmZpZ1Byb2JsZW1zIChleHREYXRhLCBleHROYW1lKSB7XG4gICAgY29uc3QgcHJvYmxlbXMgPSBbXTtcbiAgICBjb25zdCB7cGxhdGZvcm1OYW1lcywgYXV0b21hdGlvbk5hbWV9ID0gZXh0RGF0YTtcblxuICAgIGlmICghXy5pc0FycmF5KHBsYXRmb3JtTmFtZXMpKSB7XG4gICAgICBwcm9ibGVtcy5wdXNoKHtcbiAgICAgICAgZXJyOiAnTWlzc2luZyBvciBpbmNvcnJlY3Qgc3VwcG9ydGVkIHBsYXRmb3JtTmFtZXMgbGlzdC4nLFxuICAgICAgICB2YWw6IHBsYXRmb3JtTmFtZXNcbiAgICAgIH0pO1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoXy5pc0VtcHR5KHBsYXRmb3JtTmFtZXMpKSB7XG4gICAgICAgIHByb2JsZW1zLnB1c2goe1xuICAgICAgICAgIGVycjogJ0VtcHR5IHBsYXRmb3JtTmFtZXMgbGlzdC4nLFxuICAgICAgICAgIHZhbDogcGxhdGZvcm1OYW1lc1xuICAgICAgICB9KTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGZvciAoY29uc3QgcE5hbWUgb2YgcGxhdGZvcm1OYW1lcykge1xuICAgICAgICAgIGlmICghXy5pc1N0cmluZyhwTmFtZSkpIHtcbiAgICAgICAgICAgIHByb2JsZW1zLnB1c2goe2VycjogJ0luY29ycmVjdGx5IGZvcm1hdHRlZCBwbGF0Zm9ybU5hbWUuJywgdmFsOiBwTmFtZX0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICghXy5pc1N0cmluZyhhdXRvbWF0aW9uTmFtZSkpIHtcbiAgICAgIHByb2JsZW1zLnB1c2goe2VycjogJ01pc3Npbmcgb3IgaW5jb3JyZWN0IGF1dG9tYXRpb25OYW1lJywgdmFsOiBhdXRvbWF0aW9uTmFtZX0pO1xuICAgIH1cblxuICAgIGlmICh0aGlzLmtub3duQXV0b21hdGlvbk5hbWVzLmhhcyhhdXRvbWF0aW9uTmFtZSkpIHtcbiAgICAgIHByb2JsZW1zLnB1c2goe1xuICAgICAgICBlcnI6ICdNdWx0aXBsZSBkcml2ZXJzIGNsYWltIHN1cHBvcnQgZm9yIHRoZSBzYW1lIGF1dG9tYXRpb25OYW1lJyxcbiAgICAgICAgdmFsOiBhdXRvbWF0aW9uTmFtZVxuICAgICAgfSk7XG4gICAgfVxuXG4gICAgLy8gc2hvdWxkIHdlIHJldGFpbiB0aGUgbmFtZSBhdCB0aGUgZW5kIG9mIHRoaXMgZnVuY3Rpb24sIG9uY2Ugd2UndmUgY2hlY2tlZCB0aGVyZSBhcmUgbm8gcHJvYmxlbXM/XG4gICAgdGhpcy5rbm93bkF1dG9tYXRpb25OYW1lcy5hZGQoYXV0b21hdGlvbk5hbWUpO1xuXG4gICAgcmV0dXJuIHByb2JsZW1zO1xuICB9XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBkcml2ZXJOYW1lXG4gICAqIEBwYXJhbSB7b2JqZWN0fSBleHREYXRhXG4gICAqL1xuICBleHRlbnNpb25EZXNjIChkcml2ZXJOYW1lLCB7dmVyc2lvbiwgYXV0b21hdGlvbk5hbWV9KSB7XG4gICAgcmV0dXJuIGAke2RyaXZlck5hbWV9QCR7dmVyc2lvbn0gKGF1dG9tYXRpb25OYW1lICcke2F1dG9tYXRpb25OYW1lfScpYDtcbiAgfVxufVxuXG4iXSwiZmlsZSI6ImxpYi9kcml2ZXItY29uZmlnLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
@@ -5,8 +5,8 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.findMatchingDriver = findMatchingDriver;
9
8
  exports.KNOWN_DRIVERS = void 0;
9
+ exports.findMatchingDriver = findMatchingDriver;
10
10
 
11
11
  require("source-map-support/register");
12
12
 
@@ -20,9 +20,12 @@ const KNOWN_DRIVERS = {
20
20
  youiengine: 'appium-youiengine-driver',
21
21
  windows: 'appium-windows-driver',
22
22
  mac: 'appium-mac-driver',
23
+ mac2: 'appium-mac2-driver',
23
24
  espresso: 'appium-espresso-driver',
24
25
  tizen: 'appium-tizen-driver',
25
- flutter: 'appium-flutter-driver'
26
+ flutter: 'appium-flutter-driver',
27
+ safari: 'appium-safari-driver',
28
+ gecko: 'appium-geckodriver'
26
29
  };
27
30
  exports.KNOWN_DRIVERS = KNOWN_DRIVERS;
28
31
 
@@ -84,7 +87,8 @@ function findMatchingDriver(config, {
84
87
 
85
88
  return {
86
89
  driver,
87
- version
90
+ version,
91
+ driverName
88
92
  };
89
93
  } catch (err) {
90
94
  const msg = `Could not find a driver for automationName ` + `'${automationName}' and platformName ${platformName}'. ` + `Have you installed a driver that supports those ` + `capabilities? Run 'appium driver list --installed' to see. ` + `(Lower-level error: ${err.message})`;
@@ -93,4 +97,4 @@ function findMatchingDriver(config, {
93
97
  }require('source-map-support').install();
94
98
 
95
99
 
96
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kcml2ZXJzLmpzIl0sIm5hbWVzIjpbIktOT1dOX0RSSVZFUlMiLCJ1aWF1dG9tYXRvcjIiLCJ4Y3VpdGVzdCIsInlvdWllbmdpbmUiLCJ3aW5kb3dzIiwibWFjIiwiZXNwcmVzc28iLCJ0aXplbiIsImZsdXR0ZXIiLCJnZXREcml2ZXJCeVN1cHBvcnQiLCJkcml2ZXJzIiwibWF0Y2hBdXRvbWF0aW9uTmFtZSIsIm1hdGNoUGxhdGZvcm1OYW1lIiwiZHJpdmVyTmFtZSIsImRyaXZlckRhdGEiLCJfIiwidG9QYWlycyIsImF1dG9tYXRpb25OYW1lIiwicGxhdGZvcm1OYW1lcyIsImFOYW1lTWF0Y2hlcyIsInRvTG93ZXJDYXNlIiwicE5hbWVNYXRjaGVzIiwiaW5jbHVkZXMiLCJtYXAiLCJ0b0xvd2VyIiwiRXJyb3IiLCJKU09OIiwic3RyaW5naWZ5IiwiZmluZE1hdGNoaW5nRHJpdmVyIiwiY29uZmlnIiwicGxhdGZvcm1OYW1lIiwiaXNTdHJpbmciLCJsb2ciLCJpbmZvIiwibWFpbkNsYXNzIiwidmVyc2lvbiIsImluc3RhbGxlZEV4dGVuc2lvbnMiLCJnZXRFeHRlbnNpb25SZXF1aXJlUGF0aCIsImRyaXZlciIsInJlcXVpcmUiLCJlcnIiLCJtc2ciLCJtZXNzYWdlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFPQSxNQUFNQSxhQUFhLEdBQUc7QUFDcEJDLEVBQUFBLFlBQVksRUFBRSw0QkFETTtBQUVwQkMsRUFBQUEsUUFBUSxFQUFFLHdCQUZVO0FBR3BCQyxFQUFBQSxVQUFVLEVBQUUsMEJBSFE7QUFJcEJDLEVBQUFBLE9BQU8sRUFBRSx1QkFKVztBQUtwQkMsRUFBQUEsR0FBRyxFQUFFLG1CQUxlO0FBTXBCQyxFQUFBQSxRQUFRLEVBQUUsd0JBTlU7QUFPcEJDLEVBQUFBLEtBQUssRUFBRSxxQkFQYTtBQVFwQkMsRUFBQUEsT0FBTyxFQUFFO0FBUlcsQ0FBdEI7OztBQVdBLFNBQVNDLGtCQUFULENBQTZCQyxPQUE3QixFQUFzQ0MsbUJBQXRDLEVBQTJEQyxpQkFBM0QsRUFBOEU7QUFDNUUsT0FBSyxNQUFNLENBQUNDLFVBQUQsRUFBYUMsVUFBYixDQUFYLElBQXVDQyxnQkFBRUMsT0FBRixDQUFVTixPQUFWLENBQXZDLEVBQTJEO0FBQ3pELFVBQU07QUFBQ08sTUFBQUEsY0FBRDtBQUFpQkMsTUFBQUE7QUFBakIsUUFBa0NKLFVBQXhDO0FBQ0EsVUFBTUssWUFBWSxHQUFHRixjQUFjLENBQUNHLFdBQWYsT0FBaUNULG1CQUFtQixDQUFDUyxXQUFwQixFQUF0RDs7QUFDQSxVQUFNQyxZQUFZLEdBQUdOLGdCQUFFTyxRQUFGLENBQVdKLGFBQWEsQ0FBQ0ssR0FBZCxDQUFrQlIsZ0JBQUVTLE9BQXBCLENBQVgsRUFDV1osaUJBQWlCLENBQUNRLFdBQWxCLEVBRFgsQ0FBckI7O0FBR0EsUUFBSUQsWUFBWSxJQUFJRSxZQUFwQixFQUFrQztBQUNoQyxhQUFPO0FBQUNSLFFBQUFBLFVBQUQ7QUFBYSxXQUFHQztBQUFoQixPQUFQO0FBQ0Q7O0FBRUQsUUFBSUssWUFBSixFQUFrQjtBQUNoQixZQUFNLElBQUlNLEtBQUosQ0FBVyxXQUFVWixVQUFXLDRCQUF0QixHQUNDLElBQUdJLGNBQWUsK0JBRG5CLEdBRUMsNkJBQTRCTCxpQkFBa0IsZUFGL0MsR0FHQyxxQkFIRCxHQUlBYyxJQUFJLENBQUNDLFNBQUwsQ0FBZVQsYUFBZixDQUpWLENBQU47QUFLRDtBQUNGOztBQUVELFFBQU0sSUFBSU8sS0FBSixDQUFXLHVEQUFYLENBQU47QUFDRDs7QUFFRCxTQUFTRyxrQkFBVCxDQUE2QkMsTUFBN0IsRUFBcUM7QUFBQ1osRUFBQUEsY0FBRDtBQUFpQmEsRUFBQUE7QUFBakIsQ0FBckMsRUFBcUU7QUFDbkUsTUFBSSxDQUFDZixnQkFBRWdCLFFBQUYsQ0FBV0QsWUFBWCxDQUFMLEVBQStCO0FBQzdCLFVBQU0sSUFBSUwsS0FBSixDQUFVLDRDQUFWLENBQU47QUFDRDs7QUFFRCxNQUFJLENBQUNWLGdCQUFFZ0IsUUFBRixDQUFXZCxjQUFYLENBQUwsRUFBaUM7QUFDL0IsVUFBTSxJQUFJUSxLQUFKLENBQVUsK0NBQVYsQ0FBTjtBQUNEOztBQUVETyxrQkFBSUMsSUFBSixDQUFVLHdEQUFELEdBQ0MsSUFBR2hCLGNBQWUsdUJBQXNCYSxZQUFhLEdBRC9EOztBQUdBLE1BQUk7QUFDRixVQUFNO0FBQ0pqQixNQUFBQSxVQURJO0FBRUpxQixNQUFBQSxTQUZJO0FBR0pDLE1BQUFBO0FBSEksUUFJRjFCLGtCQUFrQixDQUFDb0IsTUFBTSxDQUFDTyxtQkFBUixFQUE2Qm5CLGNBQTdCLEVBQTZDYSxZQUE3QyxDQUp0Qjs7QUFLQUUsb0JBQUlDLElBQUosQ0FBVSxRQUFPcEIsVUFBVywwQ0FBNUI7O0FBQ0FtQixvQkFBSUMsSUFBSixDQUFVLHNCQUFxQkosTUFBTSxDQUFDUSx1QkFBUCxDQUErQnhCLFVBQS9CLENBQTJDLEVBQTFFOztBQUNBLFVBQU15QixNQUFNLEdBQUdULE1BQU0sQ0FBQ1UsT0FBUCxDQUFlMUIsVUFBZixDQUFmOztBQUNBLFFBQUksQ0FBQ3lCLE1BQUwsRUFBYTtBQUNYLFlBQU0sSUFBSWIsS0FBSixDQUFXLGFBQVlTLFNBQVUsb0NBQWpDLENBQU47QUFDRDs7QUFDRCxXQUFPO0FBQUNJLE1BQUFBLE1BQUQ7QUFBU0gsTUFBQUE7QUFBVCxLQUFQO0FBQ0QsR0FiRCxDQWFFLE9BQU9LLEdBQVAsRUFBWTtBQUNaLFVBQU1DLEdBQUcsR0FBSSw2Q0FBRCxHQUNDLElBQUd4QixjQUFlLHNCQUFxQmEsWUFBYSxLQURyRCxHQUVDLGtEQUZELEdBR0MsNkRBSEQsR0FJQyx1QkFBc0JVLEdBQUcsQ0FBQ0UsT0FBUSxHQUovQztBQUtBLFVBQU0sSUFBSWpCLEtBQUosQ0FBVWdCLEdBQVYsQ0FBTjtBQUNEO0FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IGxvZyBmcm9tICcuL2xvZ2dlcic7XG5cblxuLy8gVGhpcyBpcyBhIG1hcCBvZiBkcml2ZXIgbmFtZXMgdG8gbnBtIHBhY2thZ2VzIHJlcHJlc2VudGluZyB0aG9zZSBkcml2ZXJzLlxuLy8gVGhlIGRyaXZlcnMgaW4gdGhpcyBsaXN0IHdpbGwgYmUgYXZhaWxhYmxlIHRvIHRoZSBDTEkgc28gdXNlcnMgY2FuIGp1c3Rcbi8vIHR5cGUgJ2FwcGl1bSBkcml2ZXIgaW5zdGFsbCAnbmFtZScnLCByYXRoZXIgdGhhbiBoYXZpbmcgdG8gc3BlY2lmeSB0aGUgZnVsbFxuLy8gbnBtIHBhY2thZ2UuIEkuZS4sIHRoZXNlIGFyZSB0aGUgb2ZmaWNpYWxseSByZWNvZ25pemVkIGRyaXZlcnMuXG5jb25zdCBLTk9XTl9EUklWRVJTID0ge1xuICB1aWF1dG9tYXRvcjI6ICdhcHBpdW0tdWlhdXRvbWF0b3IyLWRyaXZlcicsXG4gIHhjdWl0ZXN0OiAnYXBwaXVtLXhjdWl0ZXN0LWRyaXZlcicsXG4gIHlvdWllbmdpbmU6ICdhcHBpdW0teW91aWVuZ2luZS1kcml2ZXInLFxuICB3aW5kb3dzOiAnYXBwaXVtLXdpbmRvd3MtZHJpdmVyJyxcbiAgbWFjOiAnYXBwaXVtLW1hYy1kcml2ZXInLFxuICBlc3ByZXNzbzogJ2FwcGl1bS1lc3ByZXNzby1kcml2ZXInLFxuICB0aXplbjogJ2FwcGl1bS10aXplbi1kcml2ZXInLFxuICBmbHV0dGVyOiAnYXBwaXVtLWZsdXR0ZXItZHJpdmVyJyxcbn07XG5cbmZ1bmN0aW9uIGdldERyaXZlckJ5U3VwcG9ydCAoZHJpdmVycywgbWF0Y2hBdXRvbWF0aW9uTmFtZSwgbWF0Y2hQbGF0Zm9ybU5hbWUpIHtcbiAgZm9yIChjb25zdCBbZHJpdmVyTmFtZSwgZHJpdmVyRGF0YV0gb2YgXy50b1BhaXJzKGRyaXZlcnMpKSB7XG4gICAgY29uc3Qge2F1dG9tYXRpb25OYW1lLCBwbGF0Zm9ybU5hbWVzfSA9IGRyaXZlckRhdGE7XG4gICAgY29uc3QgYU5hbWVNYXRjaGVzID0gYXV0b21hdGlvbk5hbWUudG9Mb3dlckNhc2UoKSA9PT0gbWF0Y2hBdXRvbWF0aW9uTmFtZS50b0xvd2VyQ2FzZSgpO1xuICAgIGNvbnN0IHBOYW1lTWF0Y2hlcyA9IF8uaW5jbHVkZXMocGxhdGZvcm1OYW1lcy5tYXAoXy50b0xvd2VyKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1hdGNoUGxhdGZvcm1OYW1lLnRvTG93ZXJDYXNlKCkpO1xuXG4gICAgaWYgKGFOYW1lTWF0Y2hlcyAmJiBwTmFtZU1hdGNoZXMpIHtcbiAgICAgIHJldHVybiB7ZHJpdmVyTmFtZSwgLi4uZHJpdmVyRGF0YX07XG4gICAgfVxuXG4gICAgaWYgKGFOYW1lTWF0Y2hlcykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBEcml2ZXIgJyR7ZHJpdmVyTmFtZX0nIHN1cHBvcnRzIGF1dG9tYXRpb25OYW1lIGAgK1xuICAgICAgICAgICAgICAgICAgICAgIGAnJHthdXRvbWF0aW9uTmFtZX0nLCBidXQgQXBwaXVtIGNvdWxkIG5vdCBmaW5kIGAgK1xuICAgICAgICAgICAgICAgICAgICAgIGBzdXBwb3J0IGZvciBwbGF0Zm9ybU5hbWUgJyR7bWF0Y2hQbGF0Zm9ybU5hbWV9Jy4gU3VwcG9ydGVkIGAgK1xuICAgICAgICAgICAgICAgICAgICAgIGBwbGF0Zm9ybU5hbWVzIGFyZTogYCArXG4gICAgICAgICAgICAgICAgICAgICAgSlNPTi5zdHJpbmdpZnkocGxhdGZvcm1OYW1lcykpO1xuICAgIH1cbiAgfVxuXG4gIHRocm93IG5ldyBFcnJvcihgQ291bGQgbm90IGZpbmQgaW5zdGFsbGVkIGRyaXZlciB0byBzdXBwb3J0IGdpdmVuIGNhcHNgKTtcbn1cblxuZnVuY3Rpb24gZmluZE1hdGNoaW5nRHJpdmVyIChjb25maWcsIHthdXRvbWF0aW9uTmFtZSwgcGxhdGZvcm1OYW1lfSkge1xuICBpZiAoIV8uaXNTdHJpbmcocGxhdGZvcm1OYW1lKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignWW91IG11c3QgaW5jbHVkZSBhIHBsYXRmb3JtTmFtZSBjYXBhYmlsaXR5Jyk7XG4gIH1cblxuICBpZiAoIV8uaXNTdHJpbmcoYXV0b21hdGlvbk5hbWUpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdZb3UgbXVzdCBpbmNsdWRlIGFuIGF1dG9tYXRpb25OYW1lIGNhcGFiaWxpdHknKTtcbiAgfVxuXG4gIGxvZy5pbmZvKGBBdHRlbXB0aW5nIHRvIGZpbmQgbWF0Y2hpbmcgZHJpdmVyIGZvciBhdXRvbWF0aW9uTmFtZSBgICtcbiAgICAgICAgICAgYCcke2F1dG9tYXRpb25OYW1lfScgYW5kIHBsYXRmb3JtTmFtZSAnJHtwbGF0Zm9ybU5hbWV9J2ApO1xuXG4gIHRyeSB7XG4gICAgY29uc3Qge1xuICAgICAgZHJpdmVyTmFtZSxcbiAgICAgIG1haW5DbGFzcyxcbiAgICAgIHZlcnNpb24sXG4gICAgfSA9IGdldERyaXZlckJ5U3VwcG9ydChjb25maWcuaW5zdGFsbGVkRXh0ZW5zaW9ucywgYXV0b21hdGlvbk5hbWUsIHBsYXRmb3JtTmFtZSk7XG4gICAgbG9nLmluZm8oYFRoZSAnJHtkcml2ZXJOYW1lfScgZHJpdmVyIHdhcyBpbnN0YWxsZWQgYW5kIG1hdGNoZWQgY2Fwcy5gKTtcbiAgICBsb2cuaW5mbyhgV2lsbCByZXF1aXJlIGl0IGF0ICR7Y29uZmlnLmdldEV4dGVuc2lvblJlcXVpcmVQYXRoKGRyaXZlck5hbWUpfWApO1xuICAgIGNvbnN0IGRyaXZlciA9IGNvbmZpZy5yZXF1aXJlKGRyaXZlck5hbWUpO1xuICAgIGlmICghZHJpdmVyKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYE1haW5DbGFzcyAke21haW5DbGFzc30gZGlkIG5vdCByZXN1bHQgaW4gYSBkcml2ZXIgb2JqZWN0YCk7XG4gICAgfVxuICAgIHJldHVybiB7ZHJpdmVyLCB2ZXJzaW9ufTtcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgY29uc3QgbXNnID0gYENvdWxkIG5vdCBmaW5kIGEgZHJpdmVyIGZvciBhdXRvbWF0aW9uTmFtZSBgICtcbiAgICAgICAgICAgICAgICBgJyR7YXV0b21hdGlvbk5hbWV9JyBhbmQgcGxhdGZvcm1OYW1lICR7cGxhdGZvcm1OYW1lfScuIGAgK1xuICAgICAgICAgICAgICAgIGBIYXZlIHlvdSBpbnN0YWxsZWQgYSBkcml2ZXIgdGhhdCBzdXBwb3J0cyB0aG9zZSBgICtcbiAgICAgICAgICAgICAgICBgY2FwYWJpbGl0aWVzPyBSdW4gJ2FwcGl1bSBkcml2ZXIgbGlzdCAtLWluc3RhbGxlZCcgdG8gc2VlLiBgICtcbiAgICAgICAgICAgICAgICBgKExvd2VyLWxldmVsIGVycm9yOiAke2Vyci5tZXNzYWdlfSlgO1xuICAgIHRocm93IG5ldyBFcnJvcihtc2cpO1xuICB9XG59XG5cbmV4cG9ydCB7XG4gIGZpbmRNYXRjaGluZ0RyaXZlcixcbiAgS05PV05fRFJJVkVSUyxcbn07XG4iXSwiZmlsZSI6ImxpYi9kcml2ZXJzLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
100
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kcml2ZXJzLmpzIl0sIm5hbWVzIjpbIktOT1dOX0RSSVZFUlMiLCJ1aWF1dG9tYXRvcjIiLCJ4Y3VpdGVzdCIsInlvdWllbmdpbmUiLCJ3aW5kb3dzIiwibWFjIiwibWFjMiIsImVzcHJlc3NvIiwidGl6ZW4iLCJmbHV0dGVyIiwic2FmYXJpIiwiZ2Vja28iLCJnZXREcml2ZXJCeVN1cHBvcnQiLCJkcml2ZXJzIiwibWF0Y2hBdXRvbWF0aW9uTmFtZSIsIm1hdGNoUGxhdGZvcm1OYW1lIiwiZHJpdmVyTmFtZSIsImRyaXZlckRhdGEiLCJfIiwidG9QYWlycyIsImF1dG9tYXRpb25OYW1lIiwicGxhdGZvcm1OYW1lcyIsImFOYW1lTWF0Y2hlcyIsInRvTG93ZXJDYXNlIiwicE5hbWVNYXRjaGVzIiwiaW5jbHVkZXMiLCJtYXAiLCJ0b0xvd2VyIiwiRXJyb3IiLCJKU09OIiwic3RyaW5naWZ5IiwiZmluZE1hdGNoaW5nRHJpdmVyIiwiY29uZmlnIiwicGxhdGZvcm1OYW1lIiwiaXNTdHJpbmciLCJsb2ciLCJpbmZvIiwibWFpbkNsYXNzIiwidmVyc2lvbiIsImluc3RhbGxlZEV4dGVuc2lvbnMiLCJnZXRFeHRlbnNpb25SZXF1aXJlUGF0aCIsImRyaXZlciIsInJlcXVpcmUiLCJlcnIiLCJtc2ciLCJtZXNzYWdlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFPQSxNQUFNQSxhQUFhLEdBQUc7QUFDcEJDLEVBQUFBLFlBQVksRUFBRSw0QkFETTtBQUVwQkMsRUFBQUEsUUFBUSxFQUFFLHdCQUZVO0FBR3BCQyxFQUFBQSxVQUFVLEVBQUUsMEJBSFE7QUFJcEJDLEVBQUFBLE9BQU8sRUFBRSx1QkFKVztBQUtwQkMsRUFBQUEsR0FBRyxFQUFFLG1CQUxlO0FBTXBCQyxFQUFBQSxJQUFJLEVBQUUsb0JBTmM7QUFPcEJDLEVBQUFBLFFBQVEsRUFBRSx3QkFQVTtBQVFwQkMsRUFBQUEsS0FBSyxFQUFFLHFCQVJhO0FBU3BCQyxFQUFB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QUNEO0FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IGxvZyBmcm9tICcuL2xvZ2dlcic7XG5cblxuLy8gVGhpcyBpcyBhIG1hcCBvZiBkcml2ZXIgbmFtZXMgdG8gbnBtIHBhY2thZ2VzIHJlcHJlc2VudGluZyB0aG9zZSBkcml2ZXJzLlxuLy8gVGhlIGRyaXZlcnMgaW4gdGhpcyBsaXN0IHdpbGwgYmUgYXZhaWxhYmxlIHRvIHRoZSBDTEkgc28gdXNlcnMgY2FuIGp1c3Rcbi8vIHR5cGUgJ2FwcGl1bSBkcml2ZXIgaW5zdGFsbCAnbmFtZScnLCByYXRoZXIgdGhhbiBoYXZpbmcgdG8gc3BlY2lmeSB0aGUgZnVsbFxuLy8gbnBtIHBhY2thZ2UuIEkuZS4sIHRoZXNlIGFyZSB0aGUgb2ZmaWNpYWxseSByZWNvZ25pemVkIGRyaXZlcnMuXG5jb25zdCBLTk9XTl9EUklWRVJTID0ge1xuICB1aWF1dG9tYXRvcjI6ICdhcHBpdW0tdWlhdXRvbWF0b3IyLWRyaXZlcicsXG4gIHhjdWl0ZXN0OiAnYXBwaXVtLXhjdWl0ZXN0LWRyaXZlcicsXG4gIHlvdWllbmdpbmU6ICdhcHBpdW0teW91aWVuZ2luZS1kcml2ZXInLFxuICB3aW5kb3dzOiAnYXBwaXVtLXdpbmRvd3MtZHJpdmVyJyxcbiAgbWFjOiAnYXBwaXVtLW1hYy1kcml2ZXInLFxuICBtYWMyOiAnYXBwaXVtLW1hYzItZHJpdmVyJyxcbiAgZXNwcmVzc286ICdhcHBpdW0tZXNwcmVzc28tZHJpdmVyJyxcbiAgdGl6ZW46ICdhcHBpdW0tdGl6ZW4tZHJpdmVyJyxcbiAgZmx1dHRlcjogJ2FwcGl1bS1mbHV0dGVyLWRyaXZlcicsXG4gIHNhZmFyaTogJ2FwcGl1bS1zYWZhcmktZHJpdmVyJyxcbiAgZ2Vja286ICdhcHBpdW0tZ2Vja29kcml2ZXInLFxufTtcblxuZnVuY3Rpb24gZ2V0RHJpdmVyQnlTdXBwb3J0IChkcml2ZXJzLCBtYXRjaEF1dG9tYXRpb25OYW1lLCBtYXRjaFBsYXRmb3JtTmFtZSkge1xuICBmb3IgKGNvbnN0IFtkcml2ZXJOYW1lLCBkcml2ZXJEYXRhXSBvZiBfLnRvUGFpcnMoZHJpdmVycykpIHtcbiAgICBjb25zdCB7YXV0b21hdGlvbk5hbWUsIHBsYXRmb3JtTmFtZXN9ID0gZHJpdmVyRGF0YTtcbiAgICBjb25zdCBhTmFtZU1hdGNoZXMgPSBhdXRvbWF0aW9uTmFtZS50b0xvd2VyQ2FzZSgpID09PSBtYXRjaEF1dG9tYXRpb25OYW1lLnRvTG93ZXJDYXNlKCk7XG4gICAgY29uc3QgcE5hbWVNYXRjaGVzID0gXy5pbmNsdWRlcyhwbGF0Zm9ybU5hbWVzLm1hcChfLnRvTG93ZXIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbWF0Y2hQbGF0Zm9ybU5hbWUudG9Mb3dlckNhc2UoKSk7XG5cbiAgICBpZiAoYU5hbWVNYXRjaGVzICYmIHBOYW1lTWF0Y2hlcykge1xuICAgICAgcmV0dXJuIHtkcml2ZXJOYW1lLCAuLi5kcml2ZXJEYXRhfTtcbiAgICB9XG5cbiAgICBpZiAoYU5hbWVNYXRjaGVzKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYERyaXZlciAnJHtkcml2ZXJOYW1lfScgc3VwcG9ydHMgYXV0b21hdGlvbk5hbWUgYCArXG4gICAgICAgICAgICAgICAgICAgICAgYCcke2F1dG9tYXRpb25OYW1lfScsIGJ1dCBBcHBpdW0gY291bGQgbm90IGZpbmQgYCArXG4gICAgICAgICAgICAgICAgICAgICAgYHN1cHBvcnQgZm9yIHBsYXRmb3JtTmFtZSAnJHttYXRjaFBsYXRmb3JtTmFtZX0nLiBTdXBwb3J0ZWQgYCArXG4gICAgICAgICAgICAgICAgICAgICAgYHBsYXRmb3JtTmFtZXMgYXJlOiBgICtcbiAgICAgICAgICAgICAgICAgICAgICBKU09OLnN0cmluZ2lmeShwbGF0Zm9ybU5hbWVzKSk7XG4gICAgfVxuICB9XG5cbiAgdGhyb3cgbmV3IEVycm9yKGBDb3VsZCBub3QgZmluZCBpbnN0YWxsZWQgZHJpdmVyIHRvIHN1cHBvcnQgZ2l2ZW4gY2Fwc2ApO1xufVxuXG5mdW5jdGlvbiBmaW5kTWF0Y2hpbmdEcml2ZXIgKGNvbmZpZywge2F1dG9tYXRpb25OYW1lLCBwbGF0Zm9ybU5hbWV9KSB7XG4gIGlmICghXy5pc1N0cmluZyhwbGF0Zm9ybU5hbWUpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdZb3UgbXVzdCBpbmNsdWRlIGEgcGxhdGZvcm1OYW1lIGNhcGFiaWxpdHknKTtcbiAgfVxuXG4gIGlmICghXy5pc1N0cmluZyhhdXRvbWF0aW9uTmFtZSkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1lvdSBtdXN0IGluY2x1ZGUgYW4gYXV0b21hdGlvbk5hbWUgY2FwYWJpbGl0eScpO1xuICB9XG5cbiAgbG9nLmluZm8oYEF0dGVtcHRpbmcgdG8gZmluZCBtYXRjaGluZyBkcml2ZXIgZm9yIGF1dG9tYXRpb25OYW1lIGAgK1xuICAgICAgICAgICBgJyR7YXV0b21hdGlvbk5hbWV9JyBhbmQgcGxhdGZvcm1OYW1lICcke3BsYXRmb3JtTmFtZX0nYCk7XG5cbiAgdHJ5IHtcbiAgICBjb25zdCB7XG4gICAgICBkcml2ZXJOYW1lLFxuICAgICAgbWFpbkNsYXNzLFxuICAgICAgdmVyc2lvbixcbiAgICB9ID0gZ2V0RHJpdmVyQnlTdXBwb3J0KGNvbmZpZy5pbnN0YWxsZWRFeHRlbnNpb25zLCBhdXRvbWF0aW9uTmFtZSwgcGxhdGZvcm1OYW1lKTtcbiAgICBsb2cuaW5mbyhgVGhlICcke2RyaXZlck5hbWV9JyBkcml2ZXIgd2FzIGluc3RhbGxlZCBhbmQgbWF0Y2hlZCBjYXBzLmApO1xuICAgIGxvZy5pbmZvKGBXaWxsIHJlcXVpcmUgaXQgYXQgJHtjb25maWcuZ2V0RXh0ZW5zaW9uUmVxdWlyZVBhdGgoZHJpdmVyTmFtZSl9YCk7XG4gICAgY29uc3QgZHJpdmVyID0gY29uZmlnLnJlcXVpcmUoZHJpdmVyTmFtZSk7XG4gICAgaWYgKCFkcml2ZXIpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgTWFpbkNsYXNzICR7bWFpbkNsYXNzfSBkaWQgbm90IHJlc3VsdCBpbiBhIGRyaXZlciBvYmplY3RgKTtcbiAgICB9XG4gICAgcmV0dXJuIHtkcml2ZXIsIHZlcnNpb24sIGRyaXZlck5hbWV9O1xuICB9IGNhdGNoIChlcnIpIHtcbiAgICBjb25zdCBtc2cgPSBgQ291bGQgbm90IGZpbmQgYSBkcml2ZXIgZm9yIGF1dG9tYXRpb25OYW1lIGAgK1xuICAgICAgICAgICAgICAgIGAnJHthdXRvbWF0aW9uTmFtZX0nIGFuZCBwbGF0Zm9ybU5hbWUgJHtwbGF0Zm9ybU5hbWV9Jy4gYCArXG4gICAgICAgICAgICAgICAgYEhhdmUgeW91IGluc3RhbGxlZCBhIGRyaXZlciB0aGF0IHN1cHBvcnRzIHRob3NlIGAgK1xuICAgICAgICAgICAgICAgIGBjYXBhYmlsaXRpZXM/IFJ1biAnYXBwaXVtIGRyaXZlciBsaXN0IC0taW5zdGFsbGVkJyB0byBzZWUuIGAgK1xuICAgICAgICAgICAgICAgIGAoTG93ZXItbGV2ZWwgZXJyb3I6ICR7ZXJyLm1lc3NhZ2V9KWA7XG4gICAgdGhyb3cgbmV3IEVycm9yKG1zZyk7XG4gIH1cbn1cblxuZXhwb3J0IHtcbiAgZmluZE1hdGNoaW5nRHJpdmVyLFxuICBLTk9XTl9EUklWRVJTLFxufTtcbiJdLCJmaWxlIjoibGliL2RyaXZlcnMuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==