@limrun/cli 0.1.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 +670 -0
- package/bin/dev.js +16 -0
- package/bin/run.js +8 -0
- package/dist/base-command.d.ts +17 -0
- package/dist/base-command.d.ts.map +1 -0
- package/dist/base-command.js +111 -0
- package/dist/base-command.js.map +1 -0
- package/dist/commands/build.d.ts +20 -0
- package/dist/commands/build.d.ts.map +1 -0
- package/dist/commands/build.js +83 -0
- package/dist/commands/build.js.map +1 -0
- package/dist/commands/connect/android.d.ts +15 -0
- package/dist/commands/connect/android.d.ts.map +1 -0
- package/dist/commands/connect/android.js +80 -0
- package/dist/commands/connect/android.js.map +1 -0
- package/dist/commands/delete/android.d.ts +14 -0
- package/dist/commands/delete/android.d.ts.map +1 -0
- package/dist/commands/delete/android.js +22 -0
- package/dist/commands/delete/android.js.map +1 -0
- package/dist/commands/delete/asset.d.ts +14 -0
- package/dist/commands/delete/asset.d.ts.map +1 -0
- package/dist/commands/delete/asset.js +22 -0
- package/dist/commands/delete/asset.js.map +1 -0
- package/dist/commands/delete/index.d.ts +14 -0
- package/dist/commands/delete/index.d.ts.map +1 -0
- package/dist/commands/delete/index.js +47 -0
- package/dist/commands/delete/index.js.map +1 -0
- package/dist/commands/delete/ios.d.ts +14 -0
- package/dist/commands/delete/ios.d.ts.map +1 -0
- package/dist/commands/delete/ios.js +24 -0
- package/dist/commands/delete/ios.js.map +1 -0
- package/dist/commands/delete/xcode.d.ts +14 -0
- package/dist/commands/delete/xcode.d.ts.map +1 -0
- package/dist/commands/delete/xcode.js +22 -0
- package/dist/commands/delete/xcode.js.map +1 -0
- package/dist/commands/exec/element-tree.d.ts +14 -0
- package/dist/commands/exec/element-tree.d.ts.map +1 -0
- package/dist/commands/exec/element-tree.js +51 -0
- package/dist/commands/exec/element-tree.js.map +1 -0
- package/dist/commands/exec/install-app.d.ts +16 -0
- package/dist/commands/exec/install-app.d.ts.map +1 -0
- package/dist/commands/exec/install-app.js +75 -0
- package/dist/commands/exec/install-app.js.map +1 -0
- package/dist/commands/exec/launch-app.d.ts +16 -0
- package/dist/commands/exec/launch-app.d.ts.map +1 -0
- package/dist/commands/exec/launch-app.js +49 -0
- package/dist/commands/exec/launch-app.js.map +1 -0
- package/dist/commands/exec/list-apps.d.ts +14 -0
- package/dist/commands/exec/list-apps.d.ts.map +1 -0
- package/dist/commands/exec/list-apps.js +45 -0
- package/dist/commands/exec/list-apps.js.map +1 -0
- package/dist/commands/exec/log.d.ts +17 -0
- package/dist/commands/exec/log.d.ts.map +1 -0
- package/dist/commands/exec/log.js +80 -0
- package/dist/commands/exec/log.js.map +1 -0
- package/dist/commands/exec/open-url.d.ts +15 -0
- package/dist/commands/exec/open-url.d.ts.map +1 -0
- package/dist/commands/exec/open-url.js +35 -0
- package/dist/commands/exec/open-url.js.map +1 -0
- package/dist/commands/exec/press-key.d.ts +16 -0
- package/dist/commands/exec/press-key.d.ts.map +1 -0
- package/dist/commands/exec/press-key.js +41 -0
- package/dist/commands/exec/press-key.js.map +1 -0
- package/dist/commands/exec/record.d.ts +17 -0
- package/dist/commands/exec/record.d.ts.map +1 -0
- package/dist/commands/exec/record.js +78 -0
- package/dist/commands/exec/record.js.map +1 -0
- package/dist/commands/exec/screenshot.d.ts +15 -0
- package/dist/commands/exec/screenshot.d.ts.map +1 -0
- package/dist/commands/exec/screenshot.js +65 -0
- package/dist/commands/exec/screenshot.js.map +1 -0
- package/dist/commands/exec/scroll.d.ts +16 -0
- package/dist/commands/exec/scroll.d.ts.map +1 -0
- package/dist/commands/exec/scroll.js +50 -0
- package/dist/commands/exec/scroll.js.map +1 -0
- package/dist/commands/exec/tap-element.d.ts +18 -0
- package/dist/commands/exec/tap-element.d.ts.map +1 -0
- package/dist/commands/exec/tap-element.js +91 -0
- package/dist/commands/exec/tap-element.js.map +1 -0
- package/dist/commands/exec/tap.d.ts +22 -0
- package/dist/commands/exec/tap.d.ts.map +1 -0
- package/dist/commands/exec/tap.js +41 -0
- package/dist/commands/exec/tap.js.map +1 -0
- package/dist/commands/exec/terminate-app.d.ts +15 -0
- package/dist/commands/exec/terminate-app.d.ts.map +1 -0
- package/dist/commands/exec/terminate-app.js +39 -0
- package/dist/commands/exec/terminate-app.js.map +1 -0
- package/dist/commands/exec/type.d.ts +16 -0
- package/dist/commands/exec/type.d.ts.map +1 -0
- package/dist/commands/exec/type.js +43 -0
- package/dist/commands/exec/type.js.map +1 -0
- package/dist/commands/get/android.d.ts +19 -0
- package/dist/commands/get/android.d.ts.map +1 -0
- package/dist/commands/get/android.js +69 -0
- package/dist/commands/get/android.js.map +1 -0
- package/dist/commands/get/asset.d.ts +18 -0
- package/dist/commands/get/asset.d.ts.map +1 -0
- package/dist/commands/get/asset.js +74 -0
- package/dist/commands/get/asset.js.map +1 -0
- package/dist/commands/get/ios.d.ts +19 -0
- package/dist/commands/get/ios.d.ts.map +1 -0
- package/dist/commands/get/ios.js +69 -0
- package/dist/commands/get/ios.js.map +1 -0
- package/dist/commands/get/xcode.d.ts +17 -0
- package/dist/commands/get/xcode.d.ts.map +1 -0
- package/dist/commands/get/xcode.js +65 -0
- package/dist/commands/get/xcode.js.map +1 -0
- package/dist/commands/login.d.ts +7 -0
- package/dist/commands/login.d.ts.map +1 -0
- package/dist/commands/login.js +18 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/logout.d.ts +7 -0
- package/dist/commands/logout.d.ts.map +1 -0
- package/dist/commands/logout.js +14 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/pull.d.ts +16 -0
- package/dist/commands/pull.d.ts.map +1 -0
- package/dist/commands/pull.js +71 -0
- package/dist/commands/pull.js.map +1 -0
- package/dist/commands/push.d.ts +15 -0
- package/dist/commands/push.d.ts.map +1 -0
- package/dist/commands/push.js +40 -0
- package/dist/commands/push.js.map +1 -0
- package/dist/commands/run/android.d.ts +24 -0
- package/dist/commands/run/android.d.ts.map +1 -0
- package/dist/commands/run/android.js +183 -0
- package/dist/commands/run/android.js.map +1 -0
- package/dist/commands/run/ios.d.ts +23 -0
- package/dist/commands/run/ios.d.ts.map +1 -0
- package/dist/commands/run/ios.js +129 -0
- package/dist/commands/run/ios.js.map +1 -0
- package/dist/commands/run/xcode.d.ts +19 -0
- package/dist/commands/run/xcode.d.ts.map +1 -0
- package/dist/commands/run/xcode.js +81 -0
- package/dist/commands/run/xcode.js.map +1 -0
- package/dist/commands/session/start.d.ts +15 -0
- package/dist/commands/session/start.d.ts.map +1 -0
- package/dist/commands/session/start.js +97 -0
- package/dist/commands/session/start.js.map +1 -0
- package/dist/commands/session/status.d.ts +11 -0
- package/dist/commands/session/status.d.ts.map +1 -0
- package/dist/commands/session/status.js +64 -0
- package/dist/commands/session/status.js.map +1 -0
- package/dist/commands/session/stop.d.ts +15 -0
- package/dist/commands/session/stop.d.ts.map +1 -0
- package/dist/commands/session/stop.js +67 -0
- package/dist/commands/session/stop.js.map +1 -0
- package/dist/commands/sync.d.ts +19 -0
- package/dist/commands/sync.d.ts.map +1 -0
- package/dist/commands/sync.js +80 -0
- package/dist/commands/sync.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/auth.d.ts +2 -0
- package/dist/lib/auth.d.ts.map +1 -0
- package/dist/lib/auth.js +60 -0
- package/dist/lib/auth.js.map +1 -0
- package/dist/lib/config.d.ts +21 -0
- package/dist/lib/config.d.ts.map +1 -0
- package/dist/lib/config.js +101 -0
- package/dist/lib/config.js.map +1 -0
- package/dist/lib/daemon-client.d.ts +9 -0
- package/dist/lib/daemon-client.d.ts.map +1 -0
- package/dist/lib/daemon-client.js +81 -0
- package/dist/lib/daemon-client.js.map +1 -0
- package/dist/lib/daemon.d.ts +40 -0
- package/dist/lib/daemon.d.ts.map +1 -0
- package/dist/lib/daemon.js +427 -0
- package/dist/lib/daemon.js.map +1 -0
- package/dist/lib/formatting.d.ts +3 -0
- package/dist/lib/formatting.d.ts.map +1 -0
- package/dist/lib/formatting.js +31 -0
- package/dist/lib/formatting.js.map +1 -0
- package/dist/lib/instance-client-factory.d.ts +23 -0
- package/dist/lib/instance-client-factory.d.ts.map +1 -0
- package/dist/lib/instance-client-factory.js +62 -0
- package/dist/lib/instance-client-factory.js.map +1 -0
- package/package.json +55 -0
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecElementTree extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecElementTree);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
12
|
+
const tree = await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'element-tree');
|
|
13
|
+
if (flags.json) {
|
|
14
|
+
this.outputJson(tree);
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
this.log(typeof tree === 'string' ? tree : JSON.stringify(tree, null, 2));
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
22
|
+
try {
|
|
23
|
+
if (type === 'ios') {
|
|
24
|
+
const tree = await client.elementTree();
|
|
25
|
+
this.log(typeof tree === 'string' ? tree : JSON.stringify(tree, null, 2));
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
const tree = await client.getElementTree();
|
|
29
|
+
if (flags.json) {
|
|
30
|
+
this.outputJson(tree);
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
this.log(tree.xml || JSON.stringify(tree.nodes, null, 2));
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
finally {
|
|
38
|
+
disconnect();
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
ExecElementTree.summary = 'Get the UI element tree from a running instance';
|
|
45
|
+
ExecElementTree.examples = ['<%= config.bin %> exec element-tree <instance-ID>'];
|
|
46
|
+
ExecElementTree.args = {
|
|
47
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
48
|
+
};
|
|
49
|
+
ExecElementTree.flags = { ...base_command_1.BaseCommand.baseFlags };
|
|
50
|
+
exports.default = ExecElementTree;
|
|
51
|
+
//# sourceMappingURL=element-tree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"element-tree.js","sourceRoot":"","sources":["../../../src/commands/exec/element-tree.ts"],"names":[],"mappings":";;AAAA,sCAAmC;AACnC,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,eAAgB,SAAQ,0BAAW;IAUtD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;QAC1D,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,MAAM,IAAI,GAAG,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,cAAc,CAAC,CAAC;gBAC/D,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;oBACf,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBACxB,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,GAAG,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;gBAC5E,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBACnF,IAAI,CAAC;oBACH,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;wBACnB,MAAM,IAAI,GAAG,MAAO,MAAc,CAAC,WAAW,EAAE,CAAC;wBACjD,IAAI,CAAC,GAAG,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;oBAC5E,CAAC;yBAAM,CAAC;wBACN,MAAM,IAAI,GAAG,MAAO,MAAc,CAAC,cAAc,EAAE,CAAC;wBACpD,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;4BACf,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;wBACxB,CAAC;6BAAM,CAAC;4BACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;wBAC5D,CAAC;oBACH,CAAC;gBACH,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;;AAxCM,uBAAO,GAAG,iDAAiD,CAAC;AAC5D,wBAAQ,GAAG,CAAC,mDAAmD,CAAC,CAAC;AAEjE,oBAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAChE,CAAC;AAEK,qBAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAC;kBARzB,eAAe"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecInstallApp extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static description: string;
|
|
5
|
+
static examples: string[];
|
|
6
|
+
static args: {
|
|
7
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
path_or_url: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
9
|
+
};
|
|
10
|
+
static flags: {
|
|
11
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
};
|
|
14
|
+
run(): Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=install-app.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"install-app.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/install-app.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,cAAe,SAAQ,WAAW;IACrD,MAAM,CAAC,OAAO,SAA0C;IACxD,MAAM,CAAC,WAAW,SACkF;IAEpG,MAAM,CAAC,QAAQ,WAGb;IAEF,MAAM,CAAC,IAAI;;;MAGT;IAEF,MAAM,CAAC,KAAK;;;MAAgC;IAEtC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CA+C3B"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const path_1 = __importDefault(require("path"));
|
|
7
|
+
const fs_1 = __importDefault(require("fs"));
|
|
8
|
+
const core_1 = require("@oclif/core");
|
|
9
|
+
const base_command_1 = require("../../base-command");
|
|
10
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
11
|
+
class ExecInstallApp extends base_command_1.BaseCommand {
|
|
12
|
+
async run() {
|
|
13
|
+
const { args, flags } = await this.parse(ExecInstallApp);
|
|
14
|
+
this.setParsedFlags(flags);
|
|
15
|
+
await this.withAuth(async () => {
|
|
16
|
+
let downloadUrl;
|
|
17
|
+
if (args.path_or_url.startsWith('http://') || args.path_or_url.startsWith('https://')) {
|
|
18
|
+
downloadUrl = args.path_or_url;
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
const filePath = path_1.default.resolve(args.path_or_url);
|
|
22
|
+
if (!fs_1.default.existsSync(filePath)) {
|
|
23
|
+
this.error(`File not found: ${filePath}`);
|
|
24
|
+
}
|
|
25
|
+
const name = path_1.default.basename(filePath);
|
|
26
|
+
this.log(`Uploading ${name}...`);
|
|
27
|
+
const asset = await this.client.assets.getOrUpload({ path: filePath, name });
|
|
28
|
+
downloadUrl = asset.signedDownloadUrl;
|
|
29
|
+
}
|
|
30
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
31
|
+
const result = await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'install-app', [downloadUrl]);
|
|
32
|
+
if (flags.json) {
|
|
33
|
+
this.outputJson(result);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
this.log('App installed');
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
41
|
+
try {
|
|
42
|
+
if (type === 'ios') {
|
|
43
|
+
const result = await client.installApp(downloadUrl);
|
|
44
|
+
if (flags.json) {
|
|
45
|
+
this.outputJson(result);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
this.log(`App installed${result?.bundleId ? `: ${result.bundleId}` : ''}`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
await client.sendAsset(downloadUrl);
|
|
53
|
+
this.log('App sent to instance');
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
finally {
|
|
57
|
+
disconnect();
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
ExecInstallApp.summary = 'Install an app on a running instance';
|
|
64
|
+
ExecInstallApp.description = 'Installs an app from a local file or URL. Local files are auto-uploaded to asset storage first.';
|
|
65
|
+
ExecInstallApp.examples = [
|
|
66
|
+
'<%= config.bin %> exec install-app <instance-ID> ./MyApp.ipa',
|
|
67
|
+
'<%= config.bin %> exec install-app <instance-ID> https://example.com/app.apk',
|
|
68
|
+
];
|
|
69
|
+
ExecInstallApp.args = {
|
|
70
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
71
|
+
path_or_url: core_1.Args.string({ description: 'Local file path or URL', required: true }),
|
|
72
|
+
};
|
|
73
|
+
ExecInstallApp.flags = { ...base_command_1.BaseCommand.baseFlags };
|
|
74
|
+
exports.default = ExecInstallApp;
|
|
75
|
+
//# sourceMappingURL=install-app.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"install-app.js","sourceRoot":"","sources":["../../../src/commands/exec/install-app.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecLaunchApp extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
bundleId: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
mode: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
};
|
|
14
|
+
run(): Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=launch-app.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"launch-app.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/launch-app.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,aAAc,SAAQ,WAAW;IACpD,MAAM,CAAC,OAAO,SAA6C;IAC3D,MAAM,CAAC,QAAQ,WAGb;IAEF,MAAM,CAAC,IAAI;;;MAGT;IAEF,MAAM,CAAC,KAAK;;;;MAOV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAsB3B"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecLaunchApp extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecLaunchApp);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
12
|
+
await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'launch-app', [args.bundleId, flags.mode]);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
16
|
+
if (type !== 'ios') {
|
|
17
|
+
disconnect();
|
|
18
|
+
this.error('launch-app is only supported on iOS instances');
|
|
19
|
+
}
|
|
20
|
+
try {
|
|
21
|
+
await client.launchApp(args.bundleId, flags.mode);
|
|
22
|
+
}
|
|
23
|
+
finally {
|
|
24
|
+
disconnect();
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
this.log(`Launched ${args.bundleId}`);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
ExecLaunchApp.summary = 'Launch an app on a running iOS instance';
|
|
32
|
+
ExecLaunchApp.examples = [
|
|
33
|
+
'<%= config.bin %> exec launch-app <instance-ID> com.example.app',
|
|
34
|
+
'<%= config.bin %> exec launch-app <instance-ID> com.example.app --mode RelaunchIfRunning',
|
|
35
|
+
];
|
|
36
|
+
ExecLaunchApp.args = {
|
|
37
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
38
|
+
bundleId: core_1.Args.string({ description: 'App bundle identifier', required: true }),
|
|
39
|
+
};
|
|
40
|
+
ExecLaunchApp.flags = {
|
|
41
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
42
|
+
mode: core_1.Flags.string({
|
|
43
|
+
description: 'Launch mode',
|
|
44
|
+
options: ['ForegroundIfRunning', 'RelaunchIfRunning'],
|
|
45
|
+
default: 'ForegroundIfRunning',
|
|
46
|
+
}),
|
|
47
|
+
};
|
|
48
|
+
exports.default = ExecLaunchApp;
|
|
49
|
+
//# sourceMappingURL=launch-app.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"launch-app.js","sourceRoot":"","sources":["../../../src/commands/exec/launch-app.ts"],"names":[],"mappings":";;AAAA,sCAA0C;AAC1C,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,aAAc,SAAQ,0BAAW;IAqBpD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACxD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,YAAY,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;YAC/E,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBACnF,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;oBACnB,UAAU,EAAE,CAAC;oBACb,IAAI,CAAC,KAAK,CAAC,+CAA+C,CAAC,CAAC;gBAC9D,CAAC;gBACD,IAAI,CAAC;oBACH,MAAO,MAAc,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;gBAC7D,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;;AAzCM,qBAAO,GAAG,yCAAyC,CAAC;AACpD,sBAAQ,GAAG;IAChB,iEAAiE;IACjE,0FAA0F;CAC3F,CAAC;AAEK,kBAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC/D,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,uBAAuB,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAChF,CAAC;AAEK,mBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,IAAI,EAAE,YAAK,CAAC,MAAM,CAAC;QACjB,WAAW,EAAE,aAAa;QAC1B,OAAO,EAAE,CAAC,qBAAqB,EAAE,mBAAmB,CAAC;QACrD,OAAO,EAAE,qBAAqB;KAC/B,CAAC;CACH,CAAC;kBAnBiB,aAAa"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecListApps extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
};
|
|
12
|
+
run(): Promise<void>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=list-apps.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list-apps.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/list-apps.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,YAAa,SAAQ,WAAW;IACnD,MAAM,CAAC,OAAO,SAAmD;IACjE,MAAM,CAAC,QAAQ,WAAsD;IAErE,MAAM,CAAC,IAAI;;MAET;IAEF,MAAM,CAAC,KAAK;;;MAAgC;IAEtC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CA8B3B"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecListApps extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecListApps);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
let apps;
|
|
12
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
13
|
+
apps = (await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'list-apps'));
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
17
|
+
if (type !== 'ios') {
|
|
18
|
+
disconnect();
|
|
19
|
+
this.error('list-apps is only supported on iOS instances');
|
|
20
|
+
}
|
|
21
|
+
try {
|
|
22
|
+
apps = await client.listApps();
|
|
23
|
+
}
|
|
24
|
+
finally {
|
|
25
|
+
disconnect();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
if (flags.json) {
|
|
29
|
+
this.outputJson(apps);
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
const rows = apps.map((a) => [a.bundleId, a.name, a.installType]);
|
|
33
|
+
this.outputTable(['Bundle ID', 'Name', 'Install Type'], rows);
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
ExecListApps.summary = 'List installed apps on a running iOS instance';
|
|
39
|
+
ExecListApps.examples = ['<%= config.bin %> exec list-apps <instance-ID>'];
|
|
40
|
+
ExecListApps.args = {
|
|
41
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
42
|
+
};
|
|
43
|
+
ExecListApps.flags = { ...base_command_1.BaseCommand.baseFlags };
|
|
44
|
+
exports.default = ExecListApps;
|
|
45
|
+
//# sourceMappingURL=list-apps.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list-apps.js","sourceRoot":"","sources":["../../../src/commands/exec/list-apps.ts"],"names":[],"mappings":";;AAAA,sCAAmC;AACnC,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,YAAa,SAAQ,0BAAW;IAUnD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACvD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,IAAW,CAAC;YAEhB,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,IAAI,GAAG,CAAC,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,WAAW,CAAC,CAAU,CAAC;YACnE,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBACnF,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;oBACnB,UAAU,EAAE,CAAC;oBACb,IAAI,CAAC,KAAK,CAAC,8CAA8C,CAAC,CAAC;gBAC7D,CAAC;gBACD,IAAI,CAAC;oBACH,IAAI,GAAG,MAAO,MAAc,CAAC,QAAQ,EAAE,CAAC;gBAC1C,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YAED,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACxB,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC;gBACvE,IAAI,CAAC,WAAW,CAAC,CAAC,WAAW,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;YAChE,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;;AAtCM,oBAAO,GAAG,+CAA+C,CAAC;AAC1D,qBAAQ,GAAG,CAAC,gDAAgD,CAAC,CAAC;AAE9D,iBAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAChE,CAAC;AAEK,kBAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAC;kBARzB,YAAY"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecLog extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
bundleId: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
follow: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
lines: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
13
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=log.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/log.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,OAAQ,SAAQ,WAAW;IAC9C,MAAM,CAAC,OAAO,SAAyD;IACvE,MAAM,CAAC,QAAQ,WAIb;IAEF,MAAM,CAAC,IAAI;;;MAGT;IAEF,MAAM,CAAC,KAAK;;;;;MAIV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAyD3B"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecLog extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecLog);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
// Log tail (non-streaming) can use session
|
|
12
|
+
if (!flags.follow) {
|
|
13
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
14
|
+
const output = await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'app-log-tail', [args.bundleId, flags.lines]);
|
|
15
|
+
this.log(String(output));
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
19
|
+
if (type !== 'ios') {
|
|
20
|
+
disconnect();
|
|
21
|
+
this.error('log command is only supported on iOS instances');
|
|
22
|
+
}
|
|
23
|
+
try {
|
|
24
|
+
const output = await client.appLogTail(args.bundleId, flags.lines);
|
|
25
|
+
this.log(output);
|
|
26
|
+
}
|
|
27
|
+
finally {
|
|
28
|
+
disconnect();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
// Streaming requires direct connection (long-lived)
|
|
34
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
35
|
+
if (type !== 'ios') {
|
|
36
|
+
disconnect();
|
|
37
|
+
this.error('log command is only supported on iOS instances');
|
|
38
|
+
}
|
|
39
|
+
try {
|
|
40
|
+
const logStream = client.streamAppLog(args.bundleId);
|
|
41
|
+
logStream.on('line', (line) => {
|
|
42
|
+
process.stdout.write(line + '\n');
|
|
43
|
+
});
|
|
44
|
+
logStream.on('error', (err) => {
|
|
45
|
+
this.warn(`Log stream error: ${err.message}`);
|
|
46
|
+
});
|
|
47
|
+
await new Promise((resolve) => {
|
|
48
|
+
const keepAlive = setInterval(() => { }, 1 << 30);
|
|
49
|
+
const shutdown = () => {
|
|
50
|
+
clearInterval(keepAlive);
|
|
51
|
+
logStream.stop();
|
|
52
|
+
resolve();
|
|
53
|
+
};
|
|
54
|
+
process.on('SIGINT', shutdown);
|
|
55
|
+
process.on('SIGTERM', shutdown);
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
finally {
|
|
59
|
+
disconnect();
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
ExecLog.summary = 'Stream or tail app logs from a running iOS instance';
|
|
65
|
+
ExecLog.examples = [
|
|
66
|
+
'<%= config.bin %> exec log <instance-ID> com.example.app',
|
|
67
|
+
'<%= config.bin %> exec log <instance-ID> com.example.app --lines 50',
|
|
68
|
+
'<%= config.bin %> exec log <instance-ID> com.example.app -f',
|
|
69
|
+
];
|
|
70
|
+
ExecLog.args = {
|
|
71
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
72
|
+
bundleId: core_1.Args.string({ description: 'App bundle identifier', required: true }),
|
|
73
|
+
};
|
|
74
|
+
ExecLog.flags = {
|
|
75
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
76
|
+
follow: core_1.Flags.boolean({ char: 'f', description: 'Stream logs continuously', default: false }),
|
|
77
|
+
lines: core_1.Flags.integer({ description: 'Number of lines to tail (non-streaming)', default: 100 }),
|
|
78
|
+
};
|
|
79
|
+
exports.default = ExecLog;
|
|
80
|
+
//# sourceMappingURL=log.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log.js","sourceRoot":"","sources":["../../../src/commands/exec/log.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecOpenUrl extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
url: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=open-url.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"open-url.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/open-url.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,WAAY,SAAQ,WAAW;IAClD,MAAM,CAAC,OAAO,SAAsC;IACpD,MAAM,CAAC,QAAQ,WAAyE;IAExF,MAAM,CAAC,IAAI;;;MAGT;IAEF,MAAM,CAAC,KAAK;;;MAAgC;IAEtC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAkB3B"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecOpenUrl extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecOpenUrl);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
12
|
+
await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'open-url', [args.url]);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const { client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
16
|
+
try {
|
|
17
|
+
await client.openUrl(args.url);
|
|
18
|
+
}
|
|
19
|
+
finally {
|
|
20
|
+
disconnect();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
this.log(`Opened URL: ${args.url}`);
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
ExecOpenUrl.summary = 'Open a URL on a running instance';
|
|
28
|
+
ExecOpenUrl.examples = ['<%= config.bin %> exec open-url <instance-ID> https://example.com'];
|
|
29
|
+
ExecOpenUrl.args = {
|
|
30
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
31
|
+
url: core_1.Args.string({ description: 'URL to open', required: true }),
|
|
32
|
+
};
|
|
33
|
+
ExecOpenUrl.flags = { ...base_command_1.BaseCommand.baseFlags };
|
|
34
|
+
exports.default = ExecOpenUrl;
|
|
35
|
+
//# sourceMappingURL=open-url.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"open-url.js","sourceRoot":"","sources":["../../../src/commands/exec/open-url.ts"],"names":[],"mappings":";;AAAA,sCAAmC;AACnC,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,WAAY,SAAQ,0BAAW;IAWlD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QACtD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,UAAU,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;YAC5D,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC7E,IAAI,CAAC;oBACH,MAAO,MAAc,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC1C,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACL,CAAC;;AA3BM,mBAAO,GAAG,kCAAkC,CAAC;AAC7C,oBAAQ,GAAG,CAAC,mEAAmE,CAAC,CAAC;AAEjF,gBAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC/D,GAAG,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACjE,CAAC;AAEK,iBAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAC;kBATzB,WAAW"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecPressKey extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
key: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
modifier: import("@oclif/core/lib/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
};
|
|
14
|
+
run(): Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=press-key.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"press-key.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/press-key.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,YAAa,SAAQ,WAAW;IACnD,MAAM,CAAC,OAAO,SAAuC;IACrD,MAAM,CAAC,QAAQ,WAGb;IAEF,MAAM,CAAC,IAAI;;;MAGT;IAEF,MAAM,CAAC,KAAK;;;;MAGV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAkB3B"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecPressKey extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecPressKey);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
12
|
+
await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'press-key', [args.key, flags.modifier]);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const { client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
16
|
+
try {
|
|
17
|
+
await client.pressKey(args.key, flags.modifier);
|
|
18
|
+
}
|
|
19
|
+
finally {
|
|
20
|
+
disconnect();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
this.log(`Pressed key: ${args.key}`);
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
ExecPressKey.summary = 'Press a key on a running instance';
|
|
28
|
+
ExecPressKey.examples = [
|
|
29
|
+
'<%= config.bin %> exec press-key <instance-ID> enter',
|
|
30
|
+
'<%= config.bin %> exec press-key <instance-ID> a --modifier shift',
|
|
31
|
+
];
|
|
32
|
+
ExecPressKey.args = {
|
|
33
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
34
|
+
key: core_1.Args.string({ description: 'Key to press (e.g. enter, backspace, a, f1)', required: true }),
|
|
35
|
+
};
|
|
36
|
+
ExecPressKey.flags = {
|
|
37
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
38
|
+
modifier: core_1.Flags.string({ description: 'Modifier key (e.g. shift, command, alt)', multiple: true }),
|
|
39
|
+
};
|
|
40
|
+
exports.default = ExecPressKey;
|
|
41
|
+
//# sourceMappingURL=press-key.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"press-key.js","sourceRoot":"","sources":["../../../src/commands/exec/press-key.ts"],"names":[],"mappings":";;AAAA,sCAA0C;AAC1C,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,YAAa,SAAQ,0BAAW;IAiBnD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACvD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,WAAW,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC7E,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC7E,IAAI,CAAC;oBACH,MAAO,MAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;gBAC3D,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,gBAAgB,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;;AAjCM,oBAAO,GAAG,mCAAmC,CAAC;AAC9C,qBAAQ,GAAG;IAChB,sDAAsD;IACtD,mEAAmE;CACpE,CAAC;AAEK,iBAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC/D,GAAG,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,6CAA6C,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACjG,CAAC;AAEK,kBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,QAAQ,EAAE,YAAK,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,yCAAyC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACnG,CAAC;kBAfiB,YAAY"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecRecord extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
action: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
quality: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
output: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
13
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=record.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"record.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/record.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,UAAW,SAAQ,WAAW;IACjD,MAAM,CAAC,OAAO,SAAyD;IACvE,MAAM,CAAC,QAAQ,WAIb;IAEF,MAAM,CAAC,IAAI;;;MAGT;IAEF,MAAM,CAAC,KAAK;;;;;MAIV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CA4C3B"}
|