appium-ios-device 2.1.0 → 2.2.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.
- package/README.md +1 -0
- package/build/lib/instrument/headers.js +356 -0
- package/build/lib/instrument/index.js +187 -0
- package/build/lib/instrument/transformer/dtx-decode.js +108 -0
- package/build/lib/instrument/transformer/dtx-encode.js +57 -0
- package/build/lib/instrument/transformer/nskeyed.js +446 -0
- package/build/lib/services.js +12 -3
- package/build/lib/ssl-helper.js +39 -1
- package/build/lib/utilities.js +3 -3
- package/lib/instrument/headers.js +421 -0
- package/lib/instrument/index.js +190 -0
- package/lib/instrument/transformer/dtx-decode.js +70 -0
- package/lib/instrument/transformer/dtx-encode.js +33 -0
- package/lib/instrument/transformer/nskeyed.js +447 -0
- package/lib/services.js +14 -3
- package/lib/ssl-helper.js +43 -2
- package/lib/utilities.js +6 -3
- package/package.json +9 -3
package/build/lib/services.js
CHANGED
|
@@ -9,6 +9,7 @@ exports.startAfcService = startAfcService;
|
|
|
9
9
|
exports.startCrashLogService = startCrashLogService;
|
|
10
10
|
exports.startHouseArrestService = startHouseArrestService;
|
|
11
11
|
exports.startInstallationProxyService = startInstallationProxyService;
|
|
12
|
+
exports.startInstrumentService = startInstrumentService;
|
|
12
13
|
exports.startNotificationProxyService = startNotificationProxyService;
|
|
13
14
|
exports.startSimulateLocationService = startSimulateLocationService;
|
|
14
15
|
exports.startSyslogService = startSyslogService;
|
|
@@ -32,11 +33,14 @@ var _notificationProxy = require("./notification-proxy");
|
|
|
32
33
|
|
|
33
34
|
var _houseArrest = require("./house-arrest");
|
|
34
35
|
|
|
36
|
+
var _instrument = require("./instrument");
|
|
37
|
+
|
|
35
38
|
var _plistService = _interopRequireDefault(require("./plist-service"));
|
|
36
39
|
|
|
37
40
|
var _semver = _interopRequireDefault(require("semver"));
|
|
38
41
|
|
|
39
42
|
const CRASH_LOG_SERVICE_NAME = 'com.apple.crashreportcopymobile';
|
|
43
|
+
const INSTRUMENT_HANDSHAKE_VERSION = 14;
|
|
40
44
|
|
|
41
45
|
async function startSyslogService(udid, opts = {}) {
|
|
42
46
|
const socket = await startService(udid, _syslog.SYSLOG_SERVICE_NAME, opts.socket);
|
|
@@ -111,14 +115,19 @@ async function startHouseArrestService(udid, opts = {}) {
|
|
|
111
115
|
return new _houseArrest.HouseArrestService(socket);
|
|
112
116
|
}
|
|
113
117
|
|
|
114
|
-
async function
|
|
118
|
+
async function startInstrumentService(udid, opts = {}) {
|
|
119
|
+
const osVersion = opts.osVersion || (await (0, _utilities.getOSVersion)(udid, opts.socket));
|
|
120
|
+
return new _instrument.InstrumentService(parseInt(osVersion.split('.')[0], 10) < INSTRUMENT_HANDSHAKE_VERSION ? await startService(udid, _instrument.INSTRUMENT_SERVICE_NAME, opts.socket, true) : await startService(udid, _instrument.INSTRUMENT_SERVICE_NAME_VERSION_14, opts.socket));
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
async function startService(udid, serviceName, socket, handshakeOnly = false) {
|
|
115
124
|
const lockdown = await (0, _utilities.startLockdownSession)(udid, socket);
|
|
116
125
|
|
|
117
126
|
try {
|
|
118
127
|
const service = await lockdown.startService(serviceName);
|
|
119
128
|
|
|
120
129
|
if (service.EnableServiceSSL) {
|
|
121
|
-
return await (0, _utilities.connectPortSSL)(udid, service.Port, socket);
|
|
130
|
+
return await (0, _utilities.connectPortSSL)(udid, service.Port, socket, handshakeOnly);
|
|
122
131
|
} else {
|
|
123
132
|
return await (0, _utilities.connectPort)(udid, service.Port, socket);
|
|
124
133
|
}
|
|
@@ -128,4 +137,4 @@ async function startService(udid, serviceName, socket) {
|
|
|
128
137
|
}require('source-map-support').install();
|
|
129
138
|
|
|
130
139
|
|
|
131
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/services.js"],"names":["CRASH_LOG_SERVICE_NAME","startSyslogService","udid","opts","socket","startService","SYSLOG_SERVICE_NAME","SyslogService","startSimulateLocationService","SIMULATE_LOCATION_SERVICE_NAME","SimulateLocationService","startWebInspectorService","osVersion","isSimulator","verbose","verboseHexDump","socketChunkSize","maxFrameLength","semverVersion","semver","coerce","Error","WebInspectorService","majorOsVersion","major","socketClient","WEB_INSPECTOR_SERVICE_NAME","undefined","startInstallationProxyService","INSTALLATION_PROXY_SERVICE_NAME","InstallationProxyService","PlistService","startAfcService","AFC_SERVICE_NAME","AfcService","startCrashLogService","startNotificationProxyService","NOTIFICATION_PROXY_SERVICE_NAME","NotificationProxyService","startHouseArrestService","HOUSE_ARREST_SERVICE_NAME","HouseArrestService","serviceName","lockdown","service","EnableServiceSSL","Port","close"],"mappings":"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","sourcesContent":["import { connectPort, connectPortSSL, startLockdownSession, getOSVersion } from './utilities';\nimport { SyslogService, SYSLOG_SERVICE_NAME } from './syslog';\nimport { SimulateLocationService, SIMULATE_LOCATION_SERVICE_NAME } from './simulatelocation';\nimport { WebInspectorService, WEB_INSPECTOR_SERVICE_NAME } from './webinspector';\nimport { InstallationProxyService, INSTALLATION_PROXY_SERVICE_NAME } from './installation-proxy';\nimport { AfcService, AFC_SERVICE_NAME } from './afc';\nimport { NotificationProxyService, NOTIFICATION_PROXY_SERVICE_NAME } from './notification-proxy';\nimport { HouseArrestService, HOUSE_ARREST_SERVICE_NAME } from './house-arrest';\nimport PlistService from './plist-service';\nimport semver from 'semver';\n\nconst CRASH_LOG_SERVICE_NAME = 'com.apple.crashreportcopymobile';\n\nasync function startSyslogService (udid, opts = {}) {\n  const socket = await startService(udid, SYSLOG_SERVICE_NAME, opts.socket);\n  return new SyslogService(socket);\n}\n\nasync function startSimulateLocationService (udid, opts = {}) {\n  const socket = await startService(udid, SIMULATE_LOCATION_SERVICE_NAME, opts.socket);\n  return new SimulateLocationService(socket);\n}\n\nasync function startWebInspectorService (udid, opts = {}) {\n  const osVersion = opts.osVersion || await getOSVersion(udid, opts.socket);\n  const isSimulator = !!opts.isSimulator;\n  const verbose = !!opts.verbose;\n  const verboseHexDump = !!opts.verboseHexDump;\n  const socketChunkSize = opts.socketChunkSize;\n  const maxFrameLength = opts.maxFrameLength;\n  const semverVersion = semver.coerce(osVersion);\n  if (!semverVersion) {\n    throw new Error(`Could not create a semver version out of '${osVersion}'`);\n  }\n  if (opts.socket) {\n    return new WebInspectorService({\n      majorOsVersion: semverVersion.major,\n      isSimulator,\n      socketChunkSize,\n      verbose,\n      verboseHexDump,\n      socketClient: opts.socket,\n      maxFrameLength,\n    });\n  }\n  const socket = await startService(udid, WEB_INSPECTOR_SERVICE_NAME, undefined);\n  return new WebInspectorService({\n    majorOsVersion: semverVersion.major,\n    isSimulator,\n    socketChunkSize,\n    verbose,\n    verboseHexDump,\n    socketClient: socket,\n    maxFrameLength,\n  });\n}\n\nasync function startInstallationProxyService (udid, opts = {}) {\n  const socket = await startService(udid, INSTALLATION_PROXY_SERVICE_NAME, opts.socket);\n  return new InstallationProxyService(new PlistService(socket));\n}\n\nasync function startAfcService (udid, opts = {}) {\n  const socket = await startService(udid, AFC_SERVICE_NAME, opts.socket);\n  return new AfcService(socket);\n}\n\nasync function startCrashLogService (udid, opts = {}) {\n  const socket = await startService(udid, CRASH_LOG_SERVICE_NAME, opts.socket);\n  return new AfcService(socket);\n}\n\nasync function startNotificationProxyService (udid, opts = {}) {\n  const socket = await startService(udid, NOTIFICATION_PROXY_SERVICE_NAME, opts.socket);\n  return new NotificationProxyService(socket);\n}\n\nasync function startHouseArrestService (udid, opts = {}) {\n  const socket = await startService(udid, HOUSE_ARREST_SERVICE_NAME, opts.socket);\n  return new HouseArrestService(socket);\n}\n\nasync function startService (udid, serviceName, socket) {\n  const lockdown = await startLockdownSession(udid, socket);\n  try {\n    const service = await lockdown.startService(serviceName);\n    if (service.EnableServiceSSL) {\n      return await connectPortSSL(udid, service.Port, socket);\n    } else {\n      return await connectPort(udid, service.Port, socket);\n    }\n  } finally {\n    lockdown.close();\n  }\n}\n\nexport {\n  startSyslogService, startWebInspectorService,\n  startInstallationProxyService, startSimulateLocationService,\n  startAfcService, startCrashLogService, startNotificationProxyService,\n  startHouseArrestService\n};\n"],"file":"lib/services.js","sourceRoot":"../.."}
|
|
140
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/services.js"],"names":["CRASH_LOG_SERVICE_NAME","INSTRUMENT_HANDSHAKE_VERSION","startSyslogService","udid","opts","socket","startService","SYSLOG_SERVICE_NAME","SyslogService","startSimulateLocationService","SIMULATE_LOCATION_SERVICE_NAME","SimulateLocationService","startWebInspectorService","osVersion","isSimulator","verbose","verboseHexDump","socketChunkSize","maxFrameLength","semverVersion","semver","coerce","Error","WebInspectorService","majorOsVersion","major","socketClient","WEB_INSPECTOR_SERVICE_NAME","undefined","startInstallationProxyService","INSTALLATION_PROXY_SERVICE_NAME","InstallationProxyService","PlistService","startAfcService","AFC_SERVICE_NAME","AfcService","startCrashLogService","startNotificationProxyService","NOTIFICATION_PROXY_SERVICE_NAME","NotificationProxyService","startHouseArrestService","HOUSE_ARREST_SERVICE_NAME","HouseArrestService","startInstrumentService","InstrumentService","parseInt","split","INSTRUMENT_SERVICE_NAME","INSTRUMENT_SERVICE_NAME_VERSION_14","serviceName","handshakeOnly","lockdown","service","EnableServiceSSL","Port","close"],"mappings":"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","sourcesContent":["import { connectPort, connectPortSSL, startLockdownSession, getOSVersion } from './utilities';\nimport { SyslogService, SYSLOG_SERVICE_NAME } from './syslog';\nimport { SimulateLocationService, SIMULATE_LOCATION_SERVICE_NAME } from './simulatelocation';\nimport { WebInspectorService, WEB_INSPECTOR_SERVICE_NAME } from './webinspector';\nimport { InstallationProxyService, INSTALLATION_PROXY_SERVICE_NAME } from './installation-proxy';\nimport { AfcService, AFC_SERVICE_NAME } from './afc';\nimport { NotificationProxyService, NOTIFICATION_PROXY_SERVICE_NAME } from './notification-proxy';\nimport { HouseArrestService, HOUSE_ARREST_SERVICE_NAME } from './house-arrest';\nimport { InstrumentService, INSTRUMENT_SERVICE_NAME_VERSION_14, INSTRUMENT_SERVICE_NAME} from './instrument';\nimport PlistService from './plist-service';\nimport semver from 'semver';\n\nconst CRASH_LOG_SERVICE_NAME = 'com.apple.crashreportcopymobile';\nconst INSTRUMENT_HANDSHAKE_VERSION = 14;\n\nasync function startSyslogService (udid, opts = {}) {\n  const socket = await startService(udid, SYSLOG_SERVICE_NAME, opts.socket);\n  return new SyslogService(socket);\n}\n\nasync function startSimulateLocationService (udid, opts = {}) {\n  const socket = await startService(udid, SIMULATE_LOCATION_SERVICE_NAME, opts.socket);\n  return new SimulateLocationService(socket);\n}\n\nasync function startWebInspectorService (udid, opts = {}) {\n  const osVersion = opts.osVersion || await getOSVersion(udid, opts.socket);\n  const isSimulator = !!opts.isSimulator;\n  const verbose = !!opts.verbose;\n  const verboseHexDump = !!opts.verboseHexDump;\n  const socketChunkSize = opts.socketChunkSize;\n  const maxFrameLength = opts.maxFrameLength;\n  const semverVersion = semver.coerce(osVersion);\n  if (!semverVersion) {\n    throw new Error(`Could not create a semver version out of '${osVersion}'`);\n  }\n  if (opts.socket) {\n    return new WebInspectorService({\n      majorOsVersion: semverVersion.major,\n      isSimulator,\n      socketChunkSize,\n      verbose,\n      verboseHexDump,\n      socketClient: opts.socket,\n      maxFrameLength,\n    });\n  }\n  const socket = await startService(udid, WEB_INSPECTOR_SERVICE_NAME, undefined);\n  return new WebInspectorService({\n    majorOsVersion: semverVersion.major,\n    isSimulator,\n    socketChunkSize,\n    verbose,\n    verboseHexDump,\n    socketClient: socket,\n    maxFrameLength,\n  });\n}\n\nasync function startInstallationProxyService (udid, opts = {}) {\n  const socket = await startService(udid, INSTALLATION_PROXY_SERVICE_NAME, opts.socket);\n  return new InstallationProxyService(new PlistService(socket));\n}\n\nasync function startAfcService (udid, opts = {}) {\n  const socket = await startService(udid, AFC_SERVICE_NAME, opts.socket);\n  return new AfcService(socket);\n}\n\nasync function startCrashLogService (udid, opts = {}) {\n  const socket = await startService(udid, CRASH_LOG_SERVICE_NAME, opts.socket);\n  return new AfcService(socket);\n}\n\nasync function startNotificationProxyService (udid, opts = {}) {\n  const socket = await startService(udid, NOTIFICATION_PROXY_SERVICE_NAME, opts.socket);\n  return new NotificationProxyService(socket);\n}\n\nasync function startHouseArrestService (udid, opts = {}) {\n  const socket = await startService(udid, HOUSE_ARREST_SERVICE_NAME, opts.socket);\n  return new HouseArrestService(socket);\n}\n\nasync function startInstrumentService (udid, opts = {}) {\n  const osVersion = opts.osVersion || await getOSVersion(udid, opts.socket);\n  return new InstrumentService(\n  parseInt(osVersion.split('.')[0], 10) < INSTRUMENT_HANDSHAKE_VERSION\n    ? await startService(udid, INSTRUMENT_SERVICE_NAME, opts.socket, true)\n    : await startService(udid, INSTRUMENT_SERVICE_NAME_VERSION_14, opts.socket)\n  );\n}\n\nasync function startService (udid, serviceName, socket, handshakeOnly = false) {\n  const lockdown = await startLockdownSession(udid, socket);\n  try {\n    const service = await lockdown.startService(serviceName);\n    if (service.EnableServiceSSL) {\n      return await connectPortSSL(udid, service.Port, socket, handshakeOnly);\n    } else {\n      return await connectPort(udid, service.Port, socket);\n    }\n  } finally {\n    lockdown.close();\n  }\n}\n\nexport {\n  startSyslogService, startWebInspectorService,\n  startInstallationProxyService, startSimulateLocationService,\n  startAfcService, startCrashLogService, startNotificationProxyService,\n  startHouseArrestService, startInstrumentService\n};\n"],"file":"lib/services.js","sourceRoot":"../.."}
|
package/build/lib/ssl-helper.js
CHANGED
|
@@ -5,13 +5,19 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
+
exports.enableSSLHandshakeOnly = enableSSLHandshakeOnly;
|
|
8
9
|
exports.upgradeToSSL = upgradeToSSL;
|
|
9
10
|
|
|
10
11
|
require("source-map-support/register");
|
|
11
12
|
|
|
12
13
|
var _tls = _interopRequireDefault(require("tls"));
|
|
13
14
|
|
|
15
|
+
var _net = _interopRequireDefault(require("net"));
|
|
16
|
+
|
|
17
|
+
var _bluebird = _interopRequireDefault(require("bluebird"));
|
|
18
|
+
|
|
14
19
|
const TLS_VERSION = 'TLSv1_method';
|
|
20
|
+
const HANDSHAKE_TIMEOUT_MS = 10000;
|
|
15
21
|
|
|
16
22
|
function upgradeToSSL(socket, key, cert) {
|
|
17
23
|
return new _tls.default.TLSSocket(socket, {
|
|
@@ -22,7 +28,39 @@ function upgradeToSSL(socket, key, cert) {
|
|
|
22
28
|
secureProtocol: TLS_VERSION
|
|
23
29
|
})
|
|
24
30
|
});
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
async function enableSSLHandshakeOnly(socket, key, cert) {
|
|
34
|
+
const sslSocket = _tls.default.connect({
|
|
35
|
+
socket,
|
|
36
|
+
secureContext: _tls.default.createSecureContext({
|
|
37
|
+
key,
|
|
38
|
+
cert,
|
|
39
|
+
secureProtocol: TLS_VERSION
|
|
40
|
+
}),
|
|
41
|
+
rejectUnauthorized: false
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
await new _bluebird.default((resolve, reject) => {
|
|
45
|
+
const timeoutHandler = setTimeout(() => {
|
|
46
|
+
if (!sslSocket.destroyed) {
|
|
47
|
+
sslSocket.end();
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
return reject(new Error('ssl handshake error'));
|
|
51
|
+
}, HANDSHAKE_TIMEOUT_MS);
|
|
52
|
+
sslSocket.once('secureConnect', () => {
|
|
53
|
+
clearTimeout(timeoutHandler);
|
|
54
|
+
|
|
55
|
+
sslSocket._handle.readStop();
|
|
56
|
+
|
|
57
|
+
return resolve();
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
return _net.default.Socket({
|
|
61
|
+
fd: socket._handle.fd
|
|
62
|
+
});
|
|
25
63
|
}require('source-map-support').install();
|
|
26
64
|
|
|
27
65
|
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9zc2wtaGVscGVyLmpzIl0sIm5hbWVzIjpbIlRMU19WRVJTSU9OIiwiSEFORFNIQUtFX1RJTUVPVVRfTVMiLCJ1cGdyYWRlVG9TU0wiLCJzb2NrZXQiLCJrZXkiLCJjZXJ0IiwidGxzIiwiVExTU29ja2V0IiwicmVqZWN0VW5hdXRob3JpemVkIiwic2VjdXJlQ29udGV4dCIsImNyZWF0ZVNlY3VyZUNvbnRleHQiLCJzZWN1cmVQcm90b2NvbCIsImVuYWJsZVNTTEhhbmRzaGFrZU9ubHkiLCJzc2xTb2NrZXQiLCJjb25uZWN0IiwiQiIsInJlc29sdmUiLCJyZWplY3QiLCJ0aW1lb3V0SGFuZGxlciIsInNldFRpbWVvdXQiLCJkZXN0cm95ZWQiLCJlbmQiLCJFcnJvciIsIm9uY2UiLCJjbGVhclRpbWVvdXQiLCJfaGFuZGxlIiwicmVhZFN0b3AiLCJuZXQiLCJTb2NrZXQiLCJmZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBRUEsTUFBTUEsV0FBVyxHQUFHLGNBQXBCO0FBQ0EsTUFBTUMsb0JBQW9CLEdBQUcsS0FBN0I7O0FBRUEsU0FBU0MsWUFBVCxDQUF1QkMsTUFBdkIsRUFBK0JDLEdBQS9CLEVBQW9DQyxJQUFwQyxFQUEwQztBQUN4QyxTQUFPLElBQUlDLGFBQUlDLFNBQVIsQ0FBa0JKLE1BQWxCLEVBQTBCO0FBQy9CSyxJQUFBQSxrQkFBa0IsRUFBRSxLQURXO0FBRS9CQyxJQUFBQSxhQUFhLEVBQUVILGFBQUlJLG1CQUFKLENBQXdCO0FBQ3JDTixNQUFBQSxHQURxQztBQUVyQ0MsTUFBQUEsSUFGcUM7QUFHckNNLE1BQUFBLGNBQWMsRUFBRVg7QUFIcUIsS0FBeEI7QUFGZ0IsR0FBMUIsQ0FBUDtBQVFEOztBQVNELGVBQWVZLHNCQUFmLENBQXVDVCxNQUF2QyxFQUErQ0MsR0FBL0MsRUFBb0RDLElBQXBELEVBQTBEO0FBQ3hELFFBQU1RLFNBQVMsR0FBR1AsYUFBSVEsT0FBSixDQUFZO0FBQzVCWCxJQUFBQSxNQUQ0QjtBQUU1Qk0sSUFBQUEsYUFBYSxFQUFFSCxhQUFJSSxtQkFBSixDQUF3QjtBQUNyQ04sTUFBQUEsR0FEcUM7QUFFckNDLE1BQUFBLElBRnFDO0FBR3JDTSxNQUFBQSxjQUFjLEVBQUVYO0FBSHFCLEtBQXhCLENBRmE7QUFPNUJRLElBQUFBLGtCQUFrQixFQUFFO0FBUFEsR0FBWixDQUFsQjs7QUFXQSxRQUFNLElBQUlPLGlCQUFKLENBQU0sQ0FBQ0MsT0FBRCxFQUFVQyxNQUFWLEtBQXFCO0FBQy9CLFVBQU1DLGNBQWMsR0FBR0MsVUFBVSxDQUFDLE1BQU07QUFDdEMsVUFBSSxDQUFDTixTQUFTLENBQUNPLFNBQWYsRUFBMEI7QUFDeEJQLFFBQUFBLFNBQVMsQ0FBQ1EsR0FBVjtBQUNEOztBQUNELGFBQU9KLE1BQU0sQ0FBQyxJQUFJSyxLQUFKLENBQVUscUJBQVYsQ0FBRCxDQUFiO0FBQ0QsS0FMZ0MsRUFLOUJyQixvQkFMOEIsQ0FBakM7QUFPQVksSUFBQUEsU0FBUyxDQUFDVSxJQUFWLENBQWUsZUFBZixFQUFnQyxNQUFNO0FBQ3BDQyxNQUFBQSxZQUFZLENBQUNOLGNBQUQsQ0FBWjs7QUFDQUwsTUFBQUEsU0FBUyxDQUFDWSxPQUFWLENBQWtCQyxRQUFsQjs7QUFDQSxhQUFPVixPQUFPLEVBQWQ7QUFDRCxLQUpEO0FBS0QsR0FiSyxDQUFOO0FBZUEsU0FBT1csYUFBSUMsTUFBSixDQUFXO0FBQUNDLElBQUFBLEVBQUUsRUFBRTFCLE1BQU0sQ0FBQ3NCLE9BQVAsQ0FBZUk7QUFBcEIsR0FBWCxDQUFQO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdGxzIGZyb20gJ3Rscyc7XG5pbXBvcnQgbmV0IGZyb20gJ25ldCc7XG5pbXBvcnQgQiBmcm9tICdibHVlYmlyZCc7XG5cbmNvbnN0IFRMU19WRVJTSU9OID0gJ1RMU3YxX21ldGhvZCc7XG5jb25zdCBIQU5EU0hBS0VfVElNRU9VVF9NUyA9IDEwMDAwO1xuXG5mdW5jdGlvbiB1cGdyYWRlVG9TU0wgKHNvY2tldCwga2V5LCBjZXJ0KSB7XG4gIHJldHVybiBuZXcgdGxzLlRMU1NvY2tldChzb2NrZXQsIHtcbiAgICByZWplY3RVbmF1dGhvcml6ZWQ6IGZhbHNlLFxuICAgIHNlY3VyZUNvbnRleHQ6IHRscy5jcmVhdGVTZWN1cmVDb250ZXh0KHtcbiAgICAgIGtleSxcbiAgICAgIGNlcnQsXG4gICAgICBzZWN1cmVQcm90b2NvbDogVExTX1ZFUlNJT05cbiAgICB9KVxuICB9KTtcbn1cblxuLyoqXG4gKiBBZnRlciB0aGUgc3NsIHByb3RvY29sIGlzIHN1Y2Nlc3NmdWxseSBoYW5kc2hha2UsIGNsb3NlIHRoZSBzc2wgcHJvdG9jb2wgY2hhbm5lbCBhbmQgdXNlIHRleHQgdHJhbnNtaXNzaW9uXG4gKiBAcGFyYW0gc29ja2V0XG4gKiBAcGFyYW0ga2V5XG4gKiBAcGFyYW0gY2VydFxuICogQHJldHVybnMge1Byb21pc2U8U29ja2V0Pn0gRHVwbGljYXRlIHRoZSBpbnB1dCBzb2NrZXRcbiAqL1xuYXN5bmMgZnVuY3Rpb24gZW5hYmxlU1NMSGFuZHNoYWtlT25seSAoc29ja2V0LCBrZXksIGNlcnQpIHtcbiAgY29uc3Qgc3NsU29ja2V0ID0gdGxzLmNvbm5lY3Qoe1xuICAgIHNvY2tldCxcbiAgICBzZWN1cmVDb250ZXh0OiB0bHMuY3JlYXRlU2VjdXJlQ29udGV4dCh7XG4gICAgICBrZXksXG4gICAgICBjZXJ0LFxuICAgICAgc2VjdXJlUHJvdG9jb2w6IFRMU19WRVJTSU9OXG4gICAgfSksXG4gICAgcmVqZWN0VW5hdXRob3JpemVkOiBmYWxzZSxcbiAgfSk7XG5cbiAgLy8gc3RvcCByZWNlaXZpbmcgZGF0YSBhZnRlciBzdWNjZXNzZnVsIGhhbmRzaGFrZVxuICBhd2FpdCBuZXcgQigocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgY29uc3QgdGltZW91dEhhbmRsZXIgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIGlmICghc3NsU29ja2V0LmRlc3Ryb3llZCkge1xuICAgICAgICBzc2xTb2NrZXQuZW5kKCk7XG4gICAgICB9XG4gICAgICByZXR1cm4gcmVqZWN0KG5ldyBFcnJvcignc3NsIGhhbmRzaGFrZSBlcnJvcicpKTtcbiAgICB9LCBIQU5EU0hBS0VfVElNRU9VVF9NUyk7XG5cbiAgICBzc2xTb2NrZXQub25jZSgnc2VjdXJlQ29ubmVjdCcsICgpID0+IHtcbiAgICAgIGNsZWFyVGltZW91dCh0aW1lb3V0SGFuZGxlcik7XG4gICAgICBzc2xTb2NrZXQuX2hhbmRsZS5yZWFkU3RvcCgpO1xuICAgICAgcmV0dXJuIHJlc29sdmUoKTtcbiAgICB9KTtcbiAgfSk7XG4gIC8vIER1cGxpY2F0ZSB0aGUgc29ja2V0LiBSZXR1cm4gYSBuZXcgc29ja2V0IG9iamVjdCBjb25uZWN0ZWQgdG8gdGhlIHNhbWUgc3lzdGVtIHJlc291cmNlXG4gIHJldHVybiBuZXQuU29ja2V0KHtmZDogc29ja2V0Ll9oYW5kbGUuZmR9KTtcbn1cblxuXG5leHBvcnQgeyB1cGdyYWRlVG9TU0wsIGVuYWJsZVNTTEhhbmRzaGFrZU9ubHkgfTtcbiJdLCJmaWxlIjoibGliL3NzbC1oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
|
package/build/lib/utilities.js
CHANGED
|
@@ -133,7 +133,7 @@ async function startLockdownSession(udid, socket = null) {
|
|
|
133
133
|
}
|
|
134
134
|
}
|
|
135
135
|
|
|
136
|
-
async function connectPortSSL(udid, port, socket = null) {
|
|
136
|
+
async function connectPortSSL(udid, port, socket = null, handshakeOnly = false) {
|
|
137
137
|
const usbmux = new _usbmux.default(socket || (await (0, _usbmux.getDefaultSocket)()));
|
|
138
138
|
|
|
139
139
|
try {
|
|
@@ -150,7 +150,7 @@ async function connectPortSSL(udid, port, socket = null) {
|
|
|
150
150
|
}
|
|
151
151
|
|
|
152
152
|
const socket = await usbmux.connect(device.Properties.DeviceID, port, undefined);
|
|
153
|
-
return (0, _sslHelper.upgradeToSSL)(socket, pairRecord.HostPrivateKey, pairRecord.HostCertificate);
|
|
153
|
+
return handshakeOnly ? await (0, _sslHelper.enableSSLHandshakeOnly)(socket, pairRecord.HostPrivateKey, pairRecord.HostCertificate) : (0, _sslHelper.upgradeToSSL)(socket, pairRecord.HostPrivateKey, pairRecord.HostCertificate);
|
|
154
154
|
} catch (e) {
|
|
155
155
|
usbmux.close();
|
|
156
156
|
throw e;
|
|
@@ -175,4 +175,4 @@ async function connectPort(udid, port, socket = null) {
|
|
|
175
175
|
}require('source-map-support').install();
|
|
176
176
|
|
|
177
177
|
|
|
178
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/utilities.js"],"names":["LOCKDOWN_REQUEST","DEVICE_TIME","Key","DEVICE_UTC_OFFSET","DEVICE_TIME_ZONE","DEVICE_VERSION","DEVICE_NAME","getConnectedDevices","socket","usbmux","Usbmux","e","log","debug","devices","listDevices","udids","map","device","Properties","SerialNumber","_","uniq","close","getOSVersion","udid","lockdown","connectLockdown","getValue","getDeviceName","getDeviceInfo","getDeviceTime","startLockdownSession","timestamp","utcOffset","timeZone","pairRecord","readPairRecord","Error","startSession","HostID","SystemBUID","enableSessionSSL","HostPrivateKey","HostCertificate","connectPortSSL","port","findDevice","connect","DeviceID","undefined","connectPort"],"mappings":"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","sourcesContent":["import Usbmux, { getDefaultSocket } from './usbmux';\nimport { upgradeToSSL } from './ssl-helper';\nimport _ from 'lodash';\nimport log from './logger';\n\n// https://github.com/samdmarshall/iOS-Internals/blob/master/lockbot/lockbot/lockdown_keys.h\nconst LOCKDOWN_REQUEST = {\n  DEVICE_TIME: { Key: 'TimeIntervalSince1970' },\n  DEVICE_UTC_OFFSET: { Key: 'TimeZoneOffsetFromUTC' },\n  DEVICE_TIME_ZONE: { Key: 'TimeZone' },\n  DEVICE_VERSION: { Key: 'ProductVersion' },\n  DEVICE_NAME: { Key: 'DeviceName' }\n};\n\n\n/**\n * Retrieves the udids of the connected devices\n *\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {Array.<string>} The list of device serial numbers (udid) or\n * an empty list if no devices are connected\n */\nasync function getConnectedDevices (socket = null) {\n  let usbmux;\n  try {\n    usbmux = new Usbmux(socket || await getDefaultSocket());\n  } catch (e) {\n    log.debug(e);\n    return [];\n  }\n  try {\n    const devices = await usbmux.listDevices();\n    const udids = devices.map((device) => device.Properties.SerialNumber);\n    return _.uniq(udids);\n  } finally {\n    usbmux.close();\n  }\n}\n\n/**\n * Retrieves the os version of the device\n *\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {string}\n */\nasync function getOSVersion (udid, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    // lockdown doesn't need to be closed since it uses the same socket usbmux uses\n    const lockdown = await usbmux.connectLockdown(udid);\n    return await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_VERSION);\n  } finally {\n    usbmux.close();\n  }\n}\n\n/**\n * Retrieves the name of the device\n *\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {string}\n */\nasync function getDeviceName (udid, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    // lockdown doesn't need to be closed since it uses the same socket usbmux uses\n    const lockdown = await usbmux.connectLockdown(udid);\n    return await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_NAME);\n  } finally {\n    usbmux.close();\n  }\n}\n\n/**\n * Returns all available device values\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {object} Returns available default device values via lockdown.\n * e.g.\n * {\n *   \"BasebandCertId\"=>3840149528,\n *   \"BasebandKeyHashInformation\"=>\n *     {\"AKeyStatus\"=>2,\n *     \"SKeyHash\"=>{\n *       \"type\"=>\"Buffer\",\n *       \"data\"=>[187, 239, ....]},\n *     \"SKeyStatus\"=>0},\n *   \"BasebandSerialNumber\"=>{\"type\"=>\"Buffer\", \"data\"=>[...]},\n *   \"BasebandVersion\"=>\"11.01.02\",\n *   \"BoardId\"=>2,\n *   \"BuildVersion\"=>\"19C56\",\n *   \"CPUArchitecture\"=>\"arm64\",\n *   \"ChipID\"=>32768,\n *   \"DeviceClass\"=>\"iPhone\",\n *   \"DeviceColor\"=>\"#c8caca\",\n *   \"DeviceName\"=>\"kazu\",\n *   \"DieID\"=>1111111111111,\n *   \"HardwareModel\"=>\"N69uAP\",\n *   \"HasSiDP\"=>true,\n *   \"PartitionType\"=>\"GUID_partition_scheme\",\n *   \"ProductName\"=>\"iPhone OS\",\n *   \"ProductType\"=>\"iPhone8,4\",\n *   \"ProductVersion\"=>\"15.2\",\n *   \"ProductionSOC\"=>true,\n *   \"ProtocolVersion\"=>\"2\",\n *   \"SupportedDeviceFamilies\"=>[1],\n *   \"TelephonyCapability\"=>true,\n *   \"UniqueChipID\"=>1111111111111,\n *   \"UniqueDeviceID\"=>\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\",\n *   \"WiFiAddress\"=>\"00:00:00:00:00:00\"\n * }\n */\nasync function getDeviceInfo (udid, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    const lockdown = await usbmux.connectLockdown(udid);\n    return await lockdown.getValue();\n  } finally {\n    usbmux.close();\n  }\n}\n\n/**\n * @typedef {Object} DeviceTime\n *\n * @property {number} timestamp Unix timestamp in seconds since 1970-01-01T00:00:00Z\n * @property {number} utcOffset The difference in minutes between the UTC time and the local device time.\n * Can be negative.\n * @property {string} timeZone Time zone name configured on the device, for example `Europe/Paris`\n */\n\n/**\n * Retrieves the local time from the device under test\n *\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {DeviceTime}\n */\nasync function getDeviceTime (udid, socket = null) {\n  const lockdown = await startLockdownSession(udid, socket);\n  try {\n    return {\n      timestamp: await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_TIME),\n      // Apple returns utcOffset in seconds which doesnt comply with the general standard\n      utcOffset: await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_UTC_OFFSET) / 60,\n      timeZone: await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_TIME_ZONE),\n    };\n  } finally {\n    lockdown.close();\n  }\n}\n\n/**\n * Starts a lockdown session on the given device\n *\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {Lockdown}\n */\nasync function startLockdownSession (udid, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    const pairRecord = await usbmux.readPairRecord(udid);\n    if (!pairRecord) {\n      throw new Error(`Could not find a pair record for device '${udid}'. Please first pair with the device`);\n    }\n    // lockdown doesn't need to be closed since it uses the same socket usbmux uses\n    const lockdown = await usbmux.connectLockdown(udid);\n    await lockdown.startSession(pairRecord.HostID, pairRecord.SystemBUID);\n    lockdown.enableSessionSSL(pairRecord.HostPrivateKey, pairRecord.HostCertificate);\n    return lockdown;\n  } catch (e) {\n    usbmux.close();\n    throw e;\n  }\n}\n\n/**\n * Connects to a given port with the certs and keys used in the pairing process\n *\n * @param {string} udid Device UDID\n * @param {number} port Port to connect\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {tls.TLSSocket|Object} The socket or the object returned in the callback if the callback function exists\n */\nasync function connectPortSSL (udid, port, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    const device = await usbmux.findDevice(udid);\n    if (!device) {\n      throw new Error(`Could not find the expected device '${udid}'`);\n    }\n    const pairRecord = await usbmux.readPairRecord(udid);\n    if (!pairRecord) {\n      throw new Error(`Could not find a pair record for device '${udid}'. Please first pair with the device`);\n    }\n    const socket = await usbmux.connect(device.Properties.DeviceID, port, undefined);\n    return upgradeToSSL(socket, pairRecord.HostPrivateKey, pairRecord.HostCertificate);\n  } catch (e) {\n    usbmux.close();\n    throw e;\n  }\n}\n\n/**\n * Connects to a given port\n *\n * @param {string} udid Device UDID\n * @param {number} port Port to connect\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {net.Socket|Object} The socket or the object returned in the callback if the callback function exists\n */\nasync function connectPort (udid, port, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    const device = await usbmux.findDevice(udid);\n    if (!device) {\n      throw new Error(`Could not find the expected device ${udid}`);\n    }\n    return await usbmux.connect(device.Properties.DeviceID, port, undefined);\n  } catch (e) {\n    usbmux.close();\n    throw e;\n  }\n}\n\nexport {\n  getConnectedDevices, getOSVersion, getDeviceName, getDeviceTime,\n  startLockdownSession, connectPort, connectPortSSL, getDeviceInfo\n};\n"],"file":"lib/utilities.js","sourceRoot":"../.."}
|
|
178
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/utilities.js"],"names":["LOCKDOWN_REQUEST","DEVICE_TIME","Key","DEVICE_UTC_OFFSET","DEVICE_TIME_ZONE","DEVICE_VERSION","DEVICE_NAME","getConnectedDevices","socket","usbmux","Usbmux","e","log","debug","devices","listDevices","udids","map","device","Properties","SerialNumber","_","uniq","close","getOSVersion","udid","lockdown","connectLockdown","getValue","getDeviceName","getDeviceInfo","getDeviceTime","startLockdownSession","timestamp","utcOffset","timeZone","pairRecord","readPairRecord","Error","startSession","HostID","SystemBUID","enableSessionSSL","HostPrivateKey","HostCertificate","connectPortSSL","port","handshakeOnly","findDevice","connect","DeviceID","undefined","connectPort"],"mappings":"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","sourcesContent":["import Usbmux, { getDefaultSocket } from './usbmux';\nimport { upgradeToSSL, enableSSLHandshakeOnly } from './ssl-helper';\nimport _ from 'lodash';\nimport log from './logger';\n\n// https://github.com/samdmarshall/iOS-Internals/blob/master/lockbot/lockbot/lockdown_keys.h\nconst LOCKDOWN_REQUEST = {\n  DEVICE_TIME: { Key: 'TimeIntervalSince1970' },\n  DEVICE_UTC_OFFSET: { Key: 'TimeZoneOffsetFromUTC' },\n  DEVICE_TIME_ZONE: { Key: 'TimeZone' },\n  DEVICE_VERSION: { Key: 'ProductVersion' },\n  DEVICE_NAME: { Key: 'DeviceName' }\n};\n\n\n/**\n * Retrieves the udids of the connected devices\n *\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {Array.<string>} The list of device serial numbers (udid) or\n * an empty list if no devices are connected\n */\nasync function getConnectedDevices (socket = null) {\n  let usbmux;\n  try {\n    usbmux = new Usbmux(socket || await getDefaultSocket());\n  } catch (e) {\n    log.debug(e);\n    return [];\n  }\n  try {\n    const devices = await usbmux.listDevices();\n    const udids = devices.map((device) => device.Properties.SerialNumber);\n    return _.uniq(udids);\n  } finally {\n    usbmux.close();\n  }\n}\n\n/**\n * Retrieves the os version of the device\n *\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {string}\n */\nasync function getOSVersion (udid, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    // lockdown doesn't need to be closed since it uses the same socket usbmux uses\n    const lockdown = await usbmux.connectLockdown(udid);\n    return await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_VERSION);\n  } finally {\n    usbmux.close();\n  }\n}\n\n/**\n * Retrieves the name of the device\n *\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {string}\n */\nasync function getDeviceName (udid, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    // lockdown doesn't need to be closed since it uses the same socket usbmux uses\n    const lockdown = await usbmux.connectLockdown(udid);\n    return await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_NAME);\n  } finally {\n    usbmux.close();\n  }\n}\n\n/**\n * Returns all available device values\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {object} Returns available default device values via lockdown.\n * e.g.\n * {\n *   \"BasebandCertId\"=>3840149528,\n *   \"BasebandKeyHashInformation\"=>\n *     {\"AKeyStatus\"=>2,\n *     \"SKeyHash\"=>{\n *       \"type\"=>\"Buffer\",\n *       \"data\"=>[187, 239, ....]},\n *     \"SKeyStatus\"=>0},\n *   \"BasebandSerialNumber\"=>{\"type\"=>\"Buffer\", \"data\"=>[...]},\n *   \"BasebandVersion\"=>\"11.01.02\",\n *   \"BoardId\"=>2,\n *   \"BuildVersion\"=>\"19C56\",\n *   \"CPUArchitecture\"=>\"arm64\",\n *   \"ChipID\"=>32768,\n *   \"DeviceClass\"=>\"iPhone\",\n *   \"DeviceColor\"=>\"#c8caca\",\n *   \"DeviceName\"=>\"kazu\",\n *   \"DieID\"=>1111111111111,\n *   \"HardwareModel\"=>\"N69uAP\",\n *   \"HasSiDP\"=>true,\n *   \"PartitionType\"=>\"GUID_partition_scheme\",\n *   \"ProductName\"=>\"iPhone OS\",\n *   \"ProductType\"=>\"iPhone8,4\",\n *   \"ProductVersion\"=>\"15.2\",\n *   \"ProductionSOC\"=>true,\n *   \"ProtocolVersion\"=>\"2\",\n *   \"SupportedDeviceFamilies\"=>[1],\n *   \"TelephonyCapability\"=>true,\n *   \"UniqueChipID\"=>1111111111111,\n *   \"UniqueDeviceID\"=>\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\",\n *   \"WiFiAddress\"=>\"00:00:00:00:00:00\"\n * }\n */\nasync function getDeviceInfo (udid, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    const lockdown = await usbmux.connectLockdown(udid);\n    return await lockdown.getValue();\n  } finally {\n    usbmux.close();\n  }\n}\n\n/**\n * @typedef {Object} DeviceTime\n *\n * @property {number} timestamp Unix timestamp in seconds since 1970-01-01T00:00:00Z\n * @property {number} utcOffset The difference in minutes between the UTC time and the local device time.\n * Can be negative.\n * @property {string} timeZone Time zone name configured on the device, for example `Europe/Paris`\n */\n\n/**\n * Retrieves the local time from the device under test\n *\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {DeviceTime}\n */\nasync function getDeviceTime (udid, socket = null) {\n  const lockdown = await startLockdownSession(udid, socket);\n  try {\n    return {\n      timestamp: await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_TIME),\n      // Apple returns utcOffset in seconds which doesnt comply with the general standard\n      utcOffset: await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_UTC_OFFSET) / 60,\n      timeZone: await lockdown.getValue(LOCKDOWN_REQUEST.DEVICE_TIME_ZONE),\n    };\n  } finally {\n    lockdown.close();\n  }\n}\n\n/**\n * Starts a lockdown session on the given device\n *\n * @param {string} udid Device UDID\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {Lockdown}\n */\nasync function startLockdownSession (udid, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    const pairRecord = await usbmux.readPairRecord(udid);\n    if (!pairRecord) {\n      throw new Error(`Could not find a pair record for device '${udid}'. Please first pair with the device`);\n    }\n    // lockdown doesn't need to be closed since it uses the same socket usbmux uses\n    const lockdown = await usbmux.connectLockdown(udid);\n    await lockdown.startSession(pairRecord.HostID, pairRecord.SystemBUID);\n    lockdown.enableSessionSSL(pairRecord.HostPrivateKey, pairRecord.HostCertificate);\n    return lockdown;\n  } catch (e) {\n    usbmux.close();\n    throw e;\n  }\n}\n\n/**\n * Connects to a given port with the certs and keys used in the pairing process\n *\n * @param {string} udid Device UDID\n * @param {number} port Port to connect\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @param {boolean} handshakeOnly only handshake and return the initial socket\n * @returns {tls.TLSSocket|Object} The socket or the object returned in the callback if the callback function exists\n */\nasync function connectPortSSL (udid, port, socket = null, handshakeOnly = false) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    const device = await usbmux.findDevice(udid);\n    if (!device) {\n      throw new Error(`Could not find the expected device '${udid}'`);\n    }\n    const pairRecord = await usbmux.readPairRecord(udid);\n    if (!pairRecord) {\n      throw new Error(`Could not find a pair record for device '${udid}'. Please first pair with the device`);\n    }\n    const socket = await usbmux.connect(device.Properties.DeviceID, port, undefined);\n    return handshakeOnly ?\n      await enableSSLHandshakeOnly(socket, pairRecord.HostPrivateKey, pairRecord.HostCertificate) :\n      upgradeToSSL(socket, pairRecord.HostPrivateKey, pairRecord.HostCertificate);\n  } catch (e) {\n    usbmux.close();\n    throw e;\n  }\n}\n\n/**\n * Connects to a given port\n *\n * @param {string} udid Device UDID\n * @param {number} port Port to connect\n * @param {?net.Socket} socket the socket of usbmuxd. It will default to /var/run/usbmuxd if it is not passed\n * @returns {net.Socket|Object} The socket or the object returned in the callback if the callback function exists\n */\nasync function connectPort (udid, port, socket = null) {\n  const usbmux = new Usbmux(socket || await getDefaultSocket());\n  try {\n    const device = await usbmux.findDevice(udid);\n    if (!device) {\n      throw new Error(`Could not find the expected device ${udid}`);\n    }\n    return await usbmux.connect(device.Properties.DeviceID, port, undefined);\n  } catch (e) {\n    usbmux.close();\n    throw e;\n  }\n}\n\nexport {\n  getConnectedDevices, getOSVersion, getDeviceName, getDeviceTime,\n  startLockdownSession, connectPort, connectPortSSL, getDeviceInfo\n};\n"],"file":"lib/utilities.js","sourceRoot":"../.."}
|