appium-remote-debugger 5.3.0 → 5.7.0

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.
@@ -16,6 +16,8 @@ exports.simpleStringify = simpleStringify;
16
16
  exports.deferredPromise = deferredPromise;
17
17
  exports.isTargetBased = isTargetBased;
18
18
  exports.getElapsedTime = getElapsedTime;
19
+ exports.convertResult = convertResult;
20
+ exports.RESPONSE_LOG_LENGTH = void 0;
19
21
 
20
22
  require("source-map-support/register");
21
23
 
@@ -31,8 +33,12 @@ var _bluebird = _interopRequireDefault(require("bluebird"));
31
33
 
32
34
  var _appiumSupport = require("appium-support");
33
35
 
36
+ var _appiumBaseDriver = require("appium-base-driver");
37
+
34
38
  const WEB_CONTENT_BUNDLE_ID = 'com.apple.WebKit.WebContent';
35
39
  const MIN_PLATFORM_FOR_TARGET_BASED = '12.2';
40
+ const RESPONSE_LOG_LENGTH = 100;
41
+ exports.RESPONSE_LOG_LENGTH = RESPONSE_LOG_LENGTH;
36
42
 
37
43
  function appInfoFromDict(dict) {
38
44
  const id = dict.WIRApplicationIdentifierKey;
@@ -113,7 +119,7 @@ function appIdForBundle(bundleId, appDict) {
113
119
  let appId;
114
120
 
115
121
  for (const [key, data] of _lodash.default.toPairs(appDict)) {
116
- if (data.bundleId === bundleId) {
122
+ if (data.bundleId.endsWith(bundleId)) {
117
123
  appId = key;
118
124
  break;
119
125
  }
@@ -241,7 +247,27 @@ function isTargetBased(isSafari, platformVersion) {
241
247
  function getElapsedTime(startTime) {
242
248
  const endTime = process.hrtime(startTime);
243
249
  return parseInt((endTime[0] * 1e9 + endTime[1]) / 1e6, 10);
250
+ }
251
+
252
+ function convertResult(res) {
253
+ if (_lodash.default.isUndefined(res)) {
254
+ throw new Error(`Did not get OK result from remote debugger. Result was: ${_lodash.default.truncate(simpleStringify(res), {
255
+ length: RESPONSE_LOG_LENGTH
256
+ })}`);
257
+ } else if (_lodash.default.isString(res)) {
258
+ try {
259
+ res = JSON.parse(res);
260
+ } catch (err) {}
261
+ } else if (!_lodash.default.isObject(res)) {
262
+ throw new Error(`Result has unexpected type: (${typeof res}).`);
263
+ }
264
+
265
+ if (res.status && res.status !== 0) {
266
+ throw (0, _appiumBaseDriver.errorFromMJSONWPStatusCode)(res.status, res.value.message || res.value);
267
+ }
268
+
269
+ return _lodash.default.has(res, 'value') ? res.value : res;
244
270
  }require('source-map-support').install();
245
271
 
246
272
 
247
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/helpers.js"],"names":["WEB_CONTENT_BUNDLE_ID","MIN_PLATFORM_FOR_TARGET_BASED","appInfoFromDict","dict","id","WIRApplicationIdentifierKey","isProxy","_","isString","WIRIsApplicationProxyKey","toLowerCase","entry","name","WIRApplicationNameKey","bundleId","WIRApplicationBundleIdentifierKey","hostId","WIRHostApplicationIdentifierKey","isActive","WIRIsApplicationActiveKey","isAutomationEnabled","WIRRemoteAutomationEnabledKey","pageArrayFromDict","pageDict","newPageArray","values","isUndefined","WIRTypeKey","push","WIRPageIdentifierKey","title","WIRTitleKey","url","WIRURLKey","isKey","WIRConnectionIdentifierKey","getDebuggerAppKey","platformVersion","appDict","appId","parseFloat","key","data","toPairs","log","debug","proxiedAppIds","length","last","has","appIdForBundle","getPossibleDebuggerAppKeys","bundleIds","checkParams","params","errors","param","value","assert","ok","err","wrapScriptForFrame","script","frame","elFromCache","toString","JSON","stringify","getScriptForAtom","atom","args","frames","asyncCallBack","atomSrc","map","join","simpleStringify","multiline","cleanValue","clone","property","deferredPromise","resolve","reject","promise","B","res","rej","isTargetBased","isSafari","isHighVersion","util","compareVersions","getElapsedTime","startTime","endTime","process","hrtime","parseInt"],"mappings":"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","sourcesContent":["import log from './logger';\nimport getAtom from './atoms';\nimport _ from 'lodash';\nimport assert from 'assert';\nimport B from 'bluebird';\nimport { util } from 'appium-support';\n\n\nconst WEB_CONTENT_BUNDLE_ID = 'com.apple.WebKit.WebContent';\nconst MIN_PLATFORM_FOR_TARGET_BASED = '12.2';\n\n/*\n * Takes a dictionary from the remote debugger and makes a more manageable\n * dictionary whose keys are understandable\n */\nfunction appInfoFromDict (dict) {\n  const id = dict.WIRApplicationIdentifierKey;\n  const isProxy = _.isString(dict.WIRIsApplicationProxyKey)\n    ? dict.WIRIsApplicationProxyKey.toLowerCase() === 'true'\n    : dict.WIRIsApplicationProxyKey;\n  const entry = {\n    id,\n    isProxy,\n    name: dict.WIRApplicationNameKey,\n    bundleId: dict.WIRApplicationBundleIdentifierKey,\n    hostId: dict.WIRHostApplicationIdentifierKey,\n    isActive: dict.WIRIsApplicationActiveKey,\n    isAutomationEnabled: !!dict.WIRRemoteAutomationEnabledKey,\n  };\n\n  return [id, entry];\n}\n\n/*\n * Take a dictionary from the remote debugger and makes a more manageable\n * dictionary of pages available.\n */\nfunction pageArrayFromDict (pageDict) {\n  if (pageDict.id) {\n    // the page is already translated, so wrap in an array and pass back\n    return [pageDict];\n  }\n  let newPageArray = [];\n  for (const dict of _.values(pageDict)) {\n    // count only WIRTypeWeb pages and ignore all others (WIRTypeJavaScript etc)\n    if (_.isUndefined(dict.WIRTypeKey) || dict.WIRTypeKey === 'WIRTypeWeb') {\n      newPageArray.push({\n        id: dict.WIRPageIdentifierKey,\n        title: dict.WIRTitleKey,\n        url: dict.WIRURLKey,\n        isKey: !_.isUndefined(dict.WIRConnectionIdentifierKey),\n      });\n    }\n  }\n  return newPageArray;\n}\n\n/*\n * Given a bundle id, finds the correct remote debugger app that is\n * connected.\n */\nfunction getDebuggerAppKey (bundleId, platformVersion, appDict) {\n  let appId;\n  if (parseFloat(platformVersion) >= 8) {\n    for (const [key, data] of _.toPairs(appDict)) {\n      if (data.bundleId === bundleId) {\n        appId = key;\n        break;\n      }\n    }\n    // now we need to determine if we should pick a proxy for this instead\n    if (appId) {\n      log.debug(`Found app id key '${appId}' for bundle '${bundleId}'`);\n      let proxiedAppIds = [];\n      for (const [key, data] of _.toPairs(appDict)) {\n        if (data.isProxy && data.hostId === appId) {\n          log.debug(`Found separate bundleId '${data.bundleId}' ` +\n                    `acting as proxy for '${bundleId}', with app id '${key}'`);\n          proxiedAppIds.push(key);\n        }\n      }\n      if (proxiedAppIds.length) {\n        // use the last app being proxied\n        appId = _.last(proxiedAppIds);\n        log.debug(`Using proxied app id '${appId}'`);\n      }\n    }\n  } else {\n    if (_.has(appDict, bundleId)) {\n      appId = bundleId;\n    }\n  }\n\n  return appId;\n}\n\nfunction appIdForBundle (bundleId, appDict) {\n  let appId;\n  for (const [key, data] of _.toPairs(appDict)) {\n    if (data.bundleId === bundleId) {\n      appId = key;\n      break;\n    }\n  }\n\n  // if nothing is found, try to get the generic app\n  if (!appId && bundleId !== WEB_CONTENT_BUNDLE_ID) {\n    return appIdForBundle(WEB_CONTENT_BUNDLE_ID, appDict);\n  }\n\n  return appId;\n}\n\nfunction getPossibleDebuggerAppKeys (bundleIds, platformVersion, appDict) {\n  let proxiedAppIds = [];\n\n  for (const bundleId of bundleIds) {\n    const appId = appIdForBundle(bundleId, appDict);\n\n    // now we need to determine if we should pick a proxy for this instead\n    if (appId) {\n      proxiedAppIds.push(appId);\n      log.debug(`Found app id key '${appId}' for bundle '${bundleId}'`);\n      for (const [key, data] of _.toPairs(appDict)) {\n        if (data.isProxy && data.hostId === appId) {\n          log.debug(`Found separate bundleId '${data.bundleId}' ` +\n                    `acting as proxy for '${bundleId}', with app id '${key}'`);\n          proxiedAppIds.push(key);\n        }\n      }\n    }\n  }\n\n  return proxiedAppIds;\n}\n\nfunction checkParams (params) {\n  let errors = [];\n  for (const [param, value] of _.toPairs(params)) {\n    try {\n      assert.ok(value);\n    } catch (err) {\n      errors.push(param);\n    }\n  }\n  if (errors.length) {\n    return errors;\n  }\n}\n\nasync function wrapScriptForFrame (script, frame) {\n  log.debug(`Wrapping script for frame '${frame}'`);\n  let elFromCache = await getAtom('get_element_from_cache');\n  return `(function (window) { var document = window.document; ` +\n         `return (${script}); })((${elFromCache.toString('utf8')})(${JSON.stringify(frame)}))`;\n}\n\nasync function getScriptForAtom (atom, args, frames, asyncCallBack = null) {\n  let atomSrc = await getAtom(atom);\n  let script;\n  if (frames.length > 0) {\n    script = atomSrc;\n    for (const frame of frames) {\n      script = await wrapScriptForFrame(script, frame);\n    }\n  } else {\n    log.debug(`Executing '${atom}' atom in default context`);\n    script = `(${atomSrc})`;\n  }\n\n  // add the arguments, as strings\n  args = args.map(JSON.stringify);\n  if (asyncCallBack) {\n    script += `(${args.join(',')}, ${asyncCallBack}, true )`;\n  } else {\n    script += `(${args.join(',')})`;\n  }\n\n  return script;\n}\n\nfunction simpleStringify (value, multiline = false) {\n  if (!value) {\n    return JSON.stringify(value);\n  }\n\n  // we get back objects sometimes with string versions of functions\n  // which muddy the logs\n  let cleanValue = _.clone(value);\n  for (const property of ['ceil', 'clone', 'floor', 'round', 'scale', 'toString']) {\n    delete cleanValue[property];\n  }\n  return multiline ? JSON.stringify(cleanValue, null, 2) : JSON.stringify(cleanValue);\n}\n\nfunction deferredPromise () {\n  // http://bluebirdjs.com/docs/api/deferred-migration.html\n  let resolve;\n  let reject;\n  const promise = new B((res, rej) => { // eslint-disable-line promise/param-names\n    resolve = res;\n    reject = rej;\n  });\n  return {\n    promise,\n    resolve,\n    reject\n  };\n}\n\nfunction isTargetBased (isSafari, platformVersion) {\n  // on iOS 12.2 the messages get sent through the Target domain\n  const isHighVersion = util.compareVersions(platformVersion, '>=', MIN_PLATFORM_FOR_TARGET_BASED);\n  log.debug(`Checking which communication style to use (${isSafari ? '' : 'non-'}Safari on platform version '${platformVersion}')`);\n  log.debug(`Platform version equal or higher than '${MIN_PLATFORM_FOR_TARGET_BASED}': ${isHighVersion}`);\n  return isSafari && isHighVersion;\n}\n\nfunction getElapsedTime (startTime) {\n  const endTime = process.hrtime(startTime);\n  return parseInt((endTime[0] * 1e9 + endTime[1]) / 1e6, 10);\n}\n\nexport {\n  appInfoFromDict, pageArrayFromDict, getDebuggerAppKey,\n  getPossibleDebuggerAppKeys, checkParams, wrapScriptForFrame, getScriptForAtom,\n  simpleStringify, deferredPromise, isTargetBased, getElapsedTime,\n};\n"],"file":"lib/helpers.js","sourceRoot":"../.."}
273
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/helpers.js"],"names":["WEB_CONTENT_BUNDLE_ID","MIN_PLATFORM_FOR_TARGET_BASED","RESPONSE_LOG_LENGTH","appInfoFromDict","dict","id","WIRApplicationIdentifierKey","isProxy","_","isString","WIRIsApplicationProxyKey","toLowerCase","entry","name","WIRApplicationNameKey","bundleId","WIRApplicationBundleIdentifierKey","hostId","WIRHostApplicationIdentifierKey","isActive","WIRIsApplicationActiveKey","isAutomationEnabled","WIRRemoteAutomationEnabledKey","pageArrayFromDict","pageDict","newPageArray","values","isUndefined","WIRTypeKey","push","WIRPageIdentifierKey","title","WIRTitleKey","url","WIRURLKey","isKey","WIRConnectionIdentifierKey","getDebuggerAppKey","platformVersion","appDict","appId","parseFloat","key","data","toPairs","log","debug","proxiedAppIds","length","last","has","appIdForBundle","endsWith","getPossibleDebuggerAppKeys","bundleIds","checkParams","params","errors","param","value","assert","ok","err","wrapScriptForFrame","script","frame","elFromCache","toString","JSON","stringify","getScriptForAtom","atom","args","frames","asyncCallBack","atomSrc","map","join","simpleStringify","multiline","cleanValue","clone","property","deferredPromise","resolve","reject","promise","B","res","rej","isTargetBased","isSafari","isHighVersion","util","compareVersions","getElapsedTime","startTime","endTime","process","hrtime","parseInt","convertResult","Error","truncate","parse","isObject","status","message"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA,MAAMA,qBAAqB,GAAG,6BAA9B;AACA,MAAMC,6BAA6B,GAAG,MAAtC;AAEA,MAAMC,mBAAmB,GAAG,GAA5B;;;AAMA,SAASC,eAAT,CAA0BC,IAA1B,EAAgC;AAC9B,QAAMC,EAAE,GAAGD,IAAI,CAACE,2BAAhB;AACA,QAAMC,OAAO,GAAGC,gBAAEC,QAAF,CAAWL,IAAI,CAACM,wBAAhB,IACZN,IAAI,CAACM,wBAAL,CAA8BC,WAA9B,OAAgD,MADpC,GAEZP,IAAI,CAACM,wBAFT;AAGA,QAAME,KAAK,GAAG;AACZP,IAAAA,EADY;AAEZE,IAAAA,OAFY;AAGZM,IAAAA,IAAI,EAAET,IAAI,CAACU,qBAHC;AAIZC,IAAAA,QAAQ,EAAEX,IAAI,CAACY,iCAJH;AAKZC,IAAAA,MAAM,EAAEb,IAAI,CAACc,+BALD;AAMZC,IAAAA,QAAQ,EAAEf,IAAI,CAACgB,yBANH;AAOZC,IAAAA,mBAAmB,EAAE,CAAC,CAACjB,IAAI,CAACkB;AAPhB,GAAd;AAUA,SAAO,CAACjB,EAAD,EAAKO,KAAL,CAAP;AACD;;AAMD,SAASW,iBAAT,CAA4BC,QAA5B,EAAsC;AACpC,MAAIA,QAAQ,CAACnB,EAAb,EAAiB;AAEf,WAAO,CAACmB,QAAD,CAAP;AACD;;AACD,MAAIC,YAAY,GAAG,EAAnB;;AACA,OAAK,MAAMrB,IAAX,IAAmBI,gBAAEkB,MAAF,CAASF,QAAT,CAAnB,EAAuC;AAErC,QAAIhB,gBAAEmB,WAAF,CAAcvB,IAAI,CAACwB,UAAnB,KAAkCxB,IAAI,CAACwB,UAAL,KAAoB,YAA1D,EAAwE;AACtEH,MAAAA,YAAY,CAACI,IAAb,CAAkB;AAChBxB,QAAAA,EAAE,EAAED,IAAI,CAAC0B,oBADO;AAEhBC,QAAAA,KAAK,EAAE3B,IAAI,CAAC4B,WAFI;AAGhBC,QAAAA,GAAG,EAAE7B,IAAI,CAAC8B,SAHM;AAIhBC,QAAAA,KAAK,EAAE,CAAC3B,gBAAEmB,WAAF,CAAcvB,IAAI,CAACgC,0BAAnB;AAJQ,OAAlB;AAMD;AACF;;AACD,SAAOX,YAAP;AACD;;AAMD,SAASY,iBAAT,CAA4BtB,QAA5B,EAAsCuB,eAAtC,EAAuDC,OAAvD,EAAgE;AAC9D,MAAIC,KAAJ;;AACA,MAAIC,UAAU,CAACH,eAAD,CAAV,IAA+B,CAAnC,EAAsC;AACpC,SAAK,MAAM,CAACI,GAAD,EAAMC,IAAN,CAAX,IAA0BnC,gBAAEoC,OAAF,CAAUL,OAAV,CAA1B,EAA8C;AAC5C,UAAII,IAAI,CAAC5B,QAAL,KAAkBA,QAAtB,EAAgC;AAC9ByB,QAAAA,KAAK,GAAGE,GAAR;AACA;AACD;AACF;;AAED,QAAIF,KAAJ,EAAW;AACTK,sBAAIC,KAAJ,CAAW,qBAAoBN,KAAM,iBAAgBzB,QAAS,GAA9D;;AACA,UAAIgC,aAAa,GAAG,EAApB;;AACA,WAAK,MAAM,CAACL,GAAD,EAAMC,IAAN,CAAX,IAA0BnC,gBAAEoC,OAAF,CAAUL,OAAV,CAA1B,EAA8C;AAC5C,YAAII,IAAI,CAACpC,OAAL,IAAgBoC,IAAI,CAAC1B,MAAL,KAAgBuB,KAApC,EAA2C;AACzCK,0BAAIC,KAAJ,CAAW,4BAA2BH,IAAI,CAAC5B,QAAS,IAA1C,GACC,wBAAuBA,QAAS,mBAAkB2B,GAAI,GADjE;;AAEAK,UAAAA,aAAa,CAAClB,IAAd,CAAmBa,GAAnB;AACD;AACF;;AACD,UAAIK,aAAa,CAACC,MAAlB,EAA0B;AAExBR,QAAAA,KAAK,GAAGhC,gBAAEyC,IAAF,CAAOF,aAAP,CAAR;;AACAF,wBAAIC,KAAJ,CAAW,yBAAwBN,KAAM,GAAzC;AACD;AACF;AACF,GAxBD,MAwBO;AACL,QAAIhC,gBAAE0C,GAAF,CAAMX,OAAN,EAAexB,QAAf,CAAJ,EAA8B;AAC5ByB,MAAAA,KAAK,GAAGzB,QAAR;AACD;AACF;;AAED,SAAOyB,KAAP;AACD;;AAED,SAASW,cAAT,CAAyBpC,QAAzB,EAAmCwB,OAAnC,EAA4C;AAC1C,MAAIC,KAAJ;;AACA,OAAK,MAAM,CAACE,GAAD,EAAMC,IAAN,CAAX,IAA0BnC,gBAAEoC,OAAF,CAAUL,OAAV,CAA1B,EAA8C;AAC5C,QAAII,IAAI,CAAC5B,QAAL,CAAcqC,QAAd,CAAuBrC,QAAvB,CAAJ,EAAsC;AACpCyB,MAAAA,KAAK,GAAGE,GAAR;AACA;AACD;AACF;;AAGD,MAAI,CAACF,KAAD,IAAUzB,QAAQ,KAAKf,qBAA3B,EAAkD;AAChD,WAAOmD,cAAc,CAACnD,qBAAD,EAAwBuC,OAAxB,CAArB;AACD;;AAED,SAAOC,KAAP;AACD;;AAED,SAASa,0BAAT,CAAqCC,SAArC,EAAgDhB,eAAhD,EAAiEC,OAAjE,EAA0E;AACxE,MAAIQ,aAAa,GAAG,EAApB;;AAEA,OAAK,MAAMhC,QAAX,IAAuBuC,SAAvB,EAAkC;AAChC,UAAMd,KAAK,GAAGW,cAAc,CAACpC,QAAD,EAAWwB,OAAX,CAA5B;;AAGA,QAAIC,KAAJ,EAAW;AACTO,MAAAA,aAAa,CAAClB,IAAd,CAAmBW,KAAnB;;AACAK,sBAAIC,KAAJ,CAAW,qBAAoBN,KAAM,iBAAgBzB,QAAS,GAA9D;;AACA,WAAK,MAAM,CAAC2B,GAAD,EAAMC,IAAN,CAAX,IAA0BnC,gBAAEoC,OAAF,CAAUL,OAAV,CAA1B,EAA8C;AAC5C,YAAII,IAAI,CAACpC,OAAL,IAAgBoC,IAAI,CAAC1B,MAAL,KAAgBuB,KAApC,EAA2C;AACzCK,0BAAIC,KAAJ,CAAW,4BAA2BH,IAAI,CAAC5B,QAAS,IAA1C,GACC,wBAAuBA,QAAS,mBAAkB2B,GAAI,GADjE;;AAEAK,UAAAA,aAAa,CAAClB,IAAd,CAAmBa,GAAnB;AACD;AACF;AACF;AACF;;AAED,SAAOK,aAAP;AACD;;AAED,SAASQ,WAAT,CAAsBC,MAAtB,EAA8B;AAC5B,MAAIC,MAAM,GAAG,EAAb;;AACA,OAAK,MAAM,CAACC,KAAD,EAAQC,KAAR,CAAX,IAA6BnD,gBAAEoC,OAAF,CAAUY,MAAV,CAA7B,EAAgD;AAC9C,QAAI;AACFI,sBAAOC,EAAP,CAAUF,KAAV;AACD,KAFD,CAEE,OAAOG,GAAP,EAAY;AACZL,MAAAA,MAAM,CAAC5B,IAAP,CAAY6B,KAAZ;AACD;AACF;;AACD,MAAID,MAAM,CAACT,MAAX,EAAmB;AACjB,WAAOS,MAAP;AACD;AACF;;AAED,eAAeM,kBAAf,CAAmCC,MAAnC,EAA2CC,KAA3C,EAAkD;AAChDpB,kBAAIC,KAAJ,CAAW,8BAA6BmB,KAAM,GAA9C;;AACA,MAAIC,WAAW,GAAG,MAAM,oBAAQ,wBAAR,CAAxB;AACA,SAAQ,uDAAD,GACC,WAAUF,MAAO,UAASE,WAAW,CAACC,QAAZ,CAAqB,MAArB,CAA6B,KAAIC,IAAI,CAACC,SAAL,CAAeJ,KAAf,CAAsB,IADzF;AAED;;AAED,eAAeK,gBAAf,CAAiCC,IAAjC,EAAuCC,IAAvC,EAA6CC,MAA7C,EAAqDC,aAAa,GAAG,IAArE,EAA2E;AACzE,MAAIC,OAAO,GAAG,MAAM,oBAAQJ,IAAR,CAApB;AACA,MAAIP,MAAJ;;AACA,MAAIS,MAAM,CAACzB,MAAP,GAAgB,CAApB,EAAuB;AACrBgB,IAAAA,MAAM,GAAGW,OAAT;;AACA,SAAK,MAAMV,KAAX,IAAoBQ,MAApB,EAA4B;AAC1BT,MAAAA,MAAM,GAAG,MAAMD,kBAAkB,CAACC,MAAD,EAASC,KAAT,CAAjC;AACD;AACF,GALD,MAKO;AACLpB,oBAAIC,KAAJ,CAAW,cAAayB,IAAK,2BAA7B;;AACAP,IAAAA,MAAM,GAAI,IAAGW,OAAQ,GAArB;AACD;;AAGDH,EAAAA,IAAI,GAAGA,IAAI,CAACI,GAAL,CAASR,IAAI,CAACC,SAAd,CAAP;;AACA,MAAIK,aAAJ,EAAmB;AACjBV,IAAAA,MAAM,IAAK,IAAGQ,IAAI,CAACK,IAAL,CAAU,GAAV,CAAe,KAAIH,aAAc,UAA/C;AACD,GAFD,MAEO;AACLV,IAAAA,MAAM,IAAK,IAAGQ,IAAI,CAACK,IAAL,CAAU,GAAV,CAAe,GAA7B;AACD;;AAED,SAAOb,MAAP;AACD;;AAED,SAASc,eAAT,CAA0BnB,KAA1B,EAAiCoB,SAAS,GAAG,KAA7C,EAAoD;AAClD,MAAI,CAACpB,KAAL,EAAY;AACV,WAAOS,IAAI,CAACC,SAAL,CAAeV,KAAf,CAAP;AACD;;AAID,MAAIqB,UAAU,GAAGxE,gBAAEyE,KAAF,CAAQtB,KAAR,CAAjB;;AACA,OAAK,MAAMuB,QAAX,IAAuB,CAAC,MAAD,EAAS,OAAT,EAAkB,OAAlB,EAA2B,OAA3B,EAAoC,OAApC,EAA6C,UAA7C,CAAvB,EAAiF;AAC/E,WAAOF,UAAU,CAACE,QAAD,CAAjB;AACD;;AACD,SAAOH,SAAS,GAAGX,IAAI,CAACC,SAAL,CAAeW,UAAf,EAA2B,IAA3B,EAAiC,CAAjC,CAAH,GAAyCZ,IAAI,CAACC,SAAL,CAAeW,UAAf,CAAzD;AACD;;AAED,SAASG,eAAT,GAA4B;AAE1B,MAAIC,OAAJ;AACA,MAAIC,MAAJ;AACA,QAAMC,OAAO,GAAG,IAAIC,iBAAJ,CAAM,CAACC,GAAD,EAAMC,GAAN,KAAc;AAClCL,IAAAA,OAAO,GAAGI,GAAV;AACAH,IAAAA,MAAM,GAAGI,GAAT;AACD,GAHe,CAAhB;AAIA,SAAO;AACLH,IAAAA,OADK;AAELF,IAAAA,OAFK;AAGLC,IAAAA;AAHK,GAAP;AAKD;;AAED,SAASK,aAAT,CAAwBC,QAAxB,EAAkCrD,eAAlC,EAAmD;AAEjD,QAAMsD,aAAa,GAAGC,oBAAKC,eAAL,CAAqBxD,eAArB,EAAsC,IAAtC,EAA4CrC,6BAA5C,CAAtB;;AACA4C,kBAAIC,KAAJ,CAAW,8CAA6C6C,QAAQ,GAAG,EAAH,GAAQ,MAAO,+BAA8BrD,eAAgB,IAA7H;;AACAO,kBAAIC,KAAJ,CAAW,0CAAyC7C,6BAA8B,MAAK2F,aAAc,EAArG;;AACA,SAAOD,QAAQ,IAAIC,aAAnB;AACD;;AAED,SAASG,cAAT,CAAyBC,SAAzB,EAAoC;AAClC,QAAMC,OAAO,GAAGC,OAAO,CAACC,MAAR,CAAeH,SAAf,CAAhB;AACA,SAAOI,QAAQ,CAAC,CAACH,OAAO,CAAC,CAAD,CAAP,GAAa,GAAb,GAAmBA,OAAO,CAAC,CAAD,CAA3B,IAAkC,GAAnC,EAAwC,EAAxC,CAAf;AACD;;AAED,SAASI,aAAT,CAAwBb,GAAxB,EAA6B;AAC3B,MAAIhF,gBAAEmB,WAAF,CAAc6D,GAAd,CAAJ,EAAwB;AACtB,UAAM,IAAIc,KAAJ,CAAW,2DAA0D9F,gBAAE+F,QAAF,CAAWzB,eAAe,CAACU,GAAD,CAA1B,EAAiC;AAACxC,MAAAA,MAAM,EAAE9C;AAAT,KAAjC,CAAgE,EAArI,CAAN;AACD,GAFD,MAEO,IAAIM,gBAAEC,QAAF,CAAW+E,GAAX,CAAJ,EAAqB;AAC1B,QAAI;AACFA,MAAAA,GAAG,GAAGpB,IAAI,CAACoC,KAAL,CAAWhB,GAAX,CAAN;AACD,KAFD,CAEE,OAAO1B,GAAP,EAAY,CAGb;AACF,GAPM,MAOA,IAAI,CAACtD,gBAAEiG,QAAF,CAAWjB,GAAX,CAAL,EAAsB;AAC3B,UAAM,IAAIc,KAAJ,CAAW,gCAA+B,OAAOd,GAAI,IAArD,CAAN;AACD;;AAED,MAAIA,GAAG,CAACkB,MAAJ,IAAclB,GAAG,CAACkB,MAAJ,KAAe,CAAjC,EAAoC;AAElC,UAAM,kDAA2BlB,GAAG,CAACkB,MAA/B,EAAuClB,GAAG,CAAC7B,KAAJ,CAAUgD,OAAV,IAAqBnB,GAAG,CAAC7B,KAAhE,CAAN;AACD;;AAID,SAAOnD,gBAAE0C,GAAF,CAAMsC,GAAN,EAAW,OAAX,IAAsBA,GAAG,CAAC7B,KAA1B,GAAkC6B,GAAzC;AACD","sourcesContent":["import log from './logger';\nimport getAtom from './atoms';\nimport _ from 'lodash';\nimport assert from 'assert';\nimport B from 'bluebird';\nimport { util } from 'appium-support';\nimport { errorFromMJSONWPStatusCode } from 'appium-base-driver';\n\n\nconst WEB_CONTENT_BUNDLE_ID = 'com.apple.WebKit.WebContent';\nconst MIN_PLATFORM_FOR_TARGET_BASED = '12.2';\n\nconst RESPONSE_LOG_LENGTH = 100;\n\n/*\n * Takes a dictionary from the remote debugger and makes a more manageable\n * dictionary whose keys are understandable\n */\nfunction appInfoFromDict (dict) {\n  const id = dict.WIRApplicationIdentifierKey;\n  const isProxy = _.isString(dict.WIRIsApplicationProxyKey)\n    ? dict.WIRIsApplicationProxyKey.toLowerCase() === 'true'\n    : dict.WIRIsApplicationProxyKey;\n  const entry = {\n    id,\n    isProxy,\n    name: dict.WIRApplicationNameKey,\n    bundleId: dict.WIRApplicationBundleIdentifierKey,\n    hostId: dict.WIRHostApplicationIdentifierKey,\n    isActive: dict.WIRIsApplicationActiveKey,\n    isAutomationEnabled: !!dict.WIRRemoteAutomationEnabledKey,\n  };\n\n  return [id, entry];\n}\n\n/*\n * Take a dictionary from the remote debugger and makes a more manageable\n * dictionary of pages available.\n */\nfunction pageArrayFromDict (pageDict) {\n  if (pageDict.id) {\n    // the page is already translated, so wrap in an array and pass back\n    return [pageDict];\n  }\n  let newPageArray = [];\n  for (const dict of _.values(pageDict)) {\n    // count only WIRTypeWeb pages and ignore all others (WIRTypeJavaScript etc)\n    if (_.isUndefined(dict.WIRTypeKey) || dict.WIRTypeKey === 'WIRTypeWeb') {\n      newPageArray.push({\n        id: dict.WIRPageIdentifierKey,\n        title: dict.WIRTitleKey,\n        url: dict.WIRURLKey,\n        isKey: !_.isUndefined(dict.WIRConnectionIdentifierKey),\n      });\n    }\n  }\n  return newPageArray;\n}\n\n/*\n * Given a bundle id, finds the correct remote debugger app that is\n * connected.\n */\nfunction getDebuggerAppKey (bundleId, platformVersion, appDict) {\n  let appId;\n  if (parseFloat(platformVersion) >= 8) {\n    for (const [key, data] of _.toPairs(appDict)) {\n      if (data.bundleId === bundleId) {\n        appId = key;\n        break;\n      }\n    }\n    // now we need to determine if we should pick a proxy for this instead\n    if (appId) {\n      log.debug(`Found app id key '${appId}' for bundle '${bundleId}'`);\n      let proxiedAppIds = [];\n      for (const [key, data] of _.toPairs(appDict)) {\n        if (data.isProxy && data.hostId === appId) {\n          log.debug(`Found separate bundleId '${data.bundleId}' ` +\n                    `acting as proxy for '${bundleId}', with app id '${key}'`);\n          proxiedAppIds.push(key);\n        }\n      }\n      if (proxiedAppIds.length) {\n        // use the last app being proxied\n        appId = _.last(proxiedAppIds);\n        log.debug(`Using proxied app id '${appId}'`);\n      }\n    }\n  } else {\n    if (_.has(appDict, bundleId)) {\n      appId = bundleId;\n    }\n  }\n\n  return appId;\n}\n\nfunction appIdForBundle (bundleId, appDict) {\n  let appId;\n  for (const [key, data] of _.toPairs(appDict)) {\n    if (data.bundleId.endsWith(bundleId)) {\n      appId = key;\n      break;\n    }\n  }\n\n  // if nothing is found, try to get the generic app\n  if (!appId && bundleId !== WEB_CONTENT_BUNDLE_ID) {\n    return appIdForBundle(WEB_CONTENT_BUNDLE_ID, appDict);\n  }\n\n  return appId;\n}\n\nfunction getPossibleDebuggerAppKeys (bundleIds, platformVersion, appDict) {\n  let proxiedAppIds = [];\n\n  for (const bundleId of bundleIds) {\n    const appId = appIdForBundle(bundleId, appDict);\n\n    // now we need to determine if we should pick a proxy for this instead\n    if (appId) {\n      proxiedAppIds.push(appId);\n      log.debug(`Found app id key '${appId}' for bundle '${bundleId}'`);\n      for (const [key, data] of _.toPairs(appDict)) {\n        if (data.isProxy && data.hostId === appId) {\n          log.debug(`Found separate bundleId '${data.bundleId}' ` +\n                    `acting as proxy for '${bundleId}', with app id '${key}'`);\n          proxiedAppIds.push(key);\n        }\n      }\n    }\n  }\n\n  return proxiedAppIds;\n}\n\nfunction checkParams (params) {\n  let errors = [];\n  for (const [param, value] of _.toPairs(params)) {\n    try {\n      assert.ok(value);\n    } catch (err) {\n      errors.push(param);\n    }\n  }\n  if (errors.length) {\n    return errors;\n  }\n}\n\nasync function wrapScriptForFrame (script, frame) {\n  log.debug(`Wrapping script for frame '${frame}'`);\n  let elFromCache = await getAtom('get_element_from_cache');\n  return `(function (window) { var document = window.document; ` +\n         `return (${script}); })((${elFromCache.toString('utf8')})(${JSON.stringify(frame)}))`;\n}\n\nasync function getScriptForAtom (atom, args, frames, asyncCallBack = null) {\n  let atomSrc = await getAtom(atom);\n  let script;\n  if (frames.length > 0) {\n    script = atomSrc;\n    for (const frame of frames) {\n      script = await wrapScriptForFrame(script, frame);\n    }\n  } else {\n    log.debug(`Executing '${atom}' atom in default context`);\n    script = `(${atomSrc})`;\n  }\n\n  // add the arguments, as strings\n  args = args.map(JSON.stringify);\n  if (asyncCallBack) {\n    script += `(${args.join(',')}, ${asyncCallBack}, true )`;\n  } else {\n    script += `(${args.join(',')})`;\n  }\n\n  return script;\n}\n\nfunction simpleStringify (value, multiline = false) {\n  if (!value) {\n    return JSON.stringify(value);\n  }\n\n  // we get back objects sometimes with string versions of functions\n  // which muddy the logs\n  let cleanValue = _.clone(value);\n  for (const property of ['ceil', 'clone', 'floor', 'round', 'scale', 'toString']) {\n    delete cleanValue[property];\n  }\n  return multiline ? JSON.stringify(cleanValue, null, 2) : JSON.stringify(cleanValue);\n}\n\nfunction deferredPromise () {\n  // http://bluebirdjs.com/docs/api/deferred-migration.html\n  let resolve;\n  let reject;\n  const promise = new B((res, rej) => { // eslint-disable-line promise/param-names\n    resolve = res;\n    reject = rej;\n  });\n  return {\n    promise,\n    resolve,\n    reject\n  };\n}\n\nfunction isTargetBased (isSafari, platformVersion) {\n  // on iOS 12.2 the messages get sent through the Target domain\n  const isHighVersion = util.compareVersions(platformVersion, '>=', MIN_PLATFORM_FOR_TARGET_BASED);\n  log.debug(`Checking which communication style to use (${isSafari ? '' : 'non-'}Safari on platform version '${platformVersion}')`);\n  log.debug(`Platform version equal or higher than '${MIN_PLATFORM_FOR_TARGET_BASED}': ${isHighVersion}`);\n  return isSafari && isHighVersion;\n}\n\nfunction getElapsedTime (startTime) {\n  const endTime = process.hrtime(startTime);\n  return parseInt((endTime[0] * 1e9 + endTime[1]) / 1e6, 10);\n}\n\nfunction convertResult (res) {\n  if (_.isUndefined(res)) {\n    throw new Error(`Did not get OK result from remote debugger. Result was: ${_.truncate(simpleStringify(res), {length: RESPONSE_LOG_LENGTH})}`);\n  } else if (_.isString(res)) {\n    try {\n      res = JSON.parse(res);\n    } catch (err) {\n      // we might get a serialized object, but we might not\n      // if we get here, it is just a value\n    }\n  } else if (!_.isObject(res)) {\n    throw new Error(`Result has unexpected type: (${typeof res}).`);\n  }\n\n  if (res.status && res.status !== 0) {\n    // we got some form of error.\n    throw errorFromMJSONWPStatusCode(res.status, res.value.message || res.value);\n  }\n\n  // with either have an object with a `value` property (even if `null`),\n  // or a plain object\n  return _.has(res, 'value') ? res.value : res;\n}\n\nexport {\n  appInfoFromDict, pageArrayFromDict, getDebuggerAppKey,\n  getPossibleDebuggerAppKeys, checkParams, wrapScriptForFrame, getScriptForAtom,\n  simpleStringify, deferredPromise, isTargetBased, getElapsedTime,\n  convertResult, RESPONSE_LOG_LENGTH,\n};\n"],"file":"lib/helpers.js","sourceRoot":"../.."}
@@ -168,25 +168,6 @@ class RpcMessageHandler {
168
168
  const dataKey = this.parseDataKey(plist);
169
169
  let msgId = (dataKey.id || '').toString();
170
170
  let result = dataKey.result;
171
- let error = dataKey.error || null;
172
-
173
- if (result && result.wasThrown) {
174
- let message = result.result && (result.result.value || result.result.description) ? result.result.value || result.result.description : 'Error occurred in handling data message';
175
- error = new Error(message);
176
- }
177
-
178
- if (error) {
179
- if (this.hasErrorHandler(msgId)) {
180
- this.errorHandlers[msgId](error);
181
- } else {
182
- _logger.default.error(`Error occurred in handling data message: ${error}`);
183
-
184
- _logger.default.error('No error handler present, ignoring');
185
- }
186
-
187
- return;
188
- }
189
-
190
171
  let method = dataKey.method;
191
172
  let params;
192
173
 
@@ -225,11 +206,28 @@ class RpcMessageHandler {
225
206
  params = dataKey.params;
226
207
  }
227
208
 
228
- if (!_lodash.default.isEmpty(msgId)) {
229
- _logger.default.debug(`Received response for message '${msgId}'`);
209
+ let error = dataKey.error || null;
210
+
211
+ if (result && result.wasThrown) {
212
+ const message = result.result && (result.result.value || result.result.description) ? result.result.value || result.result.description : 'Error occurred in handling data message';
213
+ error = new Error(message);
214
+ }
215
+
216
+ if (!error) {
217
+ if (!_lodash.default.isEmpty(msgId)) {
218
+ _logger.default.debug(`Received response for message '${msgId}'`);
219
+ }
220
+
221
+ return await this.dispatchDataMessage(msgId, method, params, result, error);
230
222
  }
231
223
 
232
- await this.dispatchDataMessage(msgId, method, params, result, error);
224
+ if (this.hasErrorHandler(msgId)) {
225
+ this.errorHandlers[msgId](error);
226
+ } else {
227
+ _logger.default.error(`Error occurred in handling data message: ${error}`);
228
+
229
+ _logger.default.error('No error handler present, ignoring');
230
+ }
233
231
  }
234
232
 
235
233
  setHandlers() {
@@ -266,4 +264,4 @@ class RpcMessageHandler {
266
264
  exports.default = RpcMessageHandler;require('source-map-support').install();
267
265
 
268
266
 
269
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/remote-debugger-message-handler.js"],"names":["IGNORED_EVENTS","RpcMessageHandler","constructor","specialHandlers","isTargetBased","setHandlers","errorHandlers","_","clone","dataHandlers","willNavigateWithoutReload","setCommunicationProtocol","setDataMessageHandler","key","errorHandler","handler","setSpecialMessageHandler","getSpecialMessageHandler","setTimelineEventHandler","timelineEventHandler","setConsoleLogEventHandler","consoleLogEventHandler","setNetworkEventHandler","networkLogEventHandler","hasErrorHandler","has","hasSpecialMessageHandler","allowNavigationWithoutReload","allow","handleMessage","plist","selector","__selector","log","debug","handlers","handleSpecialMessage","args","fn","warn","parseDataKey","JSON","parse","__argument","WIRMessageDataKey","toString","err","error","truncate","stringify","length","Error","message","dispatchDataMessage","msgId","method","params","result","isEmpty","pageLoading","isFunction","includes","pageLoad","frameDetached","record","startsWith","value","logFullMessage","bufferToJSON","Buffer","prototype","toJSON","k","v","isBuffer","handleDataMessage","dataKey","id","wasThrown","description","app","WIRApplicationIdentifierKey","targetInfo","targetCreated","targetDestroyed","WIRSimulatorNameKey","WIRSimulatorBuildKey","WIRSimulatorProductVersionKey","WIRApplicationDictionaryKey","WIRListingKey"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AAKA,MAAMA,cAAc,GAAG,CACrB,iCADqB,EAErB,2BAFqB,EAGrB,0BAHqB,EAIrB,0BAJqB,EAKrB,+BALqB,EAMrB,sCANqB,EAOrB,yBAPqB,CAAvB;;AAUe,MAAMC,iBAAN,CAAwB;AACrCC,EAAAA,WAAW,CAAEC,eAAF,EAAmBC,aAAa,GAAG,KAAnC,EAA0C;AACnD,SAAKC,WAAL;AACA,SAAKC,aAAL,GAAqB,EAArB;AACA,SAAKH,eAAL,GAAuBI,gBAAEC,KAAF,CAAQL,eAAR,CAAvB;AACA,SAAKM,YAAL,GAAoB,EAApB;AACA,SAAKC,yBAAL,GAAiC,KAAjC;AAEA,SAAKN,aAAL,GAAqBA,aAArB;AACD;;AAEDO,EAAAA,wBAAwB,CAAEP,aAAF,EAAiB;AACvC,SAAKA,aAAL,GAAqBA,aAArB;AACD;;AAEDQ,EAAAA,qBAAqB,CAAEC,GAAF,EAAOC,YAAP,EAAqBC,OAArB,EAA8B;AACjD,SAAKT,aAAL,CAAmBO,GAAnB,IAA0BC,YAA1B;AACA,SAAKL,YAAL,CAAkBI,GAAlB,IAAyBE,OAAzB;AACD;;AAEDC,EAAAA,wBAAwB,CAAEH,GAAF,EAAOC,YAAP,EAAqBC,OAArB,EAA8B;AACpD,SAAKT,aAAL,CAAmBO,GAAnB,IAA0BC,YAA1B;AACA,SAAKX,eAAL,CAAqBU,GAArB,IAA4BE,OAA5B;AACD;;AAEDE,EAAAA,wBAAwB,CAAEJ,GAAF,EAAO;AAC7B,WAAO,KAAKV,eAAL,CAAqBU,GAArB,CAAP;AACD;;AAEDK,EAAAA,uBAAuB,CAAEC,oBAAF,EAAwB;AAC7C,SAAKA,oBAAL,GAA4BA,oBAA5B;AACD;;AAEDC,EAAAA,yBAAyB,CAAEC,sBAAF,EAA0B;AACjD,SAAKA,sBAAL,GAA8BA,sBAA9B;AACD;;AAEDC,EAAAA,sBAAsB,CAAEC,sBAAF,EAA0B;AAC9C,SAAKA,sBAAL,GAA8BA,sBAA9B;AACD;;AAEDC,EAAAA,eAAe,CAAEX,GAAF,EAAO;AACpB,WAAON,gBAAEkB,GAAF,CAAM,KAAKnB,aAAX,EAA0BO,GAA1B,CAAP;AACD;;AAEDa,EAAAA,wBAAwB,CAAEb,GAAF,EAAO;AAC7B,WAAON,gBAAEkB,GAAF,CAAM,KAAKtB,eAAX,EAA4BU,GAA5B,CAAP;AACD;;AAEDc,EAAAA,4BAA4B,CAAEC,KAAK,GAAG,IAAV,EAAgB;AAC1C,SAAKlB,yBAAL,GAAiCkB,KAAjC;AACD;;AAED,QAAMC,aAAN,CAAqBC,KAArB,EAA4B;AAC1B,UAAMC,QAAQ,GAAGD,KAAK,CAACE,UAAvB;;AACA,QAAI,CAACD,QAAL,EAAe;AACbE,sBAAIC,KAAJ,CAAU,sBAAV;;AACA;AACD;;AAED,QAAI3B,gBAAEkB,GAAF,CAAM,KAAKU,QAAX,EAAqBJ,QAArB,CAAJ,EAAoC;AAClC,YAAM,KAAKI,QAAL,CAAcJ,QAAd,EAAwBD,KAAxB,CAAN;AACD,KAFD,MAEO;AACLG,sBAAIC,KAAJ,CAAW,+BAA8BH,QAAS,gBAAxC,GACC,yBADX;AAED;AACF;;AAED,QAAMK,oBAAN,CAA4BrB,OAA5B,EAAqC,GAAGsB,IAAxC,EAA8C;AAC5C,UAAMC,EAAE,GAAG,KAAKnC,eAAL,CAAqBY,OAArB,CAAX;;AAEA,QAAIuB,EAAJ,EAAQ;AAIN,UAAIvB,OAAO,KAAK,yBAAZ,IACAA,OAAO,KAAK,+BADZ,IAEAA,OAAO,KAAK,4BAFZ,IAGAA,OAAO,KAAK,0BAHZ,IAIAA,OAAO,KAAK,iCAJhB,EAImD;AACjD,aAAKZ,eAAL,CAAqBY,OAArB,IAAgC,IAAhC;AACD;;AACD,YAAMuB,EAAE,CAAC,GAAGD,IAAJ,CAAR;AACD,KAZD,MAYO;AACLJ,sBAAIM,IAAJ,CAAU,4CAA2CxB,OAAQ,IAApD,GACC,oBADV;AAED;AACF;;AAEDyB,EAAAA,YAAY,CAAEV,KAAF,EAAS;AACnB,QAAI;AACF,aAAOW,IAAI,CAACC,KAAL,CAAWZ,KAAK,CAACa,UAAN,CAAiBC,iBAAjB,CAAmCC,QAAnC,CAA4C,MAA5C,CAAX,CAAP;AACD,KAFD,CAEE,OAAOC,GAAP,EAAY;AACZb,sBAAIc,KAAJ,CAAW,6BAA4BxC,gBAAEyC,QAAF,CAAWP,IAAI,CAACQ,SAAL,CAAenB,KAAf,CAAX,EAAkC;AAACoB,QAAAA,MAAM,EAAE;AAAT,OAAlC,CAAiD,EAAxF;;AACA,YAAM,IAAIC,KAAJ,CAAW,iCAAgCL,GAAG,CAACM,OAAQ,EAAvD,CAAN;AACD;AACF;;AAED,QAAMC,mBAAN,CAA2BC,KAA3B,EAAkCC,MAAlC,EAA0CC,MAA1C,EAAkDC,MAAlD,EAA0DV,KAA1D,EAAiE;AAC/D,QAAI,CAACxC,gBAAEmD,OAAF,CAAUJ,KAAV,CAAL,EAAuB;AACrBrB,sBAAIC,KAAJ,CAAW,0BAAyBoB,KAAM,IAA1C;AACD;;AACD,QAAIC,MAAM,KAAK,wBAAf,EAAyC;AACvCtB,sBAAIC,KAAJ,CAAU,6DACA,+BADV;AAED,KAHD,MAGO,IAAIqB,MAAM,KAAK,qBAAf,EAAsC;AAC3C,UAAI,CAAC,KAAK7C,yBAAN,IAAmC,CAAC,KAAKiD,WAA7C,EAA0D;AACxD,YAAIpD,gBAAEqD,UAAF,CAAa,KAAKzD,eAAL,CAAqB,qBAArB,CAAb,CAAJ,EAA+D;AAC7D,gBAAM,KAAKA,eAAL,CAAqB,qBAArB,EAA4C,iBAA5C,CAAN;AACA,eAAKA,eAAL,CAAqB,qBAArB,IAA8C,IAA9C;AACD;AACF,OALD,MAKO;AACL8B,wBAAIC,KAAJ,CAAU,sDACA,iCADV;;AAEA,aAAKxB,yBAAL,GAAiC,KAAjC;AACD;AACF,KAXM,MAWA,IAAIV,cAAc,CAAC6D,QAAf,CAAwBN,MAAxB,CAAJ,EAAqC,CAE3C,CAFM,MAEA,IAAIA,MAAM,KAAK,qBAAX,IAAoChD,gBAAEqD,UAAF,CAAa,KAAKzD,eAAL,CAAqB2D,QAAlC,CAAxC,EAAqF;AAC1F,YAAM,KAAK3D,eAAL,CAAqB2D,QAArB,EAAN;AACD,KAFM,MAEA,IAAIP,MAAM,KAAK,oBAAX,IAAmChD,gBAAEqD,UAAF,CAAa,KAAKzD,eAAL,CAAqB4D,aAAlC,CAAvC,EAAyF;AAC9F,YAAM,KAAK5D,eAAL,CAAqB4D,aAArB,EAAN;AACD,KAFM,MAEA,IAAIR,MAAM,KAAK,wBAAX,IAAuChD,gBAAEqD,UAAF,CAAa,KAAKzC,oBAAlB,CAA3C,EAAoF;AACzF,WAAKA,oBAAL,CAA0BqC,MAAM,IAAIA,MAAM,CAACQ,MAA3C;AACD,KAFM,MAEA,IAAIT,MAAM,KAAK,sBAAX,IAAqChD,gBAAEqD,UAAF,CAAa,KAAKvC,sBAAlB,CAAzC,EAAoF;AACzF,WAAKA,sBAAL,CAA4BmC,MAAM,CAACJ,OAAnC;AACD,KAFM,MAEA,IAAIG,MAAM,IAAIA,MAAM,CAACU,UAAP,CAAkB,UAAlB,CAAV,IAA2C1D,gBAAEqD,UAAF,CAAa,KAAKrC,sBAAlB,CAA/C,EAA0F;AAC/F,WAAKA,sBAAL,CAA4BgC,MAA5B,EAAoCC,MAApC;AACD,KAFM,MAEA,IAAIjD,gBAAEqD,UAAF,CAAa,KAAKnD,YAAL,CAAkB6C,KAAlB,CAAb,CAAJ,EAA4C;AAIjD,UAAIG,MAAM,CAACA,MAAP,IAAiBA,MAAM,CAACA,MAAP,CAAcS,KAAnC,EAA0C;AACxCT,QAAAA,MAAM,GAAGA,MAAM,CAACA,MAAP,CAAcS,KAAvB;AACD;;AACD,WAAKzD,YAAL,CAAkB6C,KAAlB,EAAyBG,MAAzB;AACA,WAAKhD,YAAL,CAAkB6C,KAAlB,IAA2B,IAA3B;AACD,KATM,MASA,IAAI,KAAK7C,YAAL,CAAkB6C,KAAlB,MAA6B,IAAjC,EAAuC;AAC5CrB,sBAAIc,KAAJ,CAAW,sCAAqCO,KAAM,GAA5C,GACC,yCADX;AAED,KAHM,MAGA;AACL,UAAIA,KAAK,IAAIG,MAAT,IAAmBV,KAAvB,EAA8B;AAC5Bd,wBAAIc,KAAJ,CAAW,uCAAsCO,KAAM,IAA7C,GACC,4CADD,GAEC,YAAWb,IAAI,CAACQ,SAAL,CAAeQ,MAAf,CAAuB,KAFnC,GAGC,WAAUV,KAAM,GAH3B;AAID;AACF;AACF;;AAEDoB,EAAAA,cAAc,CAAErC,KAAF,EAAS;AAErB,UAAMsC,YAAY,GAAGC,MAAM,CAACC,SAAP,CAAiBC,MAAtC;AACA,WAAOF,MAAM,CAACC,SAAP,CAAiBC,MAAxB;;AACA,QAAI;AACF,2BAAI9B,IAAI,CAACQ,SAAL,CAAenB,KAAf,EAAsB,CAAC0C,CAAD,EAAIC,CAAJ,KAAUJ,MAAM,CAACK,QAAP,CAAgBD,CAAhB,IAAqBA,CAAC,CAAC5B,QAAF,CAAW,MAAX,CAArB,GAA0C4B,CAA1E,EAA6E,CAA7E,CAAJ;AACD,KAFD,SAEU;AAERJ,MAAAA,MAAM,CAACC,SAAP,CAAiBC,MAAjB,GAA0BH,YAA1B;AACD;AACF;;AAED,QAAMO,iBAAN,CAAyB7C,KAAzB,EAAgC;AAC9B,UAAM8C,OAAO,GAAG,KAAKpC,YAAL,CAAkBV,KAAlB,CAAhB;AACA,QAAIwB,KAAK,GAAG,CAACsB,OAAO,CAACC,EAAR,IAAc,EAAf,EAAmBhC,QAAnB,EAAZ;AACA,QAAIY,MAAM,GAAGmB,OAAO,CAACnB,MAArB;AAGA,QAAIV,KAAK,GAAG6B,OAAO,CAAC7B,KAAR,IAAiB,IAA7B;;AACA,QAAIU,MAAM,IAAIA,MAAM,CAACqB,SAArB,EAAgC;AAC9B,UAAI1B,OAAO,GAAIK,MAAM,CAACA,MAAP,KAAkBA,MAAM,CAACA,MAAP,CAAcS,KAAd,IAAuBT,MAAM,CAACA,MAAP,CAAcsB,WAAvD,CAAD,GACTtB,MAAM,CAACA,MAAP,CAAcS,KAAd,IAAuBT,MAAM,CAACA,MAAP,CAAcsB,WAD5B,GAEV,yCAFJ;AAGAhC,MAAAA,KAAK,GAAG,IAAII,KAAJ,CAAUC,OAAV,CAAR;AACD;;AAED,QAAIL,KAAJ,EAAW;AACT,UAAI,KAAKvB,eAAL,CAAqB8B,KAArB,CAAJ,EAAiC;AAC/B,aAAKhD,aAAL,CAAmBgD,KAAnB,EAA0BP,KAA1B;AACD,OAFD,MAEO;AACLd,wBAAIc,KAAJ,CAAW,4CAA2CA,KAAM,EAA5D;;AACAd,wBAAIc,KAAJ,CAAU,oCAAV;AACD;;AAGD;AACD;;AAED,QAAIQ,MAAM,GAAGqB,OAAO,CAACrB,MAArB;AACA,QAAIC,MAAJ;;AACA,QAAI,KAAKpD,aAAT,EAAwB;AACtB,UAAImD,MAAM,KAAK,sBAAf,EAAuC;AAGrC,cAAMyB,GAAG,GAAGlD,KAAK,CAACa,UAAN,CAAiBsC,2BAA7B;AACA,cAAMC,UAAU,GAAGN,OAAO,CAACpB,MAAR,CAAe0B,UAAlC;AACA,cAAM,KAAK/E,eAAL,CAAqBgF,aAArB,CAAmCH,GAAnC,EAAwCE,UAAxC,CAAN;AACA;AACD;;AAAC,UAAI3B,MAAM,KAAK,wBAAf,EAAyC;AACzC,cAAMyB,GAAG,GAAGlD,KAAK,CAACa,UAAN,CAAiBsC,2BAA7B;AACA,cAAMC,UAAU,GAAGN,OAAO,CAACpB,MAAR,CAAe0B,UAAlC;AACA,cAAM,KAAK/E,eAAL,CAAqBiF,eAArB,CAAqCJ,GAArC,EAA0CE,UAA1C,CAAN;AACA;AACD,OALC,MAKK,IAAIN,OAAO,CAACrB,MAAR,KAAmB,kCAAvB,EAA2D;AAGhE;AACD;;AAGD,UAAIH,OAAJ;;AACA,UAAI;AACFA,QAAAA,OAAO,GAAGX,IAAI,CAACC,KAAL,CAAWkC,OAAO,CAACpB,MAAR,CAAeJ,OAA1B,CAAV;AACAE,QAAAA,KAAK,GAAGF,OAAO,CAACyB,EAAhB;AACAtB,QAAAA,MAAM,GAAGH,OAAO,CAACG,MAAjB;AACAE,QAAAA,MAAM,GAAGL,OAAO,CAACK,MAAR,IAAkBL,OAA3B;AACAI,QAAAA,MAAM,GAAGC,MAAM,CAACD,MAAhB;AACD,OAND,CAME,OAAOV,GAAP,EAAY;AAGZb,wBAAIc,KAAJ,CAAW,+CAAX;;AACA,aAAKoB,cAAL,CAAoBrC,KAApB;AACA,cAAMgB,GAAN;AACD;AACF,KAlCD,MAkCO;AACLU,MAAAA,MAAM,GAAGoB,OAAO,CAACpB,MAAjB;AACD;;AAED,QAAI,CAACjD,gBAAEmD,OAAF,CAAUJ,KAAV,CAAL,EAAuB;AACrBrB,sBAAIC,KAAJ,CAAW,kCAAiCoB,KAAM,GAAlD;AACD;;AAED,UAAM,KAAKD,mBAAL,CAAyBC,KAAzB,EAAgCC,MAAhC,EAAwCC,MAAxC,EAAgDC,MAAhD,EAAwDV,KAAxD,CAAN;AACD;;AAED1C,EAAAA,WAAW,GAAI;AACb,SAAK8B,QAAL,GAAgB;AACd,2BAAqB,MAAOL,KAAP,IAAiB;AACpC,cAAM,KAAKM,oBAAL,CAA0B,wBAA1B,EACJN,KAAK,CAACa,UAAN,CAAiB0C,mBADb,EAEJvD,KAAK,CAACa,UAAN,CAAiB2C,oBAFb,EAGJxD,KAAK,CAACa,UAAN,CAAiB4C,6BAHb,CAAN;AAID,OANa;AAOd,8CAAwC,MAAOzD,KAAP,IAAiB;AACvD,cAAM,KAAKM,oBAAL,CAA0B,sCAA1B,EACJN,KAAK,CAACa,UAAN,CAAiB6C,2BADb,CAAN;AAED,OAVa;AAWd,sCAAgC,MAAO1D,KAAP,IAAiB;AAC/C,cAAM,KAAKM,oBAAL,CAA0B,yBAA1B,EACJN,KAAK,CAACa,UAAN,CAAiBsC,2BADb,EAEJnD,KAAK,CAACa,UAAN,CAAiB8C,aAFb,CAAN;AAGD,OAfa;AAgBd,oCAA8B,MAAO3D,KAAP,IAAiB;AAC7C,cAAM,KAAKM,oBAAL,CAA0B,4BAA1B,EACJN,KAAK,CAACa,UADF,CAAN;AAED,OAnBa;AAoBd,uCAAiC,MAAOb,KAAP,IAAiB;AAChD,cAAM,KAAKM,oBAAL,CAA0B,+BAA1B,EACJN,KAAK,CAACa,UADF,CAAN;AAED,OAvBa;AAwBd,kCAA4B,MAAOb,KAAP,IAAiB;AAC3C,cAAM,KAAKM,oBAAL,CAA0B,0BAA1B,EACJN,KAAK,CAACa,UADF,CAAN;AAED,OA3Ba;AA4Bd,yCAAmC,MAAOb,KAAP,IAAiB;AAClD,cAAM,KAAKM,oBAAL,CAA0B,iCAA1B,EACJN,KAAK,CAACa,UADF,CAAN;AAED,OA/Ba;AAgCd,mCAA6B,MAAOb,KAAP,IAAiB;AAC5C,cAAM,KAAK6C,iBAAL,CAAuB7C,KAAvB,CAAN;AACD;AAlCa,KAAhB;AAoCD;;AAhRoC","sourcesContent":["import log from './logger';\nimport _ from 'lodash';\n\n\n// we will receive events that we do not listen to.\n// if we start to listen to one of these, remove it from the list\nconst IGNORED_EVENTS = [\n  'Page.defaultAppearanceDidChange',\n  'Page.domContentEventFired',\n  'Page.frameStartedLoading',\n  'Page.frameStoppedLoading',\n  'Page.frameScheduledNavigation',\n  'Page.frameClearedScheduledNavigation',\n  'Console.messagesCleared',\n];\n\nexport default class RpcMessageHandler {\n  constructor (specialHandlers, isTargetBased = false) {\n    this.setHandlers();\n    this.errorHandlers = {};\n    this.specialHandlers = _.clone(specialHandlers);\n    this.dataHandlers = {};\n    this.willNavigateWithoutReload = false;\n\n    this.isTargetBased = isTargetBased;\n  }\n\n  setCommunicationProtocol (isTargetBased) {\n    this.isTargetBased = isTargetBased;\n  }\n\n  setDataMessageHandler (key, errorHandler, handler) {\n    this.errorHandlers[key] = errorHandler;\n    this.dataHandlers[key] = handler;\n  }\n\n  setSpecialMessageHandler (key, errorHandler, handler) {\n    this.errorHandlers[key] = errorHandler;\n    this.specialHandlers[key] = handler;\n  }\n\n  getSpecialMessageHandler (key) {\n    return this.specialHandlers[key];\n  }\n\n  setTimelineEventHandler (timelineEventHandler) {\n    this.timelineEventHandler = timelineEventHandler;\n  }\n\n  setConsoleLogEventHandler (consoleLogEventHandler) {\n    this.consoleLogEventHandler = consoleLogEventHandler;\n  }\n\n  setNetworkEventHandler (networkLogEventHandler) {\n    this.networkLogEventHandler = networkLogEventHandler;\n  }\n\n  hasErrorHandler (key) {\n    return _.has(this.errorHandlers, key);\n  }\n\n  hasSpecialMessageHandler (key) {\n    return _.has(this.specialHandlers, key);\n  }\n\n  allowNavigationWithoutReload (allow = true) {\n    this.willNavigateWithoutReload = allow;\n  }\n\n  async handleMessage (plist) {\n    const selector = plist.__selector;\n    if (!selector) {\n      log.debug('Got an invalid plist');\n      return;\n    }\n\n    if (_.has(this.handlers, selector)) {\n      await this.handlers[selector](plist);\n    } else {\n      log.debug(`Debugger got a message for '${selector}' and have no ` +\n                `handler, doing nothing.`);\n    }\n  }\n\n  async handleSpecialMessage (handler, ...args) {\n    const fn = this.specialHandlers[handler];\n\n    if (fn) {\n      // most responses are only to be called once, then\n      // removed. But not the ones below, which handle\n      // page change and app connect/disconnect\n      if (handler !== '_rpc_forwardGetListing:' &&\n          handler !== '_rpc_applicationDisconnected:' &&\n          handler !== '_rpc_applicationConnected:' &&\n          handler !== '_rpc_applicationUpdated:' &&\n          handler !== '_rpc_reportConnectedDriverList:') {\n        this.specialHandlers[handler] = null;\n      }\n      await fn(...args);\n    } else {\n      log.warn(`Tried to access special message handler '${handler}' ` +\n               `but none was found`);\n    }\n  }\n\n  parseDataKey (plist) {\n    try {\n      return JSON.parse(plist.__argument.WIRMessageDataKey.toString('utf8'));\n    } catch (err) {\n      log.error(`Unparseable message data: ${_.truncate(JSON.stringify(plist), {length: 100})}`);\n      throw new Error(`Unable to parse message data: ${err.message}`);\n    }\n  }\n\n  async dispatchDataMessage (msgId, method, params, result, error) {\n    if (!_.isEmpty(msgId)) {\n      log.debug(`Handling message (id: '${msgId}')`);\n    }\n    if (method === 'Profiler.resetProfiles') {\n      log.debug('Device is telling us to reset profiles. Should probably ' +\n                'do some kind of callback here');\n    } else if (method === 'Page.frameNavigated') {\n      if (!this.willNavigateWithoutReload && !this.pageLoading) {\n        if (_.isFunction(this.specialHandlers['Page.frameNavigated'])) {\n          await this.specialHandlers['Page.frameNavigated']('remote-debugger');\n          this.specialHandlers['Page.frameNavigated'] = null;\n        }\n      } else {\n        log.debug('Frame navigated but we were warned about it, not ' +\n                  'considering page state unloaded');\n        this.willNavigateWithoutReload = false;\n      }\n    } else if (IGNORED_EVENTS.includes(method)) {\n      // pass\n    } else if (method === 'Page.loadEventFired' && _.isFunction(this.specialHandlers.pageLoad)) {\n      await this.specialHandlers.pageLoad();\n    } else if (method === 'Page.frameDetached' && _.isFunction(this.specialHandlers.frameDetached)) {\n      await this.specialHandlers.frameDetached();\n    } else if (method === 'Timeline.eventRecorded' && _.isFunction(this.timelineEventHandler)) {\n      this.timelineEventHandler(params || params.record);\n    } else if (method === 'Console.messageAdded' && _.isFunction(this.consoleLogEventHandler)) {\n      this.consoleLogEventHandler(params.message);\n    } else if (method && method.startsWith('Network.') && _.isFunction(this.networkLogEventHandler)) {\n      this.networkLogEventHandler(method, params);\n    } else if (_.isFunction(this.dataHandlers[msgId])) {\n      // we will either get back a result object that has a result.value\n      // in which case that is what we want,\n      // or else we return the whole thing\n      if (result.result && result.result.value) {\n        result = result.result.value;\n      }\n      this.dataHandlers[msgId](result);\n      this.dataHandlers[msgId] = null;\n    } else if (this.dataHandlers[msgId] === null) {\n      log.error(`Debugger returned data for message ${msgId} ` +\n                `but we already ran that callback! WTF??`);\n    } else {\n      if (msgId || result || error) {\n        log.error(`Debugger returned data for message '${msgId}' ` +\n                  `but we were not waiting for that message! ` +\n                  `result: '${JSON.stringify(result)}'; ` +\n                  `error: '${error}'`);\n      }\n    }\n  }\n\n  logFullMessage (plist) {\n    // Buffers cannot be serialized in a readable way\n    const bufferToJSON = Buffer.prototype.toJSON;\n    delete Buffer.prototype.toJSON;\n    try {\n      log(JSON.stringify(plist, (k, v) => Buffer.isBuffer(v) ? v.toString('utf8') : v, 2));\n    } finally {\n      // restore the function, so as to not break further serialization\n      Buffer.prototype.toJSON = bufferToJSON;\n    }\n  }\n\n  async handleDataMessage (plist) {\n    const dataKey = this.parseDataKey(plist);\n    let msgId = (dataKey.id || '').toString();\n    let result = dataKey.result;\n\n    // we can get an error, or we can get a response that is an error\n    let error = dataKey.error || null;\n    if (result && result.wasThrown) {\n      let message = (result.result && (result.result.value || result.result.description))\n        ? (result.result.value || result.result.description)\n        : 'Error occurred in handling data message';\n      error = new Error(message);\n    }\n\n    if (error) {\n      if (this.hasErrorHandler(msgId)) {\n        this.errorHandlers[msgId](error);\n      } else {\n        log.error(`Error occurred in handling data message: ${error}`);\n        log.error('No error handler present, ignoring');\n      }\n\n      // short circuit\n      return;\n    }\n\n    let method = dataKey.method;\n    let params;\n    if (this.isTargetBased) {\n      if (method === 'Target.targetCreated') {\n        // this is in response to a `_rpc_forwardSocketSetup:` call\n        // targetInfo: { targetId: 'page-1', type: 'page' }\n        const app = plist.__argument.WIRApplicationIdentifierKey;\n        const targetInfo = dataKey.params.targetInfo;\n        await this.specialHandlers.targetCreated(app, targetInfo);\n        return;\n      } if (method === 'Target.targetDestroyed') {\n        const app = plist.__argument.WIRApplicationIdentifierKey;\n        const targetInfo = dataKey.params.targetInfo;\n        await this.specialHandlers.targetDestroyed(app, targetInfo);\n        return;\n      } else if (dataKey.method !== 'Target.dispatchMessageFromTarget') {\n        // this sort of message, at this point, is just an acknowledgement\n        // that the original message was received\n        return;\n      }\n\n      // at this point, we have a Target-based message wrapping a protocol message\n      let message;\n      try {\n        message = JSON.parse(dataKey.params.message);\n        msgId = message.id;\n        method = message.method;\n        result = message.result || message;\n        params = result.params;\n      } catch (err) {\n        // if this happens then some aspect of the protocol is missing to us\n        // so print the entire message to get visibiity into what is going on\n        log.error(`Unexpected message format from Web Inspector:`);\n        this.logFullMessage(plist);\n        throw err;\n      }\n    } else {\n      params = dataKey.params;\n    }\n\n    if (!_.isEmpty(msgId)) {\n      log.debug(`Received response for message '${msgId}'`);\n    }\n\n    await this.dispatchDataMessage(msgId, method, params, result, error);\n  }\n\n  setHandlers () {\n    this.handlers = {\n      '_rpc_reportSetup:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_reportIdentifier:',\n          plist.__argument.WIRSimulatorNameKey,\n          plist.__argument.WIRSimulatorBuildKey,\n          plist.__argument.WIRSimulatorProductVersionKey);\n      },\n      '_rpc_reportConnectedApplicationList:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_reportConnectedApplicationList:',\n          plist.__argument.WIRApplicationDictionaryKey);\n      },\n      '_rpc_applicationSentListing:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_forwardGetListing:',\n          plist.__argument.WIRApplicationIdentifierKey,\n          plist.__argument.WIRListingKey);\n      },\n      '_rpc_applicationConnected:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_applicationConnected:',\n          plist.__argument);\n      },\n      '_rpc_applicationDisconnected:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_applicationDisconnected:',\n          plist.__argument);\n      },\n      '_rpc_applicationUpdated:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_applicationUpdated:',\n          plist.__argument);\n      },\n      '_rpc_reportConnectedDriverList:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_reportConnectedDriverList:',\n          plist.__argument);\n      },\n      '_rpc_applicationSentData:': async (plist) => {\n        await this.handleDataMessage(plist);\n      },\n    };\n  }\n}\n"],"file":"lib/remote-debugger-message-handler.js","sourceRoot":"../.."}
267
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/remote-debugger-message-handler.js"],"names":["IGNORED_EVENTS","RpcMessageHandler","constructor","specialHandlers","isTargetBased","setHandlers","errorHandlers","_","clone","dataHandlers","willNavigateWithoutReload","setCommunicationProtocol","setDataMessageHandler","key","errorHandler","handler","setSpecialMessageHandler","getSpecialMessageHandler","setTimelineEventHandler","timelineEventHandler","setConsoleLogEventHandler","consoleLogEventHandler","setNetworkEventHandler","networkLogEventHandler","hasErrorHandler","has","hasSpecialMessageHandler","allowNavigationWithoutReload","allow","handleMessage","plist","selector","__selector","log","debug","handlers","handleSpecialMessage","args","fn","warn","parseDataKey","JSON","parse","__argument","WIRMessageDataKey","toString","err","error","truncate","stringify","length","Error","message","dispatchDataMessage","msgId","method","params","result","isEmpty","pageLoading","isFunction","includes","pageLoad","frameDetached","record","startsWith","value","logFullMessage","bufferToJSON","Buffer","prototype","toJSON","k","v","isBuffer","handleDataMessage","dataKey","id","app","WIRApplicationIdentifierKey","targetInfo","targetCreated","targetDestroyed","wasThrown","description","WIRSimulatorNameKey","WIRSimulatorBuildKey","WIRSimulatorProductVersionKey","WIRApplicationDictionaryKey","WIRListingKey"],"mappings":"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","sourcesContent":["import log from './logger';\nimport _ from 'lodash';\n\n\n// we will receive events that we do not listen to.\n// if we start to listen to one of these, remove it from the list\nconst IGNORED_EVENTS = [\n  'Page.defaultAppearanceDidChange',\n  'Page.domContentEventFired',\n  'Page.frameStartedLoading',\n  'Page.frameStoppedLoading',\n  'Page.frameScheduledNavigation',\n  'Page.frameClearedScheduledNavigation',\n  'Console.messagesCleared',\n];\n\nexport default class RpcMessageHandler {\n  constructor (specialHandlers, isTargetBased = false) {\n    this.setHandlers();\n    this.errorHandlers = {};\n    this.specialHandlers = _.clone(specialHandlers);\n    this.dataHandlers = {};\n    this.willNavigateWithoutReload = false;\n\n    this.isTargetBased = isTargetBased;\n  }\n\n  setCommunicationProtocol (isTargetBased) {\n    this.isTargetBased = isTargetBased;\n  }\n\n  setDataMessageHandler (key, errorHandler, handler) {\n    this.errorHandlers[key] = errorHandler;\n    this.dataHandlers[key] = handler;\n  }\n\n  setSpecialMessageHandler (key, errorHandler, handler) {\n    this.errorHandlers[key] = errorHandler;\n    this.specialHandlers[key] = handler;\n  }\n\n  getSpecialMessageHandler (key) {\n    return this.specialHandlers[key];\n  }\n\n  setTimelineEventHandler (timelineEventHandler) {\n    this.timelineEventHandler = timelineEventHandler;\n  }\n\n  setConsoleLogEventHandler (consoleLogEventHandler) {\n    this.consoleLogEventHandler = consoleLogEventHandler;\n  }\n\n  setNetworkEventHandler (networkLogEventHandler) {\n    this.networkLogEventHandler = networkLogEventHandler;\n  }\n\n  hasErrorHandler (key) {\n    return _.has(this.errorHandlers, key);\n  }\n\n  hasSpecialMessageHandler (key) {\n    return _.has(this.specialHandlers, key);\n  }\n\n  allowNavigationWithoutReload (allow = true) {\n    this.willNavigateWithoutReload = allow;\n  }\n\n  async handleMessage (plist) {\n    const selector = plist.__selector;\n    if (!selector) {\n      log.debug('Got an invalid plist');\n      return;\n    }\n\n    if (_.has(this.handlers, selector)) {\n      await this.handlers[selector](plist);\n    } else {\n      log.debug(`Debugger got a message for '${selector}' and have no ` +\n                `handler, doing nothing.`);\n    }\n  }\n\n  async handleSpecialMessage (handler, ...args) {\n    const fn = this.specialHandlers[handler];\n\n    if (fn) {\n      // most responses are only to be called once, then\n      // removed. But not the ones below, which handle\n      // page change and app connect/disconnect\n      if (handler !== '_rpc_forwardGetListing:' &&\n          handler !== '_rpc_applicationDisconnected:' &&\n          handler !== '_rpc_applicationConnected:' &&\n          handler !== '_rpc_applicationUpdated:' &&\n          handler !== '_rpc_reportConnectedDriverList:') {\n        this.specialHandlers[handler] = null;\n      }\n      await fn(...args);\n    } else {\n      log.warn(`Tried to access special message handler '${handler}' ` +\n               `but none was found`);\n    }\n  }\n\n  parseDataKey (plist) {\n    try {\n      return JSON.parse(plist.__argument.WIRMessageDataKey.toString('utf8'));\n    } catch (err) {\n      log.error(`Unparseable message data: ${_.truncate(JSON.stringify(plist), {length: 100})}`);\n      throw new Error(`Unable to parse message data: ${err.message}`);\n    }\n  }\n\n  async dispatchDataMessage (msgId, method, params, result, error) {\n    if (!_.isEmpty(msgId)) {\n      log.debug(`Handling message (id: '${msgId}')`);\n    }\n    if (method === 'Profiler.resetProfiles') {\n      log.debug('Device is telling us to reset profiles. Should probably ' +\n                'do some kind of callback here');\n    } else if (method === 'Page.frameNavigated') {\n      if (!this.willNavigateWithoutReload && !this.pageLoading) {\n        if (_.isFunction(this.specialHandlers['Page.frameNavigated'])) {\n          await this.specialHandlers['Page.frameNavigated']('remote-debugger');\n          this.specialHandlers['Page.frameNavigated'] = null;\n        }\n      } else {\n        log.debug('Frame navigated but we were warned about it, not ' +\n                  'considering page state unloaded');\n        this.willNavigateWithoutReload = false;\n      }\n    } else if (IGNORED_EVENTS.includes(method)) {\n      // pass\n    } else if (method === 'Page.loadEventFired' && _.isFunction(this.specialHandlers.pageLoad)) {\n      await this.specialHandlers.pageLoad();\n    } else if (method === 'Page.frameDetached' && _.isFunction(this.specialHandlers.frameDetached)) {\n      await this.specialHandlers.frameDetached();\n    } else if (method === 'Timeline.eventRecorded' && _.isFunction(this.timelineEventHandler)) {\n      this.timelineEventHandler(params || params.record);\n    } else if (method === 'Console.messageAdded' && _.isFunction(this.consoleLogEventHandler)) {\n      this.consoleLogEventHandler(params.message);\n    } else if (method && method.startsWith('Network.') && _.isFunction(this.networkLogEventHandler)) {\n      this.networkLogEventHandler(method, params);\n    } else if (_.isFunction(this.dataHandlers[msgId])) {\n      // we will either get back a result object that has a result.value\n      // in which case that is what we want,\n      // or else we return the whole thing\n      if (result.result && result.result.value) {\n        result = result.result.value;\n      }\n      this.dataHandlers[msgId](result);\n      this.dataHandlers[msgId] = null;\n    } else if (this.dataHandlers[msgId] === null) {\n      log.error(`Debugger returned data for message ${msgId} ` +\n                `but we already ran that callback! WTF??`);\n    } else {\n      if (msgId || result || error) {\n        log.error(`Debugger returned data for message '${msgId}' ` +\n                  `but we were not waiting for that message! ` +\n                  `result: '${JSON.stringify(result)}'; ` +\n                  `error: '${error}'`);\n      }\n    }\n  }\n\n  logFullMessage (plist) {\n    // Buffers cannot be serialized in a readable way\n    const bufferToJSON = Buffer.prototype.toJSON;\n    delete Buffer.prototype.toJSON;\n    try {\n      log(JSON.stringify(plist, (k, v) => Buffer.isBuffer(v) ? v.toString('utf8') : v, 2));\n    } finally {\n      // restore the function, so as to not break further serialization\n      Buffer.prototype.toJSON = bufferToJSON;\n    }\n  }\n\n  async handleDataMessage (plist) {\n    const dataKey = this.parseDataKey(plist);\n    let msgId = (dataKey.id || '').toString();\n    let result = dataKey.result;\n\n    let method = dataKey.method;\n    let params;\n    if (this.isTargetBased) {\n      if (method === 'Target.targetCreated') {\n        // this is in response to a `_rpc_forwardSocketSetup:` call\n        // targetInfo: { targetId: 'page-1', type: 'page' }\n        const app = plist.__argument.WIRApplicationIdentifierKey;\n        const targetInfo = dataKey.params.targetInfo;\n        await this.specialHandlers.targetCreated(app, targetInfo);\n        return;\n      } if (method === 'Target.targetDestroyed') {\n        const app = plist.__argument.WIRApplicationIdentifierKey;\n        const targetInfo = dataKey.params.targetInfo;\n        await this.specialHandlers.targetDestroyed(app, targetInfo);\n        return;\n      } else if (dataKey.method !== 'Target.dispatchMessageFromTarget') {\n        // this sort of message, at this point, is just an acknowledgement\n        // that the original message was received\n        return;\n      }\n\n      // at this point, we have a Target-based message wrapping a protocol message\n      let message;\n      try {\n        message = JSON.parse(dataKey.params.message);\n        msgId = message.id;\n        method = message.method;\n        result = message.result || message;\n        params = result.params;\n      } catch (err) {\n        // if this happens then some aspect of the protocol is missing to us\n        // so print the entire message to get visibiity into what is going on\n        log.error(`Unexpected message format from Web Inspector:`);\n        this.logFullMessage(plist);\n        throw err;\n      }\n    } else {\n      params = dataKey.params;\n    }\n\n    // we can get an error, or we can get a response that is an error\n    let error = dataKey.error || null;\n    if (result && result.wasThrown) {\n      const message = (result.result && (result.result.value || result.result.description))\n        ? (result.result.value || result.result.description)\n        : 'Error occurred in handling data message';\n      error = new Error(message);\n    }\n\n    if (!error) {\n      if (!_.isEmpty(msgId)) {\n        log.debug(`Received response for message '${msgId}'`);\n      }\n\n      return await this.dispatchDataMessage(msgId, method, params, result, error);\n    }\n\n    // handle the error\n    if (this.hasErrorHandler(msgId)) {\n      this.errorHandlers[msgId](error);\n    } else {\n      log.error(`Error occurred in handling data message: ${error}`);\n      log.error('No error handler present, ignoring');\n    }\n  }\n\n  setHandlers () {\n    this.handlers = {\n      '_rpc_reportSetup:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_reportIdentifier:',\n          plist.__argument.WIRSimulatorNameKey,\n          plist.__argument.WIRSimulatorBuildKey,\n          plist.__argument.WIRSimulatorProductVersionKey);\n      },\n      '_rpc_reportConnectedApplicationList:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_reportConnectedApplicationList:',\n          plist.__argument.WIRApplicationDictionaryKey);\n      },\n      '_rpc_applicationSentListing:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_forwardGetListing:',\n          plist.__argument.WIRApplicationIdentifierKey,\n          plist.__argument.WIRListingKey);\n      },\n      '_rpc_applicationConnected:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_applicationConnected:',\n          plist.__argument);\n      },\n      '_rpc_applicationDisconnected:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_applicationDisconnected:',\n          plist.__argument);\n      },\n      '_rpc_applicationUpdated:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_applicationUpdated:',\n          plist.__argument);\n      },\n      '_rpc_reportConnectedDriverList:': async (plist) => {\n        await this.handleSpecialMessage('_rpc_reportConnectedDriverList:',\n          plist.__argument);\n      },\n      '_rpc_applicationSentData:': async (plist) => {\n        await this.handleDataMessage(plist);\n      },\n    };\n  }\n}\n"],"file":"lib/remote-debugger-message-handler.js","sourceRoot":"../.."}
@@ -25,6 +25,7 @@ class RemoteDebuggerRealDevice extends _remoteDebugger.RemoteDebugger {
25
25
  async connect() {
26
26
  this.setup();
27
27
  this.rpcClient = new _rpcClientRealDevice.default({
28
+ bundleId: this.bundleId,
28
29
  platformVersion: this.platformVersion,
29
30
  isSafari: this.isSafari,
30
31
  host: this.host,
@@ -54,4 +55,4 @@ class RemoteDebuggerRealDevice extends _remoteDebugger.RemoteDebugger {
54
55
  exports.default = RemoteDebuggerRealDevice;require('source-map-support').install();
55
56
 
56
57
 
57
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9yZW1vdGUtZGVidWdnZXItcmVhbC1kZXZpY2UuanMiXSwibmFtZXMiOlsiUmVtb3RlRGVidWdnZXJSZWFsRGV2aWNlIiwiUmVtb3RlRGVidWdnZXIiLCJjb25zdHJ1Y3RvciIsIm9wdHMiLCJ1ZGlkIiwic2tpcHBlZEFwcHMiLCJjb25uZWN0Iiwic2V0dXAiLCJycGNDbGllbnQiLCJScGNDbGllbnRSZWFsRGV2aWNlIiwicGxhdGZvcm1WZXJzaW9uIiwiaXNTYWZhcmkiLCJob3N0IiwicG9ydCIsInNvY2tldFBhdGgiLCJzcGVjaWFsTWVzc2FnZUhhbmRsZXJzIiwic3BlY2lhbENicyIsIm1lc3NhZ2VQcm94eSIsInJlbW90ZURlYnVnUHJveHkiLCJsb2dGdWxsUmVzcG9uc2UiLCJhcHBJbmZvIiwic2V0Q29ubmVjdGlvbktleSIsImxvZyIsImRlYnVnIiwiZXJyIiwiZGlzY29ubmVjdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFHZSxNQUFNQSx3QkFBTixTQUF1Q0MsOEJBQXZDLENBQXNEO0FBQ25FQyxFQUFBQSxXQUFXLENBQUVDLElBQUksR0FBRyxFQUFULEVBQWE7QUFDdEIsVUFBTUEsSUFBTjtBQUVBLFNBQUtDLElBQUwsR0FBWUQsSUFBSSxDQUFDQyxJQUFqQjtBQUVBLFNBQUtDLFdBQUwsR0FBbUIsQ0FBQyxXQUFELENBQW5CO0FBQ0Q7O0FBRUQsUUFBTUMsT0FBTixHQUFpQjtBQUNmLFNBQUtDLEtBQUw7QUFHQSxTQUFLQyxTQUFMLEdBQWlCLElBQUlDLDRCQUFKLENBQXdCO0FBQ3ZDQyxNQUFBQSxlQUFlLEVBQUUsS0FBS0EsZUFEaUI7QUFFdkNDLE1BQUFBLFFBQVEsRUFBRSxLQUFLQSxRQUZ3QjtBQUd2Q0MsTUFBQUEsSUFBSSxFQUFFLEtBQUtBLElBSDRCO0FBSXZDQyxNQUFBQSxJQUFJLEVBQUUsS0FBS0EsSUFKNEI7QUFLdkNDLE1BQUFBLFVBQVUsRUFBRSxLQUFLQSxVQUxzQjtBQU12Q0MsTUFBQUEsc0JBQXNCLEVBQUUsS0FBS0MsVUFOVTtBQU92Q0MsTUFBQUEsWUFBWSxFQUFFLEtBQUtDLGdCQVBvQjtBQVF2Q0MsTUFBQUEsZUFBZSxFQUFFLEtBQUtBLGVBUmlCO0FBU3ZDZixNQUFBQSxJQUFJLEVBQUUsS0FBS0E7QUFUNEIsS0FBeEIsQ0FBakI7QUFXQSxVQUFNLEtBQUtJLFNBQUwsQ0FBZUYsT0FBZixFQUFOOztBQUdBLFFBQUk7QUFDRixZQUFNYyxPQUFPLEdBQUcsTUFBTSxLQUFLQyxnQkFBTCxFQUF0Qjs7QUFDQUMsc0JBQUlDLEtBQUosQ0FBVSwwQkFBVjs7QUFDQSxhQUFPSCxPQUFQO0FBQ0QsS0FKRCxDQUlFLE9BQU9JLEdBQVAsRUFBWTtBQUNaLFlBQU0sS0FBS0MsVUFBTCxFQUFOO0FBQ0EsYUFBTyxJQUFQO0FBQ0Q7QUFDRjs7QUFuQ2tFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGxvZyBmcm9tICcuL2xvZ2dlcic7XG5pbXBvcnQgeyBSZW1vdGVEZWJ1Z2dlciB9IGZyb20gJy4vcmVtb3RlLWRlYnVnZ2VyJztcbmltcG9ydCBScGNDbGllbnRSZWFsRGV2aWNlIGZyb20gJy4vcnBjLWNsaWVudC1yZWFsLWRldmljZSc7XG5cblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgUmVtb3RlRGVidWdnZXJSZWFsRGV2aWNlIGV4dGVuZHMgUmVtb3RlRGVidWdnZXIge1xuICBjb25zdHJ1Y3RvciAob3B0cyA9IHt9KSB7XG4gICAgc3VwZXIob3B0cyk7XG5cbiAgICB0aGlzLnVkaWQgPSBvcHRzLnVkaWQ7XG5cbiAgICB0aGlzLnNraXBwZWRBcHBzID0gWydsb2NrZG93bmQnXTtcbiAgfVxuXG4gIGFzeW5jIGNvbm5lY3QgKCkge1xuICAgIHRoaXMuc2V0dXAoKTtcblxuICAgIC8vIGluaXRpYWxpemUgdGhlIHJwYyBjbGllbnRcbiAgICB0aGlzLnJwY0NsaWVudCA9IG5ldyBScGNDbGllbnRSZWFsRGV2aWNlKHtcbiAgICAgIHBsYXRmb3JtVmVyc2lvbjogdGhpcy5wbGF0Zm9ybVZlcnNpb24sXG4gICAgICBpc1NhZmFyaTogdGhpcy5pc1NhZmFyaSxcbiAgICAgIGhvc3Q6IHRoaXMuaG9zdCxcbiAgICAgIHBvcnQ6IHRoaXMucG9ydCxcbiAgICAgIHNvY2tldFBhdGg6IHRoaXMuc29ja2V0UGF0aCxcbiAgICAgIHNwZWNpYWxNZXNzYWdlSGFuZGxlcnM6IHRoaXMuc3BlY2lhbENicyxcbiAgICAgIG1lc3NhZ2VQcm94eTogdGhpcy5yZW1vdGVEZWJ1Z1Byb3h5LFxuICAgICAgbG9nRnVsbFJlc3BvbnNlOiB0aGlzLmxvZ0Z1bGxSZXNwb25zZSxcbiAgICAgIHVkaWQ6IHRoaXMudWRpZFxuICAgIH0pO1xuICAgIGF3YWl0IHRoaXMucnBjQ2xpZW50LmNvbm5lY3QoKTtcblxuICAgIC8vIGdldCB0aGUgY29ubmVjdGlvbiBpbmZvcm1hdGlvbiBhYm91dCB0aGUgYXBwXG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IGFwcEluZm8gPSBhd2FpdCB0aGlzLnNldENvbm5lY3Rpb25LZXkoKTtcbiAgICAgIGxvZy5kZWJ1ZygnQ29ubmVjdGVkIHRvIGFwcGxpY2F0aW9uJyk7XG4gICAgICByZXR1cm4gYXBwSW5mbztcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIGF3YWl0IHRoaXMuZGlzY29ubmVjdCgpO1xuICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuICB9XG59XG4iXSwiZmlsZSI6ImxpYi9yZW1vdGUtZGVidWdnZXItcmVhbC1kZXZpY2UuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
58
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9yZW1vdGUtZGVidWdnZXItcmVhbC1kZXZpY2UuanMiXSwibmFtZXMiOlsiUmVtb3RlRGVidWdnZXJSZWFsRGV2aWNlIiwiUmVtb3RlRGVidWdnZXIiLCJjb25zdHJ1Y3RvciIsIm9wdHMiLCJ1ZGlkIiwic2tpcHBlZEFwcHMiLCJjb25uZWN0Iiwic2V0dXAiLCJycGNDbGllbnQiLCJScGNDbGllbnRSZWFsRGV2aWNlIiwiYnVuZGxlSWQiLCJwbGF0Zm9ybVZlcnNpb24iLCJpc1NhZmFyaSIsImhvc3QiLCJwb3J0Iiwic29ja2V0UGF0aCIsInNwZWNpYWxNZXNzYWdlSGFuZGxlcnMiLCJzcGVjaWFsQ2JzIiwibWVzc2FnZVByb3h5IiwicmVtb3RlRGVidWdQcm94eSIsImxvZ0Z1bGxSZXNwb25zZSIsImFwcEluZm8iLCJzZXRDb25uZWN0aW9uS2V5IiwibG9nIiwiZGVidWciLCJlcnIiLCJkaXNjb25uZWN0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUdlLE1BQU1BLHdCQUFOLFNBQXVDQyw4QkFBdkMsQ0FBc0Q7QUFDbkVDLEVBQUFBLFdBQVcsQ0FBRUMsSUFBSSxHQUFHLEVBQVQsRUFBYTtBQUN0QixVQUFNQSxJQUFOO0FBRUEsU0FBS0MsSUFBTCxHQUFZRCxJQUFJLENBQUNDLElBQWpCO0FBRUEsU0FBS0MsV0FBTCxHQUFtQixDQUFDLFdBQUQsQ0FBbkI7QUFDRDs7QUFFRCxRQUFNQyxPQUFOLEdBQWlCO0FBQ2YsU0FBS0MsS0FBTDtBQUdBLFNBQUtDLFNBQUwsR0FBaUIsSUFBSUMsNEJBQUosQ0FBd0I7QUFDdkNDLE1BQUFBLFFBQVEsRUFBRSxLQUFLQSxRQUR3QjtBQUV2Q0MsTUFBQUEsZUFBZSxFQUFFLEtBQUtBLGVBRmlCO0FBR3ZDQyxNQUFBQSxRQUFRLEVBQUUsS0FBS0EsUUFId0I7QUFJdkNDLE1BQUFBLElBQUksRUFBRSxLQUFLQSxJQUo0QjtBQUt2Q0MsTUFBQUEsSUFBSSxFQUFFLEtBQUtBLElBTDRCO0FBTXZDQyxNQUFBQSxVQUFVLEVBQUUsS0FBS0EsVUFOc0I7QUFPdkNDLE1BQUFBLHNCQUFzQixFQUFFLEtBQUtDLFVBUFU7QUFRdkNDLE1BQUFBLFlBQVksRUFBRSxLQUFLQyxnQkFSb0I7QUFTdkNDLE1BQUFBLGVBQWUsRUFBRSxLQUFLQSxlQVRpQjtBQVV2Q2hCLE1BQUFBLElBQUksRUFBRSxLQUFLQTtBQVY0QixLQUF4QixDQUFqQjtBQVlBLFVBQU0sS0FBS0ksU0FBTCxDQUFlRixPQUFmLEVBQU47O0FBR0EsUUFBSTtBQUNGLFlBQU1lLE9BQU8sR0FBRyxNQUFNLEtBQUtDLGdCQUFMLEVBQXRCOztBQUNBQyxzQkFBSUMsS0FBSixDQUFVLDBCQUFWOztBQUNBLGFBQU9ILE9BQVA7QUFDRCxLQUpELENBSUUsT0FBT0ksR0FBUCxFQUFZO0FBQ1osWUFBTSxLQUFLQyxVQUFMLEVBQU47QUFDQSxhQUFPLElBQVA7QUFDRDtBQUNGOztBQXBDa0UiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbG9nIGZyb20gJy4vbG9nZ2VyJztcbmltcG9ydCB7IFJlbW90ZURlYnVnZ2VyIH0gZnJvbSAnLi9yZW1vdGUtZGVidWdnZXInO1xuaW1wb3J0IFJwY0NsaWVudFJlYWxEZXZpY2UgZnJvbSAnLi9ycGMtY2xpZW50LXJlYWwtZGV2aWNlJztcblxuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBSZW1vdGVEZWJ1Z2dlclJlYWxEZXZpY2UgZXh0ZW5kcyBSZW1vdGVEZWJ1Z2dlciB7XG4gIGNvbnN0cnVjdG9yIChvcHRzID0ge30pIHtcbiAgICBzdXBlcihvcHRzKTtcblxuICAgIHRoaXMudWRpZCA9IG9wdHMudWRpZDtcblxuICAgIHRoaXMuc2tpcHBlZEFwcHMgPSBbJ2xvY2tkb3duZCddO1xuICB9XG5cbiAgYXN5bmMgY29ubmVjdCAoKSB7XG4gICAgdGhpcy5zZXR1cCgpO1xuXG4gICAgLy8gaW5pdGlhbGl6ZSB0aGUgcnBjIGNsaWVudFxuICAgIHRoaXMucnBjQ2xpZW50ID0gbmV3IFJwY0NsaWVudFJlYWxEZXZpY2Uoe1xuICAgICAgYnVuZGxlSWQ6IHRoaXMuYnVuZGxlSWQsXG4gICAgICBwbGF0Zm9ybVZlcnNpb246IHRoaXMucGxhdGZvcm1WZXJzaW9uLFxuICAgICAgaXNTYWZhcmk6IHRoaXMuaXNTYWZhcmksXG4gICAgICBob3N0OiB0aGlzLmhvc3QsXG4gICAgICBwb3J0OiB0aGlzLnBvcnQsXG4gICAgICBzb2NrZXRQYXRoOiB0aGlzLnNvY2tldFBhdGgsXG4gICAgICBzcGVjaWFsTWVzc2FnZUhhbmRsZXJzOiB0aGlzLnNwZWNpYWxDYnMsXG4gICAgICBtZXNzYWdlUHJveHk6IHRoaXMucmVtb3RlRGVidWdQcm94eSxcbiAgICAgIGxvZ0Z1bGxSZXNwb25zZTogdGhpcy5sb2dGdWxsUmVzcG9uc2UsXG4gICAgICB1ZGlkOiB0aGlzLnVkaWRcbiAgICB9KTtcbiAgICBhd2FpdCB0aGlzLnJwY0NsaWVudC5jb25uZWN0KCk7XG5cbiAgICAvLyBnZXQgdGhlIGNvbm5lY3Rpb24gaW5mb3JtYXRpb24gYWJvdXQgdGhlIGFwcFxuICAgIHRyeSB7XG4gICAgICBjb25zdCBhcHBJbmZvID0gYXdhaXQgdGhpcy5zZXRDb25uZWN0aW9uS2V5KCk7XG4gICAgICBsb2cuZGVidWcoJ0Nvbm5lY3RlZCB0byBhcHBsaWNhdGlvbicpO1xuICAgICAgcmV0dXJuIGFwcEluZm87XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICBhd2FpdCB0aGlzLmRpc2Nvbm5lY3QoKTtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbiAgfVxufVxuIl0sImZpbGUiOiJsaWIvcmVtb3RlLWRlYnVnZ2VyLXJlYWwtZGV2aWNlLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=