appium-mac2-driver 1.4.2 → 1.4.4
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 +6 -4
- package/WebDriverAgentMac/WebDriverAgentLib/Commands/FBElementCommands.m +1 -1
- package/WebDriverAgentMac/WebDriverAgentLib/Commands/FBScreenshotCommands.m +2 -3
- package/WebDriverAgentMac/WebDriverAgentLib/Utilities/AMSnapshotUtils.m +1 -1
- package/build/index.js +1 -5
- package/build/lib/commands/app-management.js +1 -4
- package/build/lib/commands/app-management.js.map +1 -0
- package/build/lib/commands/applescript.js +2 -19
- package/build/lib/commands/applescript.js.map +1 -0
- package/build/lib/commands/execute.js +1 -13
- package/build/lib/commands/execute.js.map +1 -0
- package/build/lib/commands/find.js +2 -8
- package/build/lib/commands/find.js.map +1 -0
- package/build/lib/commands/gestures.js +1 -20
- package/build/lib/commands/gestures.js.map +1 -0
- package/build/lib/commands/index.js +3 -13
- package/build/lib/commands/index.js.map +1 -0
- package/build/lib/commands/record-screen.js +1 -63
- package/build/lib/commands/record-screen.js.map +1 -0
- package/build/lib/commands/screenshots.js +2 -4
- package/build/lib/commands/screenshots.js.map +1 -0
- package/build/lib/commands/source.js +1 -4
- package/build/lib/commands/source.js.map +1 -0
- package/build/lib/desired-caps.js +1 -3
- package/build/lib/desired-caps.js.map +1 -0
- package/build/lib/driver.js +1 -33
- package/build/lib/driver.js.map +1 -0
- package/build/lib/logger.js +1 -5
- package/build/lib/logger.js.map +1 -0
- package/build/lib/utils.js +7 -27
- package/build/lib/utils.js.map +1 -0
- package/build/lib/wda-mac.js +2 -109
- package/build/lib/wda-mac.js.map +1 -0
- package/lib/utils.js +7 -15
- package/npm-shrinkwrap.json +1493 -1346
- package/package.json +3 -3
package/build/lib/wda-mac.js
CHANGED
|
@@ -1,46 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.default = void 0;
|
|
9
|
-
|
|
10
8
|
require("source-map-support/register");
|
|
11
|
-
|
|
12
9
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
13
|
-
|
|
14
10
|
var _path = _interopRequireDefault(require("path"));
|
|
15
|
-
|
|
16
11
|
var _url = _interopRequireDefault(require("url"));
|
|
17
|
-
|
|
18
12
|
var _axios = _interopRequireDefault(require("axios"));
|
|
19
|
-
|
|
20
13
|
var _bluebird = _interopRequireDefault(require("bluebird"));
|
|
21
|
-
|
|
22
14
|
var _driver = require("appium/driver");
|
|
23
|
-
|
|
24
15
|
var _support = require("appium/support");
|
|
25
|
-
|
|
26
16
|
var _teen_process = require("teen_process");
|
|
27
|
-
|
|
28
17
|
var _asyncbox = require("asyncbox");
|
|
29
|
-
|
|
30
18
|
var _portscanner = require("portscanner");
|
|
31
|
-
|
|
32
19
|
var _child_process = require("child_process");
|
|
33
|
-
|
|
34
20
|
var _utils = require("./utils");
|
|
35
|
-
|
|
36
21
|
const log = _support.logger.getLogger('WebDriverAgentMac');
|
|
37
|
-
|
|
38
22
|
const DEFAULT_WDA_ROOT = _path.default.resolve((0, _utils.getModuleRoot)(), 'WebDriverAgentMac');
|
|
39
|
-
|
|
40
23
|
const WDA_PROJECT_NAME = 'WebDriverAgentMac.xcodeproj';
|
|
41
|
-
|
|
42
24
|
const WDA_PROJECT = (wdaRoot = DEFAULT_WDA_ROOT) => _path.default.resolve(wdaRoot, WDA_PROJECT_NAME);
|
|
43
|
-
|
|
44
25
|
const RUNNER_SCHEME = 'WebDriverAgentRunner';
|
|
45
26
|
const DISABLE_STORE_ARG = 'COMPILER_INDEX_STORE_ENABLE=NO';
|
|
46
27
|
const XCODEBUILD = 'xcodebuild';
|
|
@@ -49,55 +30,42 @@ const DEFAULT_SYSTEM_PORT = 10100;
|
|
|
49
30
|
const DEFAULT_SYSTEM_HOST = '127.0.0.1';
|
|
50
31
|
const DEFAULT_SHOW_SERVER_LOGS = false;
|
|
51
32
|
const RUNNING_PROCESS_IDS = [];
|
|
52
|
-
|
|
53
33
|
const RECENT_UPGRADE_TIMESTAMP_PATH = _path.default.join('.appium', 'webdriveragent_mac', 'upgrade.time');
|
|
54
|
-
|
|
55
34
|
async function getUpgradeTimestamp() {
|
|
56
35
|
const packageManifest = _path.default.resolve((0, _utils.getModuleRoot)(), 'package.json');
|
|
57
|
-
|
|
58
36
|
if (!(await _support.fs.exists(packageManifest))) {
|
|
59
37
|
return null;
|
|
60
38
|
}
|
|
61
|
-
|
|
62
39
|
const {
|
|
63
40
|
mtime
|
|
64
41
|
} = await _support.fs.stat(packageManifest);
|
|
65
42
|
return mtime.getTime();
|
|
66
43
|
}
|
|
67
|
-
|
|
68
44
|
async function cleanupObsoleteProcesses() {
|
|
69
45
|
if (!_lodash.default.isEmpty(RUNNING_PROCESS_IDS)) {
|
|
70
46
|
log.debug(`Cleaning up ${RUNNING_PROCESS_IDS.length} obsolete ` + _support.util.pluralize('process', RUNNING_PROCESS_IDS.length, false));
|
|
71
|
-
|
|
72
47
|
try {
|
|
73
48
|
await (0, _teen_process.exec)('kill', ['-9', ...RUNNING_PROCESS_IDS]);
|
|
74
49
|
} catch (ign) {}
|
|
75
|
-
|
|
76
50
|
_lodash.default.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);
|
|
77
51
|
}
|
|
78
52
|
}
|
|
79
|
-
|
|
80
53
|
process.once('exit', () => {
|
|
81
54
|
if (!_lodash.default.isEmpty(RUNNING_PROCESS_IDS)) {
|
|
82
55
|
try {
|
|
83
56
|
(0, _child_process.execSync)(`kill -9 ${RUNNING_PROCESS_IDS.join(' ')}`);
|
|
84
57
|
} catch (ign) {}
|
|
85
|
-
|
|
86
58
|
_lodash.default.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);
|
|
87
59
|
}
|
|
88
60
|
});
|
|
89
|
-
|
|
90
61
|
class WDAMacProxy extends _driver.JWProxy {
|
|
91
62
|
async proxyCommand(url, method, body = null) {
|
|
92
63
|
if (this.didProcessExit) {
|
|
93
64
|
throw new _driver.errors.InvalidContextError(`'${method} ${url}' cannot be proxied to Mac2 Driver server because ` + 'its process is not running (probably crashed). Check the Appium log for more details');
|
|
94
65
|
}
|
|
95
|
-
|
|
96
66
|
return await super.proxyCommand(url, method, body);
|
|
97
67
|
}
|
|
98
|
-
|
|
99
68
|
}
|
|
100
|
-
|
|
101
69
|
class WDAMacProcess {
|
|
102
70
|
constructor() {
|
|
103
71
|
this.showServerLogs = DEFAULT_SHOW_SERVER_LOGS;
|
|
@@ -106,38 +74,28 @@ class WDAMacProcess {
|
|
|
106
74
|
this.bootstrapRoot = DEFAULT_WDA_ROOT;
|
|
107
75
|
this.proc = null;
|
|
108
76
|
}
|
|
109
|
-
|
|
110
77
|
get isRunning() {
|
|
111
78
|
var _this$proc;
|
|
112
|
-
|
|
113
79
|
return !!((_this$proc = this.proc) !== null && _this$proc !== void 0 && _this$proc.isRunning);
|
|
114
80
|
}
|
|
115
|
-
|
|
116
81
|
get pid() {
|
|
117
82
|
return this.isRunning ? this.proc.pid : null;
|
|
118
83
|
}
|
|
119
|
-
|
|
120
84
|
async listChildrenPids() {
|
|
121
85
|
return this.pid ? await (0, _utils.listChildrenProcessIds)(this.pid) : [];
|
|
122
86
|
}
|
|
123
|
-
|
|
124
87
|
async isFreshUpgrade() {
|
|
125
88
|
const homeFolder = process.env.HOME;
|
|
126
|
-
|
|
127
89
|
if (!homeFolder) {
|
|
128
90
|
log.info('The HOME folder path cannot be determined');
|
|
129
91
|
return false;
|
|
130
92
|
}
|
|
131
|
-
|
|
132
93
|
const currentUpgradeTimestamp = await getUpgradeTimestamp();
|
|
133
|
-
|
|
134
94
|
if (!_lodash.default.isInteger(currentUpgradeTimestamp)) {
|
|
135
95
|
log.info('It is impossible to determine the timestamp of the package');
|
|
136
96
|
return false;
|
|
137
97
|
}
|
|
138
|
-
|
|
139
98
|
const timestampPath = _path.default.resolve(homeFolder, RECENT_UPGRADE_TIMESTAMP_PATH);
|
|
140
|
-
|
|
141
99
|
if (await _support.fs.exists(timestampPath)) {
|
|
142
100
|
try {
|
|
143
101
|
await _support.fs.access(timestampPath, _support.fs.W_OK);
|
|
@@ -145,21 +103,17 @@ class WDAMacProcess {
|
|
|
145
103
|
log.info(`WebDriverAgent upgrade timestamp at '${timestampPath}' is not writeable`);
|
|
146
104
|
return false;
|
|
147
105
|
}
|
|
148
|
-
|
|
149
106
|
const recentUpgradeTimestamp = parseInt(await _support.fs.readFile(timestampPath, 'utf8'), 10);
|
|
150
|
-
|
|
151
107
|
if (_lodash.default.isInteger(recentUpgradeTimestamp)) {
|
|
152
108
|
if (recentUpgradeTimestamp >= currentUpgradeTimestamp) {
|
|
153
109
|
log.info(`WebDriverAgent sources are up to date ` + `(${recentUpgradeTimestamp} >= ${currentUpgradeTimestamp})`);
|
|
154
110
|
return false;
|
|
155
111
|
}
|
|
156
|
-
|
|
157
112
|
log.info(`WebDriverAgent sources have been upgraded ` + `(${recentUpgradeTimestamp} < ${currentUpgradeTimestamp})`);
|
|
158
113
|
} else {
|
|
159
114
|
log.warn(`The recent upgrade timestamp at '${timestampPath}' is corrupted. Trying to fix it`);
|
|
160
115
|
}
|
|
161
116
|
}
|
|
162
|
-
|
|
163
117
|
try {
|
|
164
118
|
await (0, _support.mkdirp)(_path.default.dirname(timestampPath));
|
|
165
119
|
await _support.fs.writeFile(timestampPath, `${currentUpgradeTimestamp}`, 'utf8');
|
|
@@ -168,10 +122,8 @@ class WDAMacProcess {
|
|
|
168
122
|
log.info(`Unable to create the recent WebDriverAgent upgrade timestamp at '${timestampPath}'. ` + `Original error: ${e.message}`);
|
|
169
123
|
return false;
|
|
170
124
|
}
|
|
171
|
-
|
|
172
125
|
return true;
|
|
173
126
|
}
|
|
174
|
-
|
|
175
127
|
hasSameOpts({
|
|
176
128
|
showServerLogs,
|
|
177
129
|
systemPort,
|
|
@@ -181,53 +133,41 @@ class WDAMacProcess {
|
|
|
181
133
|
if (_lodash.default.isBoolean(showServerLogs) && this.showServerLogs !== showServerLogs || _lodash.default.isNil(showServerLogs) && this.showServerLogs !== DEFAULT_SHOW_SERVER_LOGS) {
|
|
182
134
|
return false;
|
|
183
135
|
}
|
|
184
|
-
|
|
185
136
|
if (systemPort && this.port !== systemPort || !systemPort && this.port !== DEFAULT_SYSTEM_PORT) {
|
|
186
137
|
return false;
|
|
187
138
|
}
|
|
188
|
-
|
|
189
139
|
if (systemHost && this.host !== systemHost || !systemHost && this.host !== DEFAULT_SYSTEM_HOST) {
|
|
190
140
|
return false;
|
|
191
141
|
}
|
|
192
|
-
|
|
193
142
|
if (bootstrapRoot && this.bootstrapRoot !== bootstrapRoot || !bootstrapRoot && this.bootstrapRoot !== DEFAULT_WDA_ROOT) {
|
|
194
143
|
return false;
|
|
195
144
|
}
|
|
196
|
-
|
|
197
145
|
return true;
|
|
198
146
|
}
|
|
199
|
-
|
|
200
147
|
async init(opts = {}) {
|
|
201
148
|
if (this.isRunning && this.hasSameOpts(opts)) {
|
|
202
149
|
return false;
|
|
203
150
|
}
|
|
204
|
-
|
|
205
151
|
this.showServerLogs = opts.showServerLogs ?? this.showServerLogs;
|
|
206
152
|
this.port = opts.systemPort ?? this.port;
|
|
207
153
|
this.host = opts.systemHost ?? this.host;
|
|
208
154
|
this.bootstrapRoot = opts.bootstrapRoot ?? this.bootstrapRoot;
|
|
209
155
|
log.debug(`Using bootstrap root: ${this.bootstrapRoot}`);
|
|
210
|
-
|
|
211
156
|
if (!(await _support.fs.exists(WDA_PROJECT(this.bootstrapRoot)))) {
|
|
212
157
|
throw new Error(`${WDA_PROJECT_NAME} does not exist at '${WDA_PROJECT(this.bootstrapRoot)}'. ` + `Was 'bootstrapRoot' set to a proper value?`);
|
|
213
158
|
}
|
|
214
|
-
|
|
215
159
|
await this.kill();
|
|
216
160
|
await cleanupObsoleteProcesses();
|
|
217
161
|
let xcodebuild;
|
|
218
|
-
|
|
219
162
|
try {
|
|
220
163
|
xcodebuild = await _support.fs.which(XCODEBUILD);
|
|
221
164
|
} catch (e) {
|
|
222
165
|
throw new Error(`${XCODEBUILD} binary cannot be found in PATH. ` + `Please make sure that Xcode is installed on your system`);
|
|
223
166
|
}
|
|
224
|
-
|
|
225
167
|
log.debug(`Using ${XCODEBUILD} binary at '${xcodebuild}'`);
|
|
226
|
-
|
|
227
168
|
if (await this.isFreshUpgrade()) {
|
|
228
169
|
log.info('Performing project cleanup');
|
|
229
170
|
const args = ['clean', '-project', WDA_PROJECT(this.bootstrapRoot), '-scheme', RUNNER_SCHEME];
|
|
230
|
-
|
|
231
171
|
try {
|
|
232
172
|
await (0, _teen_process.exec)(XCODEBUILD, args, {
|
|
233
173
|
cwd: this.bootstrapRoot
|
|
@@ -236,16 +176,12 @@ class WDAMacProcess {
|
|
|
236
176
|
log.warn(`Cannot perform project cleanup. ` + `Original error: ${e.stderr || e.message}`);
|
|
237
177
|
}
|
|
238
178
|
}
|
|
239
|
-
|
|
240
179
|
log.debug(`Using ${this.host} as server host`);
|
|
241
180
|
log.debug(`Using port ${this.port}`);
|
|
242
|
-
|
|
243
181
|
const isPortBusy = async () => (await (0, _portscanner.checkPortStatus)(this.port, this.host)) === 'open';
|
|
244
|
-
|
|
245
182
|
if (await isPortBusy()) {
|
|
246
183
|
log.warn(`The port #${this.port} at ${this.host} is busy. ` + `Assuming it is an obsolete WDA server instance and ` + `trying to terminate it in order to start a new one`);
|
|
247
184
|
const timer = new _support.timing.Timer().start();
|
|
248
|
-
|
|
249
185
|
try {
|
|
250
186
|
await _axios.default.delete(`http://${this.host}:${this.port}/`, {
|
|
251
187
|
timeout: 5000
|
|
@@ -259,10 +195,8 @@ class WDAMacProcess {
|
|
|
259
195
|
log.warn(`Did not know how to terminate the process at ${this.host}:${this.port}: ${e.message}. ` + `Perhaps, it is not a WDA server, which is hogging the port?`);
|
|
260
196
|
throw new Error(`The port #${this.port} at ${this.host} is busy. ` + `Consider setting 'systemPort' capability to another free port number and/or ` + `make sure previous driver sessions have been closed properly.`);
|
|
261
197
|
}
|
|
262
|
-
|
|
263
198
|
log.info(`The previously running WDA server has been successfully terminated after ` + `${Math.round(timer.getDuration().asMilliSeconds)}ms`);
|
|
264
199
|
}
|
|
265
|
-
|
|
266
200
|
const args = ['build-for-testing', 'test-without-building', '-project', WDA_PROJECT(this.bootstrapRoot), '-scheme', RUNNER_SCHEME, DISABLE_STORE_ARG];
|
|
267
201
|
const env = Object.assign({}, process.env, {
|
|
268
202
|
USE_PORT: `${this.port}`,
|
|
@@ -272,18 +206,14 @@ class WDAMacProcess {
|
|
|
272
206
|
cwd: this.bootstrapRoot,
|
|
273
207
|
env
|
|
274
208
|
});
|
|
275
|
-
|
|
276
209
|
if (!this.showServerLogs) {
|
|
277
210
|
log.info(`Mac2Driver host process logging is disabled. ` + `All the ${XCODEBUILD} output is going to be suppressed. ` + `Set the 'showServerLogs' capability to 'true' if this is an undesired behavior`);
|
|
278
211
|
}
|
|
279
|
-
|
|
280
212
|
this.proc.on('output', (stdout, stderr) => {
|
|
281
213
|
if (!this.showServerLogs) {
|
|
282
214
|
return;
|
|
283
215
|
}
|
|
284
|
-
|
|
285
216
|
const line = _lodash.default.trim(stdout || stderr);
|
|
286
|
-
|
|
287
217
|
if (line) {
|
|
288
218
|
log.debug(`[${XCODEBUILD}] ${line}`);
|
|
289
219
|
}
|
|
@@ -295,56 +225,45 @@ class WDAMacProcess {
|
|
|
295
225
|
await this.proc.start(0);
|
|
296
226
|
return true;
|
|
297
227
|
}
|
|
298
|
-
|
|
299
228
|
async stop() {
|
|
300
229
|
if (!this.isRunning) {
|
|
301
230
|
return;
|
|
302
231
|
}
|
|
303
|
-
|
|
304
232
|
const childrenPids = await this.listChildrenPids();
|
|
305
|
-
|
|
306
233
|
if (!_lodash.default.isEmpty(childrenPids)) {
|
|
307
234
|
try {
|
|
308
235
|
await (0, _teen_process.exec)('kill', childrenPids);
|
|
309
236
|
} catch (ign) {}
|
|
310
237
|
}
|
|
311
|
-
|
|
312
238
|
await this.proc.stop('SIGTERM', 3000);
|
|
313
239
|
}
|
|
314
|
-
|
|
315
240
|
async kill() {
|
|
316
241
|
if (!this.isRunning) {
|
|
317
242
|
return;
|
|
318
243
|
}
|
|
319
|
-
|
|
320
244
|
const childrenPids = await this.listChildrenPids();
|
|
321
|
-
|
|
322
245
|
if (!_lodash.default.isEmpty(childrenPids)) {
|
|
323
246
|
try {
|
|
324
247
|
await (0, _teen_process.exec)('kill', ['-9', ...childrenPids]);
|
|
325
248
|
} catch (ign) {}
|
|
326
249
|
}
|
|
327
|
-
|
|
328
250
|
try {
|
|
329
251
|
await this.proc.stop('SIGKILL');
|
|
330
252
|
} catch (ign) {}
|
|
331
253
|
}
|
|
332
|
-
|
|
333
254
|
}
|
|
334
|
-
|
|
335
255
|
class WDAMacServer {
|
|
336
256
|
constructor() {
|
|
337
257
|
this.process = null;
|
|
338
258
|
this.serverStartupTimeoutMs = STARTUP_TIMEOUT_MS;
|
|
339
259
|
this.proxy = null;
|
|
260
|
+
|
|
340
261
|
this.isProxyingToRemoteServer = false;
|
|
341
262
|
}
|
|
342
|
-
|
|
343
263
|
async isProxyReady(throwOnExit = true) {
|
|
344
264
|
if (!this.proxy) {
|
|
345
265
|
return false;
|
|
346
266
|
}
|
|
347
|
-
|
|
348
267
|
try {
|
|
349
268
|
await this.proxy.command('/status', 'GET');
|
|
350
269
|
return true;
|
|
@@ -352,17 +271,14 @@ class WDAMacServer {
|
|
|
352
271
|
if (throwOnExit && this.proxy.didProcessExit) {
|
|
353
272
|
throw new Error(err.message);
|
|
354
273
|
}
|
|
355
|
-
|
|
356
274
|
return false;
|
|
357
275
|
}
|
|
358
276
|
}
|
|
359
277
|
|
|
360
278
|
parseProxyProperties(caps) {
|
|
361
279
|
let scheme = 'http';
|
|
362
|
-
|
|
363
280
|
if (!caps.webDriverAgentMacUrl) {
|
|
364
281
|
var _this$process, _this$process2;
|
|
365
|
-
|
|
366
282
|
return {
|
|
367
283
|
scheme,
|
|
368
284
|
server: ((_this$process = this.process) === null || _this$process === void 0 ? void 0 : _this$process.host) ?? caps.systemHost ?? DEFAULT_SYSTEM_HOST,
|
|
@@ -370,26 +286,21 @@ class WDAMacServer {
|
|
|
370
286
|
path: ''
|
|
371
287
|
};
|
|
372
288
|
}
|
|
373
|
-
|
|
374
289
|
let parsedUrl;
|
|
375
|
-
|
|
376
290
|
try {
|
|
377
291
|
parsedUrl = new _url.default.URL(caps.webDriverAgentMacUrl);
|
|
378
292
|
} catch (e) {
|
|
379
293
|
throw new Error(`webDriverAgentMacUrl, '${caps.webDriverAgentMacUrl}', ` + `in the capabilities is invalid. ${e.message}`);
|
|
380
294
|
}
|
|
381
|
-
|
|
382
295
|
const {
|
|
383
296
|
protocol,
|
|
384
297
|
hostname,
|
|
385
298
|
port,
|
|
386
299
|
pathname
|
|
387
300
|
} = parsedUrl;
|
|
388
|
-
|
|
389
301
|
if (_lodash.default.isString(protocol)) {
|
|
390
302
|
scheme = protocol.split(':')[0];
|
|
391
303
|
}
|
|
392
|
-
|
|
393
304
|
return {
|
|
394
305
|
scheme,
|
|
395
306
|
server: hostname ?? DEFAULT_SYSTEM_HOST,
|
|
@@ -397,28 +308,23 @@ class WDAMacServer {
|
|
|
397
308
|
path: pathname === '/' ? '' : pathname
|
|
398
309
|
};
|
|
399
310
|
}
|
|
400
|
-
|
|
401
311
|
async startSession(caps) {
|
|
402
312
|
this.serverStartupTimeoutMs = caps.serverStartupTimeout ?? this.serverStartupTimeoutMs;
|
|
403
313
|
this.isProxyingToRemoteServer = !!caps.webDriverAgentMacUrl;
|
|
404
314
|
let wasProcessInitNecessary;
|
|
405
|
-
|
|
406
315
|
if (this.isProxyingToRemoteServer) {
|
|
407
316
|
if (this.process) {
|
|
408
317
|
await this.process.kill();
|
|
409
318
|
await cleanupObsoleteProcesses();
|
|
410
319
|
this.process = null;
|
|
411
320
|
}
|
|
412
|
-
|
|
413
321
|
wasProcessInitNecessary = false;
|
|
414
322
|
} else {
|
|
415
323
|
if (!this.process) {
|
|
416
324
|
this.process = new WDAMacProcess();
|
|
417
325
|
}
|
|
418
|
-
|
|
419
326
|
wasProcessInitNecessary = await this.process.init(caps);
|
|
420
327
|
}
|
|
421
|
-
|
|
422
328
|
if (wasProcessInitNecessary || this.isProxyingToRemoteServer || !this.proxy) {
|
|
423
329
|
const {
|
|
424
330
|
scheme,
|
|
@@ -434,15 +340,12 @@ class WDAMacServer {
|
|
|
434
340
|
keepAlive: true
|
|
435
341
|
});
|
|
436
342
|
this.proxy.didProcessExit = false;
|
|
437
|
-
|
|
438
343
|
if (this.process) {
|
|
439
344
|
this.process.proc.on('exit', () => {
|
|
440
345
|
this.proxy.didProcessExit = true;
|
|
441
346
|
});
|
|
442
347
|
}
|
|
443
|
-
|
|
444
348
|
const timer = new _support.timing.Timer().start();
|
|
445
|
-
|
|
446
349
|
try {
|
|
447
350
|
await (0, _asyncbox.waitForCondition)(async () => await this.isProxyReady(), {
|
|
448
351
|
waitMs: this.serverStartupTimeoutMs,
|
|
@@ -450,19 +353,15 @@ class WDAMacServer {
|
|
|
450
353
|
});
|
|
451
354
|
} catch (e) {
|
|
452
355
|
var _this$process3;
|
|
453
|
-
|
|
454
356
|
if ((_this$process3 = this.process) !== null && _this$process3 !== void 0 && _this$process3.isRunning) {
|
|
455
357
|
await this.process.kill();
|
|
456
358
|
}
|
|
457
|
-
|
|
458
359
|
if (/Condition unmet/.test(e.message)) {
|
|
459
360
|
const msg = this.isProxyingToRemoteServer ? `No response from '${scheme}://${server}:${port}${path}' within ${this.serverStartupTimeoutMs}ms timeout.` + `Please make sure the remote server is running and accessible by Appium` : `Mac2Driver server is not listening within ${this.serverStartupTimeoutMs}ms timeout. ` + `Try to increase the value of 'serverStartupTimeout' capability, check the server logs ` + `and make sure the ${XCODEBUILD} host process could be started manually from a terminal`;
|
|
460
361
|
throw new Error(msg);
|
|
461
362
|
}
|
|
462
|
-
|
|
463
363
|
throw e;
|
|
464
364
|
}
|
|
465
|
-
|
|
466
365
|
if (this.process) {
|
|
467
366
|
const pid = this.process.pid;
|
|
468
367
|
const childrenPids = await this.process.listChildrenPids();
|
|
@@ -473,7 +372,6 @@ class WDAMacServer {
|
|
|
473
372
|
} else {
|
|
474
373
|
log.info('The host process has already been listening. Proceeding with session creation');
|
|
475
374
|
}
|
|
476
|
-
|
|
477
375
|
await this.proxy.command('/session', 'POST', {
|
|
478
376
|
capabilities: {
|
|
479
377
|
firstMatch: [{}],
|
|
@@ -481,15 +379,12 @@ class WDAMacServer {
|
|
|
481
379
|
}
|
|
482
380
|
});
|
|
483
381
|
}
|
|
484
|
-
|
|
485
382
|
async stopSession() {
|
|
486
383
|
var _this$process4, _this$proxy;
|
|
487
|
-
|
|
488
384
|
if (!this.isProxyingToRemoteServer && !((_this$process4 = this.process) !== null && _this$process4 !== void 0 && _this$process4.isRunning)) {
|
|
489
385
|
log.info(`Mac2Driver session cannot be stopped, because the server is not running`);
|
|
490
386
|
return;
|
|
491
387
|
}
|
|
492
|
-
|
|
493
388
|
if ((_this$proxy = this.proxy) !== null && _this$proxy !== void 0 && _this$proxy.sessionId) {
|
|
494
389
|
try {
|
|
495
390
|
await this.proxy.command(`/session/${this.proxy.sessionId}`, 'DELETE');
|
|
@@ -498,10 +393,8 @@ class WDAMacServer {
|
|
|
498
393
|
}
|
|
499
394
|
}
|
|
500
395
|
}
|
|
501
|
-
|
|
502
396
|
}
|
|
503
|
-
|
|
504
397
|
const WDA_MAC_SERVER = new WDAMacServer();
|
|
505
398
|
var _default = WDA_MAC_SERVER;
|
|
506
399
|
exports.default = _default;
|
|
507
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","logger","getLogger","DEFAULT_WDA_ROOT","path","resolve","getModuleRoot","WDA_PROJECT_NAME","WDA_PROJECT","wdaRoot","RUNNER_SCHEME","DISABLE_STORE_ARG","XCODEBUILD","STARTUP_TIMEOUT_MS","DEFAULT_SYSTEM_PORT","DEFAULT_SYSTEM_HOST","DEFAULT_SHOW_SERVER_LOGS","RUNNING_PROCESS_IDS","RECENT_UPGRADE_TIMESTAMP_PATH","join","getUpgradeTimestamp","packageManifest","fs","exists","mtime","stat","getTime","cleanupObsoleteProcesses","_","isEmpty","debug","length","util","pluralize","exec","ign","pullAll","process","once","execSync","WDAMacProxy","JWProxy","proxyCommand","url","method","body","didProcessExit","errors","InvalidContextError","WDAMacProcess","constructor","showServerLogs","port","host","bootstrapRoot","proc","isRunning","pid","listChildrenPids","listChildrenProcessIds","isFreshUpgrade","homeFolder","env","HOME","info","currentUpgradeTimestamp","isInteger","timestampPath","access","W_OK","recentUpgradeTimestamp","parseInt","readFile","warn","mkdirp","dirname","writeFile","e","message","hasSameOpts","systemPort","systemHost","isBoolean","isNil","init","opts","Error","kill","xcodebuild","which","args","cwd","stderr","isPortBusy","checkPortStatus","timer","timing","Timer","start","axios","delete","timeout","B","delay","waitForCondition","waitMs","intervalMs","Math","round","getDuration","asMilliSeconds","Object","assign","USE_PORT","USE_HOST","SubProcess","on","stdout","line","trim","code","signal","quote","stop","childrenPids","WDAMacServer","serverStartupTimeoutMs","proxy","isProxyingToRemoteServer","isProxyReady","throwOnExit","command","err","parseProxyProperties","caps","scheme","webDriverAgentMacUrl","server","parsedUrl","URL","protocol","hostname","pathname","isString","split","startSession","serverStartupTimeout","wasProcessInitNecessary","base","keepAlive","test","msg","push","pull","toFixed","capabilities","firstMatch","alwaysMatch","stopSession","sessionId","WDA_MAC_SERVER"],"sources":["../../lib/wda-mac.js"],"sourcesContent":["import _ from 'lodash';\nimport path from 'path';\nimport url from 'url';\nimport axios from 'axios';\nimport B from 'bluebird';\nimport { JWProxy, errors } from 'appium/driver';\nimport { fs, logger, util, timing, mkdirp } from 'appium/support';\nimport { SubProcess, exec } from 'teen_process';\nimport { waitForCondition } from 'asyncbox';\nimport { checkPortStatus } from 'portscanner';\nimport { execSync } from 'child_process';\nimport { listChildrenProcessIds, getModuleRoot } from './utils';\n\nconst log = logger.getLogger('WebDriverAgentMac');\n\nconst DEFAULT_WDA_ROOT = path.resolve(getModuleRoot(), 'WebDriverAgentMac');\nconst WDA_PROJECT_NAME = 'WebDriverAgentMac.xcodeproj';\nconst WDA_PROJECT = (wdaRoot = DEFAULT_WDA_ROOT) => path.resolve(wdaRoot, WDA_PROJECT_NAME);\nconst RUNNER_SCHEME = 'WebDriverAgentRunner';\nconst DISABLE_STORE_ARG = 'COMPILER_INDEX_STORE_ENABLE=NO';\nconst XCODEBUILD = 'xcodebuild';\nconst STARTUP_TIMEOUT_MS = 120000;\nconst DEFAULT_SYSTEM_PORT = 10100;\nconst DEFAULT_SYSTEM_HOST = '127.0.0.1';\nconst DEFAULT_SHOW_SERVER_LOGS = false;\nconst RUNNING_PROCESS_IDS = [];\nconst RECENT_UPGRADE_TIMESTAMP_PATH = path.join('.appium', 'webdriveragent_mac', 'upgrade.time');\n\n\nasync function getUpgradeTimestamp () {\n  const packageManifest = path.resolve(getModuleRoot(), 'package.json');\n  if (!await fs.exists(packageManifest)) {\n    return null;\n  }\n  const {mtime} = await fs.stat(packageManifest);\n  return mtime.getTime();\n}\n\nasync function cleanupObsoleteProcesses () {\n  if (!_.isEmpty(RUNNING_PROCESS_IDS)) {\n    log.debug(`Cleaning up ${RUNNING_PROCESS_IDS.length} obsolete ` +\n      util.pluralize('process', RUNNING_PROCESS_IDS.length, false));\n    try {\n      await exec('kill', ['-9', ...RUNNING_PROCESS_IDS]);\n    } catch (ign) {}\n    _.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);\n  }\n}\n\nprocess.once('exit', () => {\n  if (!_.isEmpty(RUNNING_PROCESS_IDS)) {\n    try {\n      execSync(`kill -9 ${RUNNING_PROCESS_IDS.join(' ')}`);\n    } catch (ign) {}\n    _.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);\n  }\n});\n\n\nclass WDAMacProxy extends JWProxy {\n  async proxyCommand (url, method, body = null) {\n    if (this.didProcessExit) {\n      throw new errors.InvalidContextError(\n        `'${method} ${url}' cannot be proxied to Mac2 Driver server because ` +\n        'its process is not running (probably crashed). Check the Appium log for more details');\n    }\n    return await super.proxyCommand(url, method, body);\n  }\n}\n\nclass WDAMacProcess {\n  constructor () {\n    this.showServerLogs = DEFAULT_SHOW_SERVER_LOGS;\n    this.port = DEFAULT_SYSTEM_PORT;\n    this.host = DEFAULT_SYSTEM_HOST;\n    this.bootstrapRoot = DEFAULT_WDA_ROOT;\n    this.proc = null;\n  }\n\n  get isRunning () {\n    return !!(this.proc?.isRunning);\n  }\n\n  get pid () {\n    return this.isRunning ? this.proc.pid : null;\n  }\n\n  async listChildrenPids () {\n    return this.pid ? (await listChildrenProcessIds(this.pid)) : [];\n  }\n\n  async isFreshUpgrade () {\n    const homeFolder = process.env.HOME;\n    if (!homeFolder) {\n      log.info('The HOME folder path cannot be determined');\n      return false;\n    }\n\n    const currentUpgradeTimestamp = await getUpgradeTimestamp();\n    if (!_.isInteger(currentUpgradeTimestamp)) {\n      log.info('It is impossible to determine the timestamp of the package');\n      return false;\n    }\n\n    const timestampPath = path.resolve(homeFolder, RECENT_UPGRADE_TIMESTAMP_PATH);\n    if (await fs.exists(timestampPath)) {\n      try {\n        await fs.access(timestampPath, fs.W_OK);\n      } catch (ign) {\n        log.info(`WebDriverAgent upgrade timestamp at '${timestampPath}' is not writeable`);\n        return false;\n      }\n      const recentUpgradeTimestamp = parseInt(await fs.readFile(timestampPath, 'utf8'), 10);\n      if (_.isInteger(recentUpgradeTimestamp)) {\n        if (recentUpgradeTimestamp >= currentUpgradeTimestamp) {\n          log.info(`WebDriverAgent sources are up to date ` +\n            `(${recentUpgradeTimestamp} >= ${currentUpgradeTimestamp})`);\n          return false;\n        }\n        log.info(`WebDriverAgent sources have been upgraded ` +\n          `(${recentUpgradeTimestamp} < ${currentUpgradeTimestamp})`);\n      } else {\n        log.warn(`The recent upgrade timestamp at '${timestampPath}' is corrupted. Trying to fix it`);\n      }\n    }\n\n    try {\n      await mkdirp(path.dirname(timestampPath));\n      await fs.writeFile(timestampPath, `${currentUpgradeTimestamp}`, 'utf8');\n      log.debug(`Stored the recent WebDriverAgent upgrade timestamp ${currentUpgradeTimestamp} ` +\n        `at '${timestampPath}'`);\n    } catch (e) {\n      log.info(`Unable to create the recent WebDriverAgent upgrade timestamp at '${timestampPath}'. ` +\n        `Original error: ${e.message}`);\n      return false;\n    }\n\n    return true;\n  }\n\n  hasSameOpts ({ showServerLogs, systemPort, systemHost, bootstrapRoot }) {\n    if (_.isBoolean(showServerLogs) && this.showServerLogs !== showServerLogs\n      || _.isNil(showServerLogs) && this.showServerLogs !== DEFAULT_SHOW_SERVER_LOGS) {\n      return false;\n    }\n    if (systemPort && this.port !== systemPort\n      || !systemPort && this.port !== DEFAULT_SYSTEM_PORT) {\n      return false;\n    }\n    if (systemHost && this.host !== systemHost\n      || !systemHost && this.host !== DEFAULT_SYSTEM_HOST) {\n      return false;\n    }\n    if (bootstrapRoot && this.bootstrapRoot !== bootstrapRoot\n      || !bootstrapRoot && this.bootstrapRoot !== DEFAULT_WDA_ROOT) {\n      return false;\n    }\n\n    return true;\n  }\n\n  async init (opts = {}) {\n    if (this.isRunning && this.hasSameOpts(opts)) {\n      return false;\n    }\n\n    this.showServerLogs = opts.showServerLogs ?? this.showServerLogs;\n    this.port = opts.systemPort ?? this.port;\n    this.host = opts.systemHost ?? this.host;\n    this.bootstrapRoot = opts.bootstrapRoot ?? this.bootstrapRoot;\n\n    log.debug(`Using bootstrap root: ${this.bootstrapRoot}`);\n    if (!await fs.exists(WDA_PROJECT(this.bootstrapRoot))) {\n      throw new Error(`${WDA_PROJECT_NAME} does not exist at '${WDA_PROJECT(this.bootstrapRoot)}'. ` +\n        `Was 'bootstrapRoot' set to a proper value?`);\n    }\n\n    await this.kill();\n    await cleanupObsoleteProcesses();\n\n    let xcodebuild;\n    try {\n      xcodebuild = await fs.which(XCODEBUILD);\n    } catch (e) {\n      throw new Error(`${XCODEBUILD} binary cannot be found in PATH. ` +\n        `Please make sure that Xcode is installed on your system`);\n    }\n    log.debug(`Using ${XCODEBUILD} binary at '${xcodebuild}'`);\n\n    if (await this.isFreshUpgrade()) {\n      log.info('Performing project cleanup');\n      const args = [\n        'clean',\n        '-project', WDA_PROJECT(this.bootstrapRoot),\n        '-scheme', RUNNER_SCHEME,\n      ];\n      try {\n        await exec(XCODEBUILD, args, {\n          cwd: this.bootstrapRoot,\n        });\n      } catch (e) {\n        log.warn(`Cannot perform project cleanup. ` +\n          `Original error: ${e.stderr || e.message}`);\n      }\n    }\n\n    log.debug(`Using ${this.host} as server host`);\n    log.debug(`Using port ${this.port}`);\n    const isPortBusy = async () => (await checkPortStatus(this.port, this.host)) === 'open';\n    if (await isPortBusy()) {\n      log.warn(`The port #${this.port} at ${this.host} is busy. ` +\n        `Assuming it is an obsolete WDA server instance and ` +\n        `trying to terminate it in order to start a new one`);\n      const timer = new timing.Timer().start();\n      try {\n        await axios.delete(`http://${this.host}:${this.port}/`, {\n          timeout: 5000,\n        });\n        // Give the server some time to finish and stop listening\n        await B.delay(500);\n        await waitForCondition(async () => !(await isPortBusy()), {\n          waitMs: 3000,\n          intervalMs: 100,\n        });\n      } catch (e) {\n        log.warn(`Did not know how to terminate the process at ${this.host}:${this.port}: ${e.message}. ` +\n          `Perhaps, it is not a WDA server, which is hogging the port?`);\n        throw new Error(`The port #${this.port} at ${this.host} is busy. ` +\n          `Consider setting 'systemPort' capability to another free port number and/or ` +\n          `make sure previous driver sessions have been closed properly.`);\n      }\n      log.info(`The previously running WDA server has been successfully terminated after ` +\n        `${Math.round(timer.getDuration().asMilliSeconds)}ms`);\n    }\n\n    const args = [\n      'build-for-testing', 'test-without-building',\n      '-project', WDA_PROJECT(this.bootstrapRoot),\n      '-scheme', RUNNER_SCHEME,\n      DISABLE_STORE_ARG,\n    ];\n    const env = Object.assign({}, process.env, {\n      USE_PORT: `${this.port}`,\n      USE_HOST: this.host,\n    });\n    this.proc = new SubProcess(xcodebuild, args, {\n      cwd: this.bootstrapRoot,\n      env,\n    });\n    if (!this.showServerLogs) {\n      log.info(`Mac2Driver host process logging is disabled. ` +\n        `All the ${XCODEBUILD} output is going to be suppressed. ` +\n        `Set the 'showServerLogs' capability to 'true' if this is an undesired behavior`);\n    }\n    this.proc.on('output', (stdout, stderr) => {\n      if (!this.showServerLogs) {\n        return;\n      }\n\n      const line = _.trim(stdout || stderr);\n      if (line) {\n        log.debug(`[${XCODEBUILD}] ${line}`);\n      }\n    });\n    this.proc.on('exit', (code, signal) => {\n      log.info(`Mac2Driver host process has exited with code ${code}, signal ${signal}`);\n    });\n    log.info(`Starting Mac2Driver host process: ${XCODEBUILD} ${util.quote(args)}`);\n    await this.proc.start(0);\n    return true;\n  }\n\n  async stop () {\n    if (!this.isRunning) {\n      return;\n    }\n\n    const childrenPids = await this.listChildrenPids();\n    if (!_.isEmpty(childrenPids)) {\n      try {\n        await exec('kill', childrenPids);\n      } catch (ign) {}\n    }\n    await this.proc.stop('SIGTERM', 3000);\n  }\n\n  async kill () {\n    if (!this.isRunning) {\n      return;\n    }\n\n    const childrenPids = await this.listChildrenPids();\n    if (!_.isEmpty(childrenPids)) {\n      try {\n        await exec('kill', ['-9', ...childrenPids]);\n      } catch (ign) {}\n    }\n    try {\n      await this.proc.stop('SIGKILL');\n    } catch (ign) {}\n  }\n}\n\nclass WDAMacServer {\n  constructor () {\n    this.process = null;\n    this.serverStartupTimeoutMs = STARTUP_TIMEOUT_MS;\n    this.proxy = null;\n\n    // To handle if the WDAMac server is proxying requests to a remote WDAMac app instance\n    this.isProxyingToRemoteServer = false;\n  }\n\n  async isProxyReady (throwOnExit = true) {\n    if (!this.proxy) {\n      return false;\n    }\n\n    try {\n      await this.proxy.command('/status', 'GET');\n      return true;\n    } catch (err) {\n      if (throwOnExit && this.proxy.didProcessExit) {\n        throw new Error(err.message);\n      }\n      return false;\n    }\n  }\n\n\n  /**\n   * @typedef {Object} ProxyProperties\n   *\n   * @property {string} scheme - The scheme proxy to.\n   * @property {string} host - The host name proxy to.\n   * @property {number} port - The port number proxy to.\n   * @property {string} path - The path proxy to.\n   */\n\n  /**\n   * Returns proxy information where WDAMacServer proxy to.\n   *\n   * @param {Object} caps - The capabilities in the session.\n   * @return {ProxyProperties}\n   * @throws Error if 'webDriverAgentMacUrl' had invalid URL\n   */\n  parseProxyProperties (caps) {\n    let scheme = 'http';\n    if (!caps.webDriverAgentMacUrl) {\n      return {\n        scheme,\n        server: (this.process?.host ?? caps.systemHost) ?? DEFAULT_SYSTEM_HOST,\n        port: (this.process?.port ?? caps.systemPort) ?? DEFAULT_SYSTEM_PORT,\n        path: ''\n      };\n    }\n\n    let parsedUrl;\n    try {\n      parsedUrl = new url.URL(caps.webDriverAgentMacUrl);\n    } catch (e) {\n      throw new Error(`webDriverAgentMacUrl, '${caps.webDriverAgentMacUrl}', ` +\n        `in the capabilities is invalid. ${e.message}`);\n    }\n\n    const { protocol, hostname, port, pathname } = parsedUrl;\n    if (_.isString(protocol)) {\n      scheme = protocol.split(':')[0];\n    }\n    return {\n      scheme,\n      server: hostname ?? DEFAULT_SYSTEM_HOST,\n      port: _.isEmpty(port) ? DEFAULT_SYSTEM_PORT : _.parseInt(port),\n      path: pathname === '/' ? '' : pathname\n    };\n  }\n\n  async startSession (caps) {\n    this.serverStartupTimeoutMs = caps.serverStartupTimeout ?? this.serverStartupTimeoutMs;\n\n    this.isProxyingToRemoteServer = !!caps.webDriverAgentMacUrl;\n\n    let wasProcessInitNecessary;\n    if (this.isProxyingToRemoteServer) {\n      if (this.process) {\n        await this.process.kill();\n        await cleanupObsoleteProcesses();\n        this.process = null;\n      }\n\n      wasProcessInitNecessary = false;\n    } else {\n      if (!this.process) {\n        this.process = new WDAMacProcess();\n      }\n      wasProcessInitNecessary = await this.process.init(caps);\n    }\n\n    if (wasProcessInitNecessary || this.isProxyingToRemoteServer || !this.proxy) {\n      const {scheme, server, port, path} = this.parseProxyProperties(caps);\n      this.proxy = new WDAMacProxy({\n        scheme,\n        server,\n        port,\n        base: path,\n        keepAlive: true,\n      });\n      this.proxy.didProcessExit = false;\n\n      if (this.process) {\n        this.process.proc.on('exit', () => {\n          this.proxy.didProcessExit = true;\n        });\n      }\n\n      const timer = new timing.Timer().start();\n      try {\n        await waitForCondition(async () => await this.isProxyReady(), {\n          waitMs: this.serverStartupTimeoutMs,\n          intervalMs: 1000,\n        });\n      } catch (e) {\n        if (this.process?.isRunning) {\n          // avoid \"frozen\" processes,\n          await this.process.kill();\n        }\n        if (/Condition unmet/.test(e.message)) {\n          const msg = this.isProxyingToRemoteServer\n            ? `No response from '${scheme}://${server}:${port}${path}' within ${this.serverStartupTimeoutMs}ms timeout.` +\n            `Please make sure the remote server is running and accessible by Appium`\n            : `Mac2Driver server is not listening within ${this.serverStartupTimeoutMs}ms timeout. ` +\n            `Try to increase the value of 'serverStartupTimeout' capability, check the server logs ` +\n            `and make sure the ${XCODEBUILD} host process could be started manually from a terminal`;\n          throw new Error(msg);\n        }\n        throw e;\n      }\n\n      if (this.process) {\n        const pid = this.process.pid;\n        const childrenPids = await this.process.listChildrenPids();\n        RUNNING_PROCESS_IDS.push(...childrenPids, pid);\n        this.process.proc.on('exit', () => void _.pull(RUNNING_PROCESS_IDS, pid));\n        log.info(`The host process is ready within ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n      }\n    } else {\n      log.info('The host process has already been listening. Proceeding with session creation');\n    }\n\n    await this.proxy.command('/session', 'POST', {\n      capabilities: {\n        firstMatch: [{}],\n        alwaysMatch: caps,\n      }\n    });\n  }\n\n  async stopSession () {\n    if (!this.isProxyingToRemoteServer && !(this.process?.isRunning)) {\n      log.info(`Mac2Driver session cannot be stopped, because the server is not running`);\n      return;\n    }\n\n    if (this.proxy?.sessionId) {\n      try {\n        await this.proxy.command(`/session/${this.proxy.sessionId}`, 'DELETE');\n      } catch (e) {\n        log.info(`Mac2Driver session cannot be deleted. Original error: ${e.message}`);\n      }\n    }\n  }\n}\n\nconst WDA_MAC_SERVER = new WDAMacServer();\n\nexport default WDA_MAC_SERVER;\n"],"mappings":"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"}
|
|
400
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","logger","getLogger","DEFAULT_WDA_ROOT","path","resolve","getModuleRoot","WDA_PROJECT_NAME","WDA_PROJECT","wdaRoot","RUNNER_SCHEME","DISABLE_STORE_ARG","XCODEBUILD","STARTUP_TIMEOUT_MS","DEFAULT_SYSTEM_PORT","DEFAULT_SYSTEM_HOST","DEFAULT_SHOW_SERVER_LOGS","RUNNING_PROCESS_IDS","RECENT_UPGRADE_TIMESTAMP_PATH","join","getUpgradeTimestamp","packageManifest","fs","exists","mtime","stat","getTime","cleanupObsoleteProcesses","_","isEmpty","debug","length","util","pluralize","exec","ign","pullAll","process","once","execSync","WDAMacProxy","JWProxy","proxyCommand","url","method","body","didProcessExit","errors","InvalidContextError","WDAMacProcess","constructor","showServerLogs","port","host","bootstrapRoot","proc","isRunning","pid","listChildrenPids","listChildrenProcessIds","isFreshUpgrade","homeFolder","env","HOME","info","currentUpgradeTimestamp","isInteger","timestampPath","access","W_OK","recentUpgradeTimestamp","parseInt","readFile","warn","mkdirp","dirname","writeFile","e","message","hasSameOpts","systemPort","systemHost","isBoolean","isNil","init","opts","Error","kill","xcodebuild","which","args","cwd","stderr","isPortBusy","checkPortStatus","timer","timing","Timer","start","axios","delete","timeout","B","delay","waitForCondition","waitMs","intervalMs","Math","round","getDuration","asMilliSeconds","Object","assign","USE_PORT","USE_HOST","SubProcess","on","stdout","line","trim","code","signal","quote","stop","childrenPids","WDAMacServer","serverStartupTimeoutMs","proxy","isProxyingToRemoteServer","isProxyReady","throwOnExit","command","err","parseProxyProperties","caps","scheme","webDriverAgentMacUrl","server","parsedUrl","URL","protocol","hostname","pathname","isString","split","startSession","serverStartupTimeout","wasProcessInitNecessary","base","keepAlive","test","msg","push","pull","toFixed","capabilities","firstMatch","alwaysMatch","stopSession","sessionId","WDA_MAC_SERVER"],"sources":["../../lib/wda-mac.js"],"sourcesContent":["import _ from 'lodash';\nimport path from 'path';\nimport url from 'url';\nimport axios from 'axios';\nimport B from 'bluebird';\nimport { JWProxy, errors } from 'appium/driver';\nimport { fs, logger, util, timing, mkdirp } from 'appium/support';\nimport { SubProcess, exec } from 'teen_process';\nimport { waitForCondition } from 'asyncbox';\nimport { checkPortStatus } from 'portscanner';\nimport { execSync } from 'child_process';\nimport { listChildrenProcessIds, getModuleRoot } from './utils';\n\nconst log = logger.getLogger('WebDriverAgentMac');\n\nconst DEFAULT_WDA_ROOT = path.resolve(getModuleRoot(), 'WebDriverAgentMac');\nconst WDA_PROJECT_NAME = 'WebDriverAgentMac.xcodeproj';\nconst WDA_PROJECT = (wdaRoot = DEFAULT_WDA_ROOT) => path.resolve(wdaRoot, WDA_PROJECT_NAME);\nconst RUNNER_SCHEME = 'WebDriverAgentRunner';\nconst DISABLE_STORE_ARG = 'COMPILER_INDEX_STORE_ENABLE=NO';\nconst XCODEBUILD = 'xcodebuild';\nconst STARTUP_TIMEOUT_MS = 120000;\nconst DEFAULT_SYSTEM_PORT = 10100;\nconst DEFAULT_SYSTEM_HOST = '127.0.0.1';\nconst DEFAULT_SHOW_SERVER_LOGS = false;\nconst RUNNING_PROCESS_IDS = [];\nconst RECENT_UPGRADE_TIMESTAMP_PATH = path.join('.appium', 'webdriveragent_mac', 'upgrade.time');\n\n\nasync function getUpgradeTimestamp () {\n  const packageManifest = path.resolve(getModuleRoot(), 'package.json');\n  if (!await fs.exists(packageManifest)) {\n    return null;\n  }\n  const {mtime} = await fs.stat(packageManifest);\n  return mtime.getTime();\n}\n\nasync function cleanupObsoleteProcesses () {\n  if (!_.isEmpty(RUNNING_PROCESS_IDS)) {\n    log.debug(`Cleaning up ${RUNNING_PROCESS_IDS.length} obsolete ` +\n      util.pluralize('process', RUNNING_PROCESS_IDS.length, false));\n    try {\n      await exec('kill', ['-9', ...RUNNING_PROCESS_IDS]);\n    } catch (ign) {}\n    _.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);\n  }\n}\n\nprocess.once('exit', () => {\n  if (!_.isEmpty(RUNNING_PROCESS_IDS)) {\n    try {\n      execSync(`kill -9 ${RUNNING_PROCESS_IDS.join(' ')}`);\n    } catch (ign) {}\n    _.pullAll(RUNNING_PROCESS_IDS, RUNNING_PROCESS_IDS);\n  }\n});\n\n\nclass WDAMacProxy extends JWProxy {\n  async proxyCommand (url, method, body = null) {\n    if (this.didProcessExit) {\n      throw new errors.InvalidContextError(\n        `'${method} ${url}' cannot be proxied to Mac2 Driver server because ` +\n        'its process is not running (probably crashed). Check the Appium log for more details');\n    }\n    return await super.proxyCommand(url, method, body);\n  }\n}\n\nclass WDAMacProcess {\n  constructor () {\n    this.showServerLogs = DEFAULT_SHOW_SERVER_LOGS;\n    this.port = DEFAULT_SYSTEM_PORT;\n    this.host = DEFAULT_SYSTEM_HOST;\n    this.bootstrapRoot = DEFAULT_WDA_ROOT;\n    this.proc = null;\n  }\n\n  get isRunning () {\n    return !!(this.proc?.isRunning);\n  }\n\n  get pid () {\n    return this.isRunning ? this.proc.pid : null;\n  }\n\n  async listChildrenPids () {\n    return this.pid ? (await listChildrenProcessIds(this.pid)) : [];\n  }\n\n  async isFreshUpgrade () {\n    const homeFolder = process.env.HOME;\n    if (!homeFolder) {\n      log.info('The HOME folder path cannot be determined');\n      return false;\n    }\n\n    const currentUpgradeTimestamp = await getUpgradeTimestamp();\n    if (!_.isInteger(currentUpgradeTimestamp)) {\n      log.info('It is impossible to determine the timestamp of the package');\n      return false;\n    }\n\n    const timestampPath = path.resolve(homeFolder, RECENT_UPGRADE_TIMESTAMP_PATH);\n    if (await fs.exists(timestampPath)) {\n      try {\n        await fs.access(timestampPath, fs.W_OK);\n      } catch (ign) {\n        log.info(`WebDriverAgent upgrade timestamp at '${timestampPath}' is not writeable`);\n        return false;\n      }\n      const recentUpgradeTimestamp = parseInt(await fs.readFile(timestampPath, 'utf8'), 10);\n      if (_.isInteger(recentUpgradeTimestamp)) {\n        if (recentUpgradeTimestamp >= currentUpgradeTimestamp) {\n          log.info(`WebDriverAgent sources are up to date ` +\n            `(${recentUpgradeTimestamp} >= ${currentUpgradeTimestamp})`);\n          return false;\n        }\n        log.info(`WebDriverAgent sources have been upgraded ` +\n          `(${recentUpgradeTimestamp} < ${currentUpgradeTimestamp})`);\n      } else {\n        log.warn(`The recent upgrade timestamp at '${timestampPath}' is corrupted. Trying to fix it`);\n      }\n    }\n\n    try {\n      await mkdirp(path.dirname(timestampPath));\n      await fs.writeFile(timestampPath, `${currentUpgradeTimestamp}`, 'utf8');\n      log.debug(`Stored the recent WebDriverAgent upgrade timestamp ${currentUpgradeTimestamp} ` +\n        `at '${timestampPath}'`);\n    } catch (e) {\n      log.info(`Unable to create the recent WebDriverAgent upgrade timestamp at '${timestampPath}'. ` +\n        `Original error: ${e.message}`);\n      return false;\n    }\n\n    return true;\n  }\n\n  hasSameOpts ({ showServerLogs, systemPort, systemHost, bootstrapRoot }) {\n    if (_.isBoolean(showServerLogs) && this.showServerLogs !== showServerLogs\n      || _.isNil(showServerLogs) && this.showServerLogs !== DEFAULT_SHOW_SERVER_LOGS) {\n      return false;\n    }\n    if (systemPort && this.port !== systemPort\n      || !systemPort && this.port !== DEFAULT_SYSTEM_PORT) {\n      return false;\n    }\n    if (systemHost && this.host !== systemHost\n      || !systemHost && this.host !== DEFAULT_SYSTEM_HOST) {\n      return false;\n    }\n    if (bootstrapRoot && this.bootstrapRoot !== bootstrapRoot\n      || !bootstrapRoot && this.bootstrapRoot !== DEFAULT_WDA_ROOT) {\n      return false;\n    }\n\n    return true;\n  }\n\n  async init (opts = {}) {\n    if (this.isRunning && this.hasSameOpts(opts)) {\n      return false;\n    }\n\n    this.showServerLogs = opts.showServerLogs ?? this.showServerLogs;\n    this.port = opts.systemPort ?? this.port;\n    this.host = opts.systemHost ?? this.host;\n    this.bootstrapRoot = opts.bootstrapRoot ?? this.bootstrapRoot;\n\n    log.debug(`Using bootstrap root: ${this.bootstrapRoot}`);\n    if (!await fs.exists(WDA_PROJECT(this.bootstrapRoot))) {\n      throw new Error(`${WDA_PROJECT_NAME} does not exist at '${WDA_PROJECT(this.bootstrapRoot)}'. ` +\n        `Was 'bootstrapRoot' set to a proper value?`);\n    }\n\n    await this.kill();\n    await cleanupObsoleteProcesses();\n\n    let xcodebuild;\n    try {\n      xcodebuild = await fs.which(XCODEBUILD);\n    } catch (e) {\n      throw new Error(`${XCODEBUILD} binary cannot be found in PATH. ` +\n        `Please make sure that Xcode is installed on your system`);\n    }\n    log.debug(`Using ${XCODEBUILD} binary at '${xcodebuild}'`);\n\n    if (await this.isFreshUpgrade()) {\n      log.info('Performing project cleanup');\n      const args = [\n        'clean',\n        '-project', WDA_PROJECT(this.bootstrapRoot),\n        '-scheme', RUNNER_SCHEME,\n      ];\n      try {\n        await exec(XCODEBUILD, args, {\n          cwd: this.bootstrapRoot,\n        });\n      } catch (e) {\n        log.warn(`Cannot perform project cleanup. ` +\n          `Original error: ${e.stderr || e.message}`);\n      }\n    }\n\n    log.debug(`Using ${this.host} as server host`);\n    log.debug(`Using port ${this.port}`);\n    const isPortBusy = async () => (await checkPortStatus(this.port, this.host)) === 'open';\n    if (await isPortBusy()) {\n      log.warn(`The port #${this.port} at ${this.host} is busy. ` +\n        `Assuming it is an obsolete WDA server instance and ` +\n        `trying to terminate it in order to start a new one`);\n      const timer = new timing.Timer().start();\n      try {\n        await axios.delete(`http://${this.host}:${this.port}/`, {\n          timeout: 5000,\n        });\n        // Give the server some time to finish and stop listening\n        await B.delay(500);\n        await waitForCondition(async () => !(await isPortBusy()), {\n          waitMs: 3000,\n          intervalMs: 100,\n        });\n      } catch (e) {\n        log.warn(`Did not know how to terminate the process at ${this.host}:${this.port}: ${e.message}. ` +\n          `Perhaps, it is not a WDA server, which is hogging the port?`);\n        throw new Error(`The port #${this.port} at ${this.host} is busy. ` +\n          `Consider setting 'systemPort' capability to another free port number and/or ` +\n          `make sure previous driver sessions have been closed properly.`);\n      }\n      log.info(`The previously running WDA server has been successfully terminated after ` +\n        `${Math.round(timer.getDuration().asMilliSeconds)}ms`);\n    }\n\n    const args = [\n      'build-for-testing', 'test-without-building',\n      '-project', WDA_PROJECT(this.bootstrapRoot),\n      '-scheme', RUNNER_SCHEME,\n      DISABLE_STORE_ARG,\n    ];\n    const env = Object.assign({}, process.env, {\n      USE_PORT: `${this.port}`,\n      USE_HOST: this.host,\n    });\n    this.proc = new SubProcess(xcodebuild, args, {\n      cwd: this.bootstrapRoot,\n      env,\n    });\n    if (!this.showServerLogs) {\n      log.info(`Mac2Driver host process logging is disabled. ` +\n        `All the ${XCODEBUILD} output is going to be suppressed. ` +\n        `Set the 'showServerLogs' capability to 'true' if this is an undesired behavior`);\n    }\n    this.proc.on('output', (stdout, stderr) => {\n      if (!this.showServerLogs) {\n        return;\n      }\n\n      const line = _.trim(stdout || stderr);\n      if (line) {\n        log.debug(`[${XCODEBUILD}] ${line}`);\n      }\n    });\n    this.proc.on('exit', (code, signal) => {\n      log.info(`Mac2Driver host process has exited with code ${code}, signal ${signal}`);\n    });\n    log.info(`Starting Mac2Driver host process: ${XCODEBUILD} ${util.quote(args)}`);\n    await this.proc.start(0);\n    return true;\n  }\n\n  async stop () {\n    if (!this.isRunning) {\n      return;\n    }\n\n    const childrenPids = await this.listChildrenPids();\n    if (!_.isEmpty(childrenPids)) {\n      try {\n        await exec('kill', childrenPids);\n      } catch (ign) {}\n    }\n    await this.proc.stop('SIGTERM', 3000);\n  }\n\n  async kill () {\n    if (!this.isRunning) {\n      return;\n    }\n\n    const childrenPids = await this.listChildrenPids();\n    if (!_.isEmpty(childrenPids)) {\n      try {\n        await exec('kill', ['-9', ...childrenPids]);\n      } catch (ign) {}\n    }\n    try {\n      await this.proc.stop('SIGKILL');\n    } catch (ign) {}\n  }\n}\n\nclass WDAMacServer {\n  constructor () {\n    this.process = null;\n    this.serverStartupTimeoutMs = STARTUP_TIMEOUT_MS;\n    this.proxy = null;\n\n    // To handle if the WDAMac server is proxying requests to a remote WDAMac app instance\n    this.isProxyingToRemoteServer = false;\n  }\n\n  async isProxyReady (throwOnExit = true) {\n    if (!this.proxy) {\n      return false;\n    }\n\n    try {\n      await this.proxy.command('/status', 'GET');\n      return true;\n    } catch (err) {\n      if (throwOnExit && this.proxy.didProcessExit) {\n        throw new Error(err.message);\n      }\n      return false;\n    }\n  }\n\n\n  /**\n   * @typedef {Object} ProxyProperties\n   *\n   * @property {string} scheme - The scheme proxy to.\n   * @property {string} host - The host name proxy to.\n   * @property {number} port - The port number proxy to.\n   * @property {string} path - The path proxy to.\n   */\n\n  /**\n   * Returns proxy information where WDAMacServer proxy to.\n   *\n   * @param {Object} caps - The capabilities in the session.\n   * @return {ProxyProperties}\n   * @throws Error if 'webDriverAgentMacUrl' had invalid URL\n   */\n  parseProxyProperties (caps) {\n    let scheme = 'http';\n    if (!caps.webDriverAgentMacUrl) {\n      return {\n        scheme,\n        server: (this.process?.host ?? caps.systemHost) ?? DEFAULT_SYSTEM_HOST,\n        port: (this.process?.port ?? caps.systemPort) ?? DEFAULT_SYSTEM_PORT,\n        path: ''\n      };\n    }\n\n    let parsedUrl;\n    try {\n      parsedUrl = new url.URL(caps.webDriverAgentMacUrl);\n    } catch (e) {\n      throw new Error(`webDriverAgentMacUrl, '${caps.webDriverAgentMacUrl}', ` +\n        `in the capabilities is invalid. ${e.message}`);\n    }\n\n    const { protocol, hostname, port, pathname } = parsedUrl;\n    if (_.isString(protocol)) {\n      scheme = protocol.split(':')[0];\n    }\n    return {\n      scheme,\n      server: hostname ?? DEFAULT_SYSTEM_HOST,\n      port: _.isEmpty(port) ? DEFAULT_SYSTEM_PORT : _.parseInt(port),\n      path: pathname === '/' ? '' : pathname\n    };\n  }\n\n  async startSession (caps) {\n    this.serverStartupTimeoutMs = caps.serverStartupTimeout ?? this.serverStartupTimeoutMs;\n\n    this.isProxyingToRemoteServer = !!caps.webDriverAgentMacUrl;\n\n    let wasProcessInitNecessary;\n    if (this.isProxyingToRemoteServer) {\n      if (this.process) {\n        await this.process.kill();\n        await cleanupObsoleteProcesses();\n        this.process = null;\n      }\n\n      wasProcessInitNecessary = false;\n    } else {\n      if (!this.process) {\n        this.process = new WDAMacProcess();\n      }\n      wasProcessInitNecessary = await this.process.init(caps);\n    }\n\n    if (wasProcessInitNecessary || this.isProxyingToRemoteServer || !this.proxy) {\n      const {scheme, server, port, path} = this.parseProxyProperties(caps);\n      this.proxy = new WDAMacProxy({\n        scheme,\n        server,\n        port,\n        base: path,\n        keepAlive: true,\n      });\n      this.proxy.didProcessExit = false;\n\n      if (this.process) {\n        this.process.proc.on('exit', () => {\n          this.proxy.didProcessExit = true;\n        });\n      }\n\n      const timer = new timing.Timer().start();\n      try {\n        await waitForCondition(async () => await this.isProxyReady(), {\n          waitMs: this.serverStartupTimeoutMs,\n          intervalMs: 1000,\n        });\n      } catch (e) {\n        if (this.process?.isRunning) {\n          // avoid \"frozen\" processes,\n          await this.process.kill();\n        }\n        if (/Condition unmet/.test(e.message)) {\n          const msg = this.isProxyingToRemoteServer\n            ? `No response from '${scheme}://${server}:${port}${path}' within ${this.serverStartupTimeoutMs}ms timeout.` +\n            `Please make sure the remote server is running and accessible by Appium`\n            : `Mac2Driver server is not listening within ${this.serverStartupTimeoutMs}ms timeout. ` +\n            `Try to increase the value of 'serverStartupTimeout' capability, check the server logs ` +\n            `and make sure the ${XCODEBUILD} host process could be started manually from a terminal`;\n          throw new Error(msg);\n        }\n        throw e;\n      }\n\n      if (this.process) {\n        const pid = this.process.pid;\n        const childrenPids = await this.process.listChildrenPids();\n        RUNNING_PROCESS_IDS.push(...childrenPids, pid);\n        this.process.proc.on('exit', () => void _.pull(RUNNING_PROCESS_IDS, pid));\n        log.info(`The host process is ready within ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n      }\n    } else {\n      log.info('The host process has already been listening. Proceeding with session creation');\n    }\n\n    await this.proxy.command('/session', 'POST', {\n      capabilities: {\n        firstMatch: [{}],\n        alwaysMatch: caps,\n      }\n    });\n  }\n\n  async stopSession () {\n    if (!this.isProxyingToRemoteServer && !(this.process?.isRunning)) {\n      log.info(`Mac2Driver session cannot be stopped, because the server is not running`);\n      return;\n    }\n\n    if (this.proxy?.sessionId) {\n      try {\n        await this.proxy.command(`/session/${this.proxy.sessionId}`, 'DELETE');\n      } catch (e) {\n        log.info(`Mac2Driver session cannot be deleted. Original error: ${e.message}`);\n      }\n    }\n  }\n}\n\nconst WDA_MAC_SERVER = new WDAMacServer();\n\nexport default WDA_MAC_SERVER;\n"],"mappings":";;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA,MAAMA,GAAG,GAAGC,eAAM,CAACC,SAAS,CAAC,mBAAmB,CAAC;AAEjD,MAAMC,gBAAgB,GAAGC,aAAI,CAACC,OAAO,CAAC,IAAAC,oBAAa,GAAE,EAAE,mBAAmB,CAAC;AAC3E,MAAMC,gBAAgB,GAAG,6BAA6B;AACtD,MAAMC,WAAW,GAAG,CAACC,OAAO,GAAGN,gBAAgB,KAAKC,aAAI,CAACC,OAAO,CAACI,OAAO,EAAEF,gBAAgB,CAAC;AAC3F,MAAMG,aAAa,GAAG,sBAAsB;AAC5C,MAAMC,iBAAiB,GAAG,gCAAgC;AAC1D,MAAMC,UAAU,GAAG,YAAY;AAC/B,MAAMC,kBAAkB,GAAG,MAAM;AACjC,MAAMC,mBAAmB,GAAG,KAAK;AACjC,MAAMC,mBAAmB,GAAG,WAAW;AACvC,MAAMC,wBAAwB,GAAG,KAAK;AACtC,MAAMC,mBAAmB,GAAG,EAAE;AAC9B,MAAMC,6BAA6B,GAAGd,aAAI,CAACe,IAAI,CAAC,SAAS,EAAE,oBAAoB,EAAE,cAAc,CAAC;AAGhG,eAAeC,mBAAmB,GAAI;EACpC,MAAMC,eAAe,GAAGjB,aAAI,CAACC,OAAO,CAAC,IAAAC,oBAAa,GAAE,EAAE,cAAc,CAAC;EACrE,IAAI,EAAC,MAAMgB,WAAE,CAACC,MAAM,CAACF,eAAe,CAAC,GAAE;IACrC,OAAO,IAAI;EACb;EACA,MAAM;IAACG;EAAK,CAAC,GAAG,MAAMF,WAAE,CAACG,IAAI,CAACJ,eAAe,CAAC;EAC9C,OAAOG,KAAK,CAACE,OAAO,EAAE;AACxB;AAEA,eAAeC,wBAAwB,GAAI;EACzC,IAAI,CAACC,eAAC,CAACC,OAAO,CAACZ,mBAAmB,CAAC,EAAE;IACnCjB,GAAG,CAAC8B,KAAK,CAAE,eAAcb,mBAAmB,CAACc,MAAO,YAAW,GAC7DC,aAAI,CAACC,SAAS,CAAC,SAAS,EAAEhB,mBAAmB,CAACc,MAAM,EAAE,KAAK,CAAC,CAAC;IAC/D,IAAI;MACF,MAAM,IAAAG,kBAAI,EAAC,MAAM,EAAE,CAAC,IAAI,EAAE,GAAGjB,mBAAmB,CAAC,CAAC;IACpD,CAAC,CAAC,OAAOkB,GAAG,EAAE,CAAC;IACfP,eAAC,CAACQ,OAAO,CAACnB,mBAAmB,EAAEA,mBAAmB,CAAC;EACrD;AACF;AAEAoB,OAAO,CAACC,IAAI,CAAC,MAAM,EAAE,MAAM;EACzB,IAAI,CAACV,eAAC,CAACC,OAAO,CAACZ,mBAAmB,CAAC,EAAE;IACnC,IAAI;MACF,IAAAsB,uBAAQ,EAAE,WAAUtB,mBAAmB,CAACE,IAAI,CAAC,GAAG,CAAE,EAAC,CAAC;IACtD,CAAC,CAAC,OAAOgB,GAAG,EAAE,CAAC;IACfP,eAAC,CAACQ,OAAO,CAACnB,mBAAmB,EAAEA,mBAAmB,CAAC;EACrD;AACF,CAAC,CAAC;AAGF,MAAMuB,WAAW,SAASC,eAAO,CAAC;EAChC,MAAMC,YAAY,CAAEC,GAAG,EAAEC,MAAM,EAAEC,IAAI,GAAG,IAAI,EAAE;IAC5C,IAAI,IAAI,CAACC,cAAc,EAAE;MACvB,MAAM,IAAIC,cAAM,CAACC,mBAAmB,CACjC,IAAGJ,MAAO,IAAGD,GAAI,oDAAmD,GACrE,sFAAsF,CAAC;IAC3F;IACA,OAAO,MAAM,KAAK,CAACD,YAAY,CAACC,GAAG,EAAEC,MAAM,EAAEC,IAAI,CAAC;EACpD;AACF;AAEA,MAAMI,aAAa,CAAC;EAClBC,WAAW,GAAI;IACb,IAAI,CAACC,cAAc,GAAGnC,wBAAwB;IAC9C,IAAI,CAACoC,IAAI,GAAGtC,mBAAmB;IAC/B,IAAI,CAACuC,IAAI,GAAGtC,mBAAmB;IAC/B,IAAI,CAACuC,aAAa,GAAGnD,gBAAgB;IACrC,IAAI,CAACoD,IAAI,GAAG,IAAI;EAClB;EAEA,IAAIC,SAAS,GAAI;IAAA;IACf,OAAO,CAAC,gBAAE,IAAI,CAACD,IAAI,uCAAT,WAAWC,SAAS,CAAC;EACjC;EAEA,IAAIC,GAAG,GAAI;IACT,OAAO,IAAI,CAACD,SAAS,GAAG,IAAI,CAACD,IAAI,CAACE,GAAG,GAAG,IAAI;EAC9C;EAEA,MAAMC,gBAAgB,GAAI;IACxB,OAAO,IAAI,CAACD,GAAG,GAAI,MAAM,IAAAE,6BAAsB,EAAC,IAAI,CAACF,GAAG,CAAC,GAAI,EAAE;EACjE;EAEA,MAAMG,cAAc,GAAI;IACtB,MAAMC,UAAU,GAAGxB,OAAO,CAACyB,GAAG,CAACC,IAAI;IACnC,IAAI,CAACF,UAAU,EAAE;MACf7D,GAAG,CAACgE,IAAI,CAAC,2CAA2C,CAAC;MACrD,OAAO,KAAK;IACd;IAEA,MAAMC,uBAAuB,GAAG,MAAM7C,mBAAmB,EAAE;IAC3D,IAAI,CAACQ,eAAC,CAACsC,SAAS,CAACD,uBAAuB,CAAC,EAAE;MACzCjE,GAAG,CAACgE,IAAI,CAAC,4DAA4D,CAAC;MACtE,OAAO,KAAK;IACd;IAEA,MAAMG,aAAa,GAAG/D,aAAI,CAACC,OAAO,CAACwD,UAAU,EAAE3C,6BAA6B,CAAC;IAC7E,IAAI,MAAMI,WAAE,CAACC,MAAM,CAAC4C,aAAa,CAAC,EAAE;MAClC,IAAI;QACF,MAAM7C,WAAE,CAAC8C,MAAM,CAACD,aAAa,EAAE7C,WAAE,CAAC+C,IAAI,CAAC;MACzC,CAAC,CAAC,OAAOlC,GAAG,EAAE;QACZnC,GAAG,CAACgE,IAAI,CAAE,wCAAuCG,aAAc,oBAAmB,CAAC;QACnF,OAAO,KAAK;MACd;MACA,MAAMG,sBAAsB,GAAGC,QAAQ,CAAC,MAAMjD,WAAE,CAACkD,QAAQ,CAACL,aAAa,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC;MACrF,IAAIvC,eAAC,CAACsC,SAAS,CAACI,sBAAsB,CAAC,EAAE;QACvC,IAAIA,sBAAsB,IAAIL,uBAAuB,EAAE;UACrDjE,GAAG,CAACgE,IAAI,CAAE,wCAAuC,GAC9C,IAAGM,sBAAuB,OAAML,uBAAwB,GAAE,CAAC;UAC9D,OAAO,KAAK;QACd;QACAjE,GAAG,CAACgE,IAAI,CAAE,4CAA2C,GAClD,IAAGM,sBAAuB,MAAKL,uBAAwB,GAAE,CAAC;MAC/D,CAAC,MAAM;QACLjE,GAAG,CAACyE,IAAI,CAAE,oCAAmCN,aAAc,kCAAiC,CAAC;MAC/F;IACF;IAEA,IAAI;MACF,MAAM,IAAAO,eAAM,EAACtE,aAAI,CAACuE,OAAO,CAACR,aAAa,CAAC,CAAC;MACzC,MAAM7C,WAAE,CAACsD,SAAS,CAACT,aAAa,EAAG,GAAEF,uBAAwB,EAAC,EAAE,MAAM,CAAC;MACvEjE,GAAG,CAAC8B,KAAK,CAAE,sDAAqDmC,uBAAwB,GAAE,GACvF,OAAME,aAAc,GAAE,CAAC;IAC5B,CAAC,CAAC,OAAOU,CAAC,EAAE;MACV7E,GAAG,CAACgE,IAAI,CAAE,oEAAmEG,aAAc,KAAI,GAC5F,mBAAkBU,CAAC,CAACC,OAAQ,EAAC,CAAC;MACjC,OAAO,KAAK;IACd;IAEA,OAAO,IAAI;EACb;EAEAC,WAAW,CAAE;IAAE5B,cAAc;IAAE6B,UAAU;IAAEC,UAAU;IAAE3B;EAAc,CAAC,EAAE;IACtE,IAAI1B,eAAC,CAACsD,SAAS,CAAC/B,cAAc,CAAC,IAAI,IAAI,CAACA,cAAc,KAAKA,cAAc,IACpEvB,eAAC,CAACuD,KAAK,CAAChC,cAAc,CAAC,IAAI,IAAI,CAACA,cAAc,KAAKnC,wBAAwB,EAAE;MAChF,OAAO,KAAK;IACd;IACA,IAAIgE,UAAU,IAAI,IAAI,CAAC5B,IAAI,KAAK4B,UAAU,IACrC,CAACA,UAAU,IAAI,IAAI,CAAC5B,IAAI,KAAKtC,mBAAmB,EAAE;MACrD,OAAO,KAAK;IACd;IACA,IAAImE,UAAU,IAAI,IAAI,CAAC5B,IAAI,KAAK4B,UAAU,IACrC,CAACA,UAAU,IAAI,IAAI,CAAC5B,IAAI,KAAKtC,mBAAmB,EAAE;MACrD,OAAO,KAAK;IACd;IACA,IAAIuC,aAAa,IAAI,IAAI,CAACA,aAAa,KAAKA,aAAa,IACpD,CAACA,aAAa,IAAI,IAAI,CAACA,aAAa,KAAKnD,gBAAgB,EAAE;MAC9D,OAAO,KAAK;IACd;IAEA,OAAO,IAAI;EACb;EAEA,MAAMiF,IAAI,CAAEC,IAAI,GAAG,CAAC,CAAC,EAAE;IACrB,IAAI,IAAI,CAAC7B,SAAS,IAAI,IAAI,CAACuB,WAAW,CAACM,IAAI,CAAC,EAAE;MAC5C,OAAO,KAAK;IACd;IAEA,IAAI,CAAClC,cAAc,GAAGkC,IAAI,CAAClC,cAAc,IAAI,IAAI,CAACA,cAAc;IAChE,IAAI,CAACC,IAAI,GAAGiC,IAAI,CAACL,UAAU,IAAI,IAAI,CAAC5B,IAAI;IACxC,IAAI,CAACC,IAAI,GAAGgC,IAAI,CAACJ,UAAU,IAAI,IAAI,CAAC5B,IAAI;IACxC,IAAI,CAACC,aAAa,GAAG+B,IAAI,CAAC/B,aAAa,IAAI,IAAI,CAACA,aAAa;IAE7DtD,GAAG,CAAC8B,KAAK,CAAE,yBAAwB,IAAI,CAACwB,aAAc,EAAC,CAAC;IACxD,IAAI,EAAC,MAAMhC,WAAE,CAACC,MAAM,CAACf,WAAW,CAAC,IAAI,CAAC8C,aAAa,CAAC,CAAC,GAAE;MACrD,MAAM,IAAIgC,KAAK,CAAE,GAAE/E,gBAAiB,uBAAsBC,WAAW,CAAC,IAAI,CAAC8C,aAAa,CAAE,KAAI,GAC3F,4CAA2C,CAAC;IACjD;IAEA,MAAM,IAAI,CAACiC,IAAI,EAAE;IACjB,MAAM5D,wBAAwB,EAAE;IAEhC,IAAI6D,UAAU;IACd,IAAI;MACFA,UAAU,GAAG,MAAMlE,WAAE,CAACmE,KAAK,CAAC7E,UAAU,CAAC;IACzC,CAAC,CAAC,OAAOiE,CAAC,EAAE;MACV,MAAM,IAAIS,KAAK,CAAE,GAAE1E,UAAW,mCAAkC,GAC7D,yDAAwD,CAAC;IAC9D;IACAZ,GAAG,CAAC8B,KAAK,CAAE,SAAQlB,UAAW,eAAc4E,UAAW,GAAE,CAAC;IAE1D,IAAI,MAAM,IAAI,CAAC5B,cAAc,EAAE,EAAE;MAC/B5D,GAAG,CAACgE,IAAI,CAAC,4BAA4B,CAAC;MACtC,MAAM0B,IAAI,GAAG,CACX,OAAO,EACP,UAAU,EAAElF,WAAW,CAAC,IAAI,CAAC8C,aAAa,CAAC,EAC3C,SAAS,EAAE5C,aAAa,CACzB;MACD,IAAI;QACF,MAAM,IAAAwB,kBAAI,EAACtB,UAAU,EAAE8E,IAAI,EAAE;UAC3BC,GAAG,EAAE,IAAI,CAACrC;QACZ,CAAC,CAAC;MACJ,CAAC,CAAC,OAAOuB,CAAC,EAAE;QACV7E,GAAG,CAACyE,IAAI,CAAE,kCAAiC,GACxC,mBAAkBI,CAAC,CAACe,MAAM,IAAIf,CAAC,CAACC,OAAQ,EAAC,CAAC;MAC/C;IACF;IAEA9E,GAAG,CAAC8B,KAAK,CAAE,SAAQ,IAAI,CAACuB,IAAK,iBAAgB,CAAC;IAC9CrD,GAAG,CAAC8B,KAAK,CAAE,cAAa,IAAI,CAACsB,IAAK,EAAC,CAAC;IACpC,MAAMyC,UAAU,GAAG,YAAY,CAAC,MAAM,IAAAC,4BAAe,EAAC,IAAI,CAAC1C,IAAI,EAAE,IAAI,CAACC,IAAI,CAAC,MAAM,MAAM;IACvF,IAAI,MAAMwC,UAAU,EAAE,EAAE;MACtB7F,GAAG,CAACyE,IAAI,CAAE,aAAY,IAAI,CAACrB,IAAK,OAAM,IAAI,CAACC,IAAK,YAAW,GACxD,qDAAoD,GACpD,oDAAmD,CAAC;MACvD,MAAM0C,KAAK,GAAG,IAAIC,eAAM,CAACC,KAAK,EAAE,CAACC,KAAK,EAAE;MACxC,IAAI;QACF,MAAMC,cAAK,CAACC,MAAM,CAAE,UAAS,IAAI,CAAC/C,IAAK,IAAG,IAAI,CAACD,IAAK,GAAE,EAAE;UACtDiD,OAAO,EAAE;QACX,CAAC,CAAC;QAEF,MAAMC,iBAAC,CAACC,KAAK,CAAC,GAAG,CAAC;QAClB,MAAM,IAAAC,0BAAgB,EAAC,YAAY,EAAE,MAAMX,UAAU,EAAE,CAAC,EAAE;UACxDY,MAAM,EAAE,IAAI;UACZC,UAAU,EAAE;QACd,CAAC,CAAC;MACJ,CAAC,CAAC,OAAO7B,CAAC,EAAE;QACV7E,GAAG,CAACyE,IAAI,CAAE,gDAA+C,IAAI,CAACpB,IAAK,IAAG,IAAI,CAACD,IAAK,KAAIyB,CAAC,CAACC,OAAQ,IAAG,GAC9F,6DAA4D,CAAC;QAChE,MAAM,IAAIQ,KAAK,CAAE,aAAY,IAAI,CAAClC,IAAK,OAAM,IAAI,CAACC,IAAK,YAAW,GAC/D,8EAA6E,GAC7E,+DAA8D,CAAC;MACpE;MACArD,GAAG,CAACgE,IAAI,CAAE,2EAA0E,GACjF,GAAE2C,IAAI,CAACC,KAAK,CAACb,KAAK,CAACc,WAAW,EAAE,CAACC,cAAc,CAAE,IAAG,CAAC;IAC1D;IAEA,MAAMpB,IAAI,GAAG,CACX,mBAAmB,EAAE,uBAAuB,EAC5C,UAAU,EAAElF,WAAW,CAAC,IAAI,CAAC8C,aAAa,CAAC,EAC3C,SAAS,EAAE5C,aAAa,EACxBC,iBAAiB,CAClB;IACD,MAAMmD,GAAG,GAAGiD,MAAM,CAACC,MAAM,CAAC,CAAC,CAAC,EAAE3E,OAAO,CAACyB,GAAG,EAAE;MACzCmD,QAAQ,EAAG,GAAE,IAAI,CAAC7D,IAAK,EAAC;MACxB8D,QAAQ,EAAE,IAAI,CAAC7D;IACjB,CAAC,CAAC;IACF,IAAI,CAACE,IAAI,GAAG,IAAI4D,wBAAU,CAAC3B,UAAU,EAAEE,IAAI,EAAE;MAC3CC,GAAG,EAAE,IAAI,CAACrC,aAAa;MACvBQ;IACF,CAAC,CAAC;IACF,IAAI,CAAC,IAAI,CAACX,cAAc,EAAE;MACxBnD,GAAG,CAACgE,IAAI,CAAE,+CAA8C,GACrD,WAAUpD,UAAW,qCAAoC,GACzD,gFAA+E,CAAC;IACrF;IACA,IAAI,CAAC2C,IAAI,CAAC6D,EAAE,CAAC,QAAQ,EAAE,CAACC,MAAM,EAAEzB,MAAM,KAAK;MACzC,IAAI,CAAC,IAAI,CAACzC,cAAc,EAAE;QACxB;MACF;MAEA,MAAMmE,IAAI,GAAG1F,eAAC,CAAC2F,IAAI,CAACF,MAAM,IAAIzB,MAAM,CAAC;MACrC,IAAI0B,IAAI,EAAE;QACRtH,GAAG,CAAC8B,KAAK,CAAE,IAAGlB,UAAW,KAAI0G,IAAK,EAAC,CAAC;MACtC;IACF,CAAC,CAAC;IACF,IAAI,CAAC/D,IAAI,CAAC6D,EAAE,CAAC,MAAM,EAAE,CAACI,IAAI,EAAEC,MAAM,KAAK;MACrCzH,GAAG,CAACgE,IAAI,CAAE,gDAA+CwD,IAAK,YAAWC,MAAO,EAAC,CAAC;IACpF,CAAC,CAAC;IACFzH,GAAG,CAACgE,IAAI,CAAE,qCAAoCpD,UAAW,IAAGoB,aAAI,CAAC0F,KAAK,CAAChC,IAAI,CAAE,EAAC,CAAC;IAC/E,MAAM,IAAI,CAACnC,IAAI,CAAC2C,KAAK,CAAC,CAAC,CAAC;IACxB,OAAO,IAAI;EACb;EAEA,MAAMyB,IAAI,GAAI;IACZ,IAAI,CAAC,IAAI,CAACnE,SAAS,EAAE;MACnB;IACF;IAEA,MAAMoE,YAAY,GAAG,MAAM,IAAI,CAAClE,gBAAgB,EAAE;IAClD,IAAI,CAAC9B,eAAC,CAACC,OAAO,CAAC+F,YAAY,CAAC,EAAE;MAC5B,IAAI;QACF,MAAM,IAAA1F,kBAAI,EAAC,MAAM,EAAE0F,YAAY,CAAC;MAClC,CAAC,CAAC,OAAOzF,GAAG,EAAE,CAAC;IACjB;IACA,MAAM,IAAI,CAACoB,IAAI,CAACoE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC;EACvC;EAEA,MAAMpC,IAAI,GAAI;IACZ,IAAI,CAAC,IAAI,CAAC/B,SAAS,EAAE;MACnB;IACF;IAEA,MAAMoE,YAAY,GAAG,MAAM,IAAI,CAAClE,gBAAgB,EAAE;IAClD,IAAI,CAAC9B,eAAC,CAACC,OAAO,CAAC+F,YAAY,CAAC,EAAE;MAC5B,IAAI;QACF,MAAM,IAAA1F,kBAAI,EAAC,MAAM,EAAE,CAAC,IAAI,EAAE,GAAG0F,YAAY,CAAC,CAAC;MAC7C,CAAC,CAAC,OAAOzF,GAAG,EAAE,CAAC;IACjB;IACA,IAAI;MACF,MAAM,IAAI,CAACoB,IAAI,CAACoE,IAAI,CAAC,SAAS,CAAC;IACjC,CAAC,CAAC,OAAOxF,GAAG,EAAE,CAAC;EACjB;AACF;AAEA,MAAM0F,YAAY,CAAC;EACjB3E,WAAW,GAAI;IACb,IAAI,CAACb,OAAO,GAAG,IAAI;IACnB,IAAI,CAACyF,sBAAsB,GAAGjH,kBAAkB;IAChD,IAAI,CAACkH,KAAK,GAAG,IAAI;;IAGjB,IAAI,CAACC,wBAAwB,GAAG,KAAK;EACvC;EAEA,MAAMC,YAAY,CAAEC,WAAW,GAAG,IAAI,EAAE;IACtC,IAAI,CAAC,IAAI,CAACH,KAAK,EAAE;MACf,OAAO,KAAK;IACd;IAEA,IAAI;MACF,MAAM,IAAI,CAACA,KAAK,CAACI,OAAO,CAAC,SAAS,EAAE,KAAK,CAAC;MAC1C,OAAO,IAAI;IACb,CAAC,CAAC,OAAOC,GAAG,EAAE;MACZ,IAAIF,WAAW,IAAI,IAAI,CAACH,KAAK,CAACjF,cAAc,EAAE;QAC5C,MAAM,IAAIwC,KAAK,CAAC8C,GAAG,CAACtD,OAAO,CAAC;MAC9B;MACA,OAAO,KAAK;IACd;EACF;;EAmBAuD,oBAAoB,CAAEC,IAAI,EAAE;IAC1B,IAAIC,MAAM,GAAG,MAAM;IACnB,IAAI,CAACD,IAAI,CAACE,oBAAoB,EAAE;MAAA;MAC9B,OAAO;QACLD,MAAM;QACNE,MAAM,EAAG,sBAAI,CAACpG,OAAO,kDAAZ,cAAcgB,IAAI,KAAIiF,IAAI,CAACrD,UAAU,IAAKlE,mBAAmB;QACtEqC,IAAI,EAAG,uBAAI,CAACf,OAAO,mDAAZ,eAAce,IAAI,KAAIkF,IAAI,CAACtD,UAAU,IAAKlE,mBAAmB;QACpEV,IAAI,EAAE;MACR,CAAC;IACH;IAEA,IAAIsI,SAAS;IACb,IAAI;MACFA,SAAS,GAAG,IAAI/F,YAAG,CAACgG,GAAG,CAACL,IAAI,CAACE,oBAAoB,CAAC;IACpD,CAAC,CAAC,OAAO3D,CAAC,EAAE;MACV,MAAM,IAAIS,KAAK,CAAE,0BAAyBgD,IAAI,CAACE,oBAAqB,KAAI,GACrE,mCAAkC3D,CAAC,CAACC,OAAQ,EAAC,CAAC;IACnD;IAEA,MAAM;MAAE8D,QAAQ;MAAEC,QAAQ;MAAEzF,IAAI;MAAE0F;IAAS,CAAC,GAAGJ,SAAS;IACxD,IAAI9G,eAAC,CAACmH,QAAQ,CAACH,QAAQ,CAAC,EAAE;MACxBL,MAAM,GAAGK,QAAQ,CAACI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACjC;IACA,OAAO;MACLT,MAAM;MACNE,MAAM,EAAEI,QAAQ,IAAI9H,mBAAmB;MACvCqC,IAAI,EAAExB,eAAC,CAACC,OAAO,CAACuB,IAAI,CAAC,GAAGtC,mBAAmB,GAAGc,eAAC,CAAC2C,QAAQ,CAACnB,IAAI,CAAC;MAC9DhD,IAAI,EAAE0I,QAAQ,KAAK,GAAG,GAAG,EAAE,GAAGA;IAChC,CAAC;EACH;EAEA,MAAMG,YAAY,CAAEX,IAAI,EAAE;IACxB,IAAI,CAACR,sBAAsB,GAAGQ,IAAI,CAACY,oBAAoB,IAAI,IAAI,CAACpB,sBAAsB;IAEtF,IAAI,CAACE,wBAAwB,GAAG,CAAC,CAACM,IAAI,CAACE,oBAAoB;IAE3D,IAAIW,uBAAuB;IAC3B,IAAI,IAAI,CAACnB,wBAAwB,EAAE;MACjC,IAAI,IAAI,CAAC3F,OAAO,EAAE;QAChB,MAAM,IAAI,CAACA,OAAO,CAACkD,IAAI,EAAE;QACzB,MAAM5D,wBAAwB,EAAE;QAChC,IAAI,CAACU,OAAO,GAAG,IAAI;MACrB;MAEA8G,uBAAuB,GAAG,KAAK;IACjC,CAAC,MAAM;MACL,IAAI,CAAC,IAAI,CAAC9G,OAAO,EAAE;QACjB,IAAI,CAACA,OAAO,GAAG,IAAIY,aAAa,EAAE;MACpC;MACAkG,uBAAuB,GAAG,MAAM,IAAI,CAAC9G,OAAO,CAAC+C,IAAI,CAACkD,IAAI,CAAC;IACzD;IAEA,IAAIa,uBAAuB,IAAI,IAAI,CAACnB,wBAAwB,IAAI,CAAC,IAAI,CAACD,KAAK,EAAE;MAC3E,MAAM;QAACQ,MAAM;QAAEE,MAAM;QAAErF,IAAI;QAAEhD;MAAI,CAAC,GAAG,IAAI,CAACiI,oBAAoB,CAACC,IAAI,CAAC;MACpE,IAAI,CAACP,KAAK,GAAG,IAAIvF,WAAW,CAAC;QAC3B+F,MAAM;QACNE,MAAM;QACNrF,IAAI;QACJgG,IAAI,EAAEhJ,IAAI;QACViJ,SAAS,EAAE;MACb,CAAC,CAAC;MACF,IAAI,CAACtB,KAAK,CAACjF,cAAc,GAAG,KAAK;MAEjC,IAAI,IAAI,CAACT,OAAO,EAAE;QAChB,IAAI,CAACA,OAAO,CAACkB,IAAI,CAAC6D,EAAE,CAAC,MAAM,EAAE,MAAM;UACjC,IAAI,CAACW,KAAK,CAACjF,cAAc,GAAG,IAAI;QAClC,CAAC,CAAC;MACJ;MAEA,MAAMiD,KAAK,GAAG,IAAIC,eAAM,CAACC,KAAK,EAAE,CAACC,KAAK,EAAE;MACxC,IAAI;QACF,MAAM,IAAAM,0BAAgB,EAAC,YAAY,MAAM,IAAI,CAACyB,YAAY,EAAE,EAAE;UAC5DxB,MAAM,EAAE,IAAI,CAACqB,sBAAsB;UACnCpB,UAAU,EAAE;QACd,CAAC,CAAC;MACJ,CAAC,CAAC,OAAO7B,CAAC,EAAE;QAAA;QACV,sBAAI,IAAI,CAACxC,OAAO,2CAAZ,eAAcmB,SAAS,EAAE;UAE3B,MAAM,IAAI,CAACnB,OAAO,CAACkD,IAAI,EAAE;QAC3B;QACA,IAAI,iBAAiB,CAAC+D,IAAI,CAACzE,CAAC,CAACC,OAAO,CAAC,EAAE;UACrC,MAAMyE,GAAG,GAAG,IAAI,CAACvB,wBAAwB,GACpC,qBAAoBO,MAAO,MAAKE,MAAO,IAAGrF,IAAK,GAAEhD,IAAK,YAAW,IAAI,CAAC0H,sBAAuB,aAAY,GAC3G,wEAAuE,GACrE,6CAA4C,IAAI,CAACA,sBAAuB,cAAa,GACvF,wFAAuF,GACvF,qBAAoBlH,UAAW,yDAAwD;UAC1F,MAAM,IAAI0E,KAAK,CAACiE,GAAG,CAAC;QACtB;QACA,MAAM1E,CAAC;MACT;MAEA,IAAI,IAAI,CAACxC,OAAO,EAAE;QAChB,MAAMoB,GAAG,GAAG,IAAI,CAACpB,OAAO,CAACoB,GAAG;QAC5B,MAAMmE,YAAY,GAAG,MAAM,IAAI,CAACvF,OAAO,CAACqB,gBAAgB,EAAE;QAC1DzC,mBAAmB,CAACuI,IAAI,CAAC,GAAG5B,YAAY,EAAEnE,GAAG,CAAC;QAC9C,IAAI,CAACpB,OAAO,CAACkB,IAAI,CAAC6D,EAAE,CAAC,MAAM,EAAE,MAAM,KAAKxF,eAAC,CAAC6H,IAAI,CAACxI,mBAAmB,EAAEwC,GAAG,CAAC,CAAC;QACzEzD,GAAG,CAACgE,IAAI,CAAE,oCAAmC+B,KAAK,CAACc,WAAW,EAAE,CAACC,cAAc,CAAC4C,OAAO,CAAC,CAAC,CAAE,IAAG,CAAC;MACjG;IACF,CAAC,MAAM;MACL1J,GAAG,CAACgE,IAAI,CAAC,+EAA+E,CAAC;IAC3F;IAEA,MAAM,IAAI,CAAC+D,KAAK,CAACI,OAAO,CAAC,UAAU,EAAE,MAAM,EAAE;MAC3CwB,YAAY,EAAE;QACZC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC;QAChBC,WAAW,EAAEvB;MACf;IACF,CAAC,CAAC;EACJ;EAEA,MAAMwB,WAAW,GAAI;IAAA;IACnB,IAAI,CAAC,IAAI,CAAC9B,wBAAwB,IAAI,oBAAE,IAAI,CAAC3F,OAAO,2CAAZ,eAAcmB,SAAS,CAAC,EAAE;MAChExD,GAAG,CAACgE,IAAI,CAAE,yEAAwE,CAAC;MACnF;IACF;IAEA,mBAAI,IAAI,CAAC+D,KAAK,wCAAV,YAAYgC,SAAS,EAAE;MACzB,IAAI;QACF,MAAM,IAAI,CAAChC,KAAK,CAACI,OAAO,CAAE,YAAW,IAAI,CAACJ,KAAK,CAACgC,SAAU,EAAC,EAAE,QAAQ,CAAC;MACxE,CAAC,CAAC,OAAOlF,CAAC,EAAE;QACV7E,GAAG,CAACgE,IAAI,CAAE,yDAAwDa,CAAC,CAACC,OAAQ,EAAC,CAAC;MAChF;IACF;EACF;AACF;AAEA,MAAMkF,cAAc,GAAG,IAAInC,YAAY,EAAE;AAAC,eAE3BmC,cAAc;AAAA"}
|