@lhremote/cli 0.1.0 → 0.2.1
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 +58 -2
- package/dist/cli.js +2 -0
- package/dist/cli.js.map +1 -1
- package/dist/handlers/campaign-add-action.d.ts +14 -0
- package/dist/handlers/campaign-add-action.d.ts.map +1 -0
- package/dist/handlers/campaign-add-action.js +51 -0
- package/dist/handlers/campaign-add-action.js.map +1 -0
- package/dist/handlers/campaign-add-action.test.d.ts +2 -0
- package/dist/handlers/campaign-add-action.test.d.ts.map +1 -0
- package/dist/handlers/campaign-add-action.test.js +121 -0
- package/dist/handlers/campaign-add-action.test.js.map +1 -0
- package/dist/handlers/campaign-create.d.ts +11 -0
- package/dist/handlers/campaign-create.d.ts.map +1 -0
- package/dist/handlers/campaign-create.js +79 -0
- package/dist/handlers/campaign-create.js.map +1 -0
- package/dist/handlers/campaign-create.test.d.ts +2 -0
- package/dist/handlers/campaign-create.test.d.ts.map +1 -0
- package/dist/handlers/campaign-create.test.js +139 -0
- package/dist/handlers/campaign-create.test.js.map +1 -0
- package/dist/handlers/campaign-delete.d.ts +8 -0
- package/dist/handlers/campaign-delete.d.ts.map +1 -0
- package/dist/handlers/campaign-delete.js +39 -0
- package/dist/handlers/campaign-delete.js.map +1 -0
- package/dist/handlers/campaign-delete.test.d.ts +2 -0
- package/dist/handlers/campaign-delete.test.d.ts.map +1 -0
- package/dist/handlers/campaign-delete.test.js +73 -0
- package/dist/handlers/campaign-delete.test.js.map +1 -0
- package/dist/handlers/campaign-exclude-add.d.ts +11 -0
- package/dist/handlers/campaign-exclude-add.d.ts.map +1 -0
- package/dist/handlers/campaign-exclude-add.js +58 -0
- package/dist/handlers/campaign-exclude-add.js.map +1 -0
- package/dist/handlers/campaign-exclude-add.test.d.ts +2 -0
- package/dist/handlers/campaign-exclude-add.test.d.ts.map +1 -0
- package/dist/handlers/campaign-exclude-add.test.js +144 -0
- package/dist/handlers/campaign-exclude-add.test.js.map +1 -0
- package/dist/handlers/campaign-exclude-list.d.ts +9 -0
- package/dist/handlers/campaign-exclude-list.d.ts.map +1 -0
- package/dist/handlers/campaign-exclude-list.js +46 -0
- package/dist/handlers/campaign-exclude-list.js.map +1 -0
- package/dist/handlers/campaign-exclude-list.test.d.ts +2 -0
- package/dist/handlers/campaign-exclude-list.test.d.ts.map +1 -0
- package/dist/handlers/campaign-exclude-list.test.js +109 -0
- package/dist/handlers/campaign-exclude-list.test.js.map +1 -0
- package/dist/handlers/campaign-exclude-remove.d.ts +11 -0
- package/dist/handlers/campaign-exclude-remove.d.ts.map +1 -0
- package/dist/handlers/campaign-exclude-remove.js +58 -0
- package/dist/handlers/campaign-exclude-remove.js.map +1 -0
- package/dist/handlers/campaign-exclude-remove.test.d.ts +2 -0
- package/dist/handlers/campaign-exclude-remove.test.d.ts.map +1 -0
- package/dist/handlers/campaign-exclude-remove.test.js +147 -0
- package/dist/handlers/campaign-exclude-remove.test.js.map +1 -0
- package/dist/handlers/campaign-export.d.ts +9 -0
- package/dist/handlers/campaign-export.d.ts.map +1 -0
- package/dist/handlers/campaign-export.js +42 -0
- package/dist/handlers/campaign-export.js.map +1 -0
- package/dist/handlers/campaign-export.test.d.ts +2 -0
- package/dist/handlers/campaign-export.test.d.ts.map +1 -0
- package/dist/handlers/campaign-export.test.js +84 -0
- package/dist/handlers/campaign-export.test.js.map +1 -0
- package/dist/handlers/campaign-get.d.ts +8 -0
- package/dist/handlers/campaign-get.d.ts.map +1 -0
- package/dist/handlers/campaign-get.js +46 -0
- package/dist/handlers/campaign-get.js.map +1 -0
- package/dist/handlers/campaign-get.test.d.ts +2 -0
- package/dist/handlers/campaign-get.test.d.ts.map +1 -0
- package/dist/handlers/campaign-get.test.js +131 -0
- package/dist/handlers/campaign-get.test.js.map +1 -0
- package/dist/handlers/campaign-list.d.ts +6 -0
- package/dist/handlers/campaign-list.d.ts.map +1 -0
- package/dist/handlers/campaign-list.js +55 -0
- package/dist/handlers/campaign-list.js.map +1 -0
- package/dist/handlers/campaign-list.test.d.ts +2 -0
- package/dist/handlers/campaign-list.test.d.ts.map +1 -0
- package/dist/handlers/campaign-list.test.js +129 -0
- package/dist/handlers/campaign-list.test.js.map +1 -0
- package/dist/handlers/campaign-move-next.d.ts +10 -0
- package/dist/handlers/campaign-move-next.d.ts.map +1 -0
- package/dist/handlers/campaign-move-next.js +52 -0
- package/dist/handlers/campaign-move-next.js.map +1 -0
- package/dist/handlers/campaign-move-next.test.d.ts +2 -0
- package/dist/handlers/campaign-move-next.test.d.ts.map +1 -0
- package/dist/handlers/campaign-move-next.test.js +127 -0
- package/dist/handlers/campaign-move-next.test.js.map +1 -0
- package/dist/handlers/campaign-remove-action.d.ts +8 -0
- package/dist/handlers/campaign-remove-action.d.ts.map +1 -0
- package/dist/handlers/campaign-remove-action.js +43 -0
- package/dist/handlers/campaign-remove-action.js.map +1 -0
- package/dist/handlers/campaign-remove-action.test.d.ts +2 -0
- package/dist/handlers/campaign-remove-action.test.d.ts.map +1 -0
- package/dist/handlers/campaign-remove-action.test.js +79 -0
- package/dist/handlers/campaign-remove-action.test.js.map +1 -0
- package/dist/handlers/campaign-reorder-actions.d.ts +9 -0
- package/dist/handlers/campaign-reorder-actions.d.ts.map +1 -0
- package/dist/handlers/campaign-reorder-actions.js +66 -0
- package/dist/handlers/campaign-reorder-actions.js.map +1 -0
- package/dist/handlers/campaign-reorder-actions.test.d.ts +2 -0
- package/dist/handlers/campaign-reorder-actions.test.d.ts.map +1 -0
- package/dist/handlers/campaign-reorder-actions.test.js +118 -0
- package/dist/handlers/campaign-reorder-actions.test.js.map +1 -0
- package/dist/handlers/campaign-retry.d.ts +10 -0
- package/dist/handlers/campaign-retry.d.ts.map +1 -0
- package/dist/handlers/campaign-retry.js +45 -0
- package/dist/handlers/campaign-retry.js.map +1 -0
- package/dist/handlers/campaign-retry.test.d.ts +2 -0
- package/dist/handlers/campaign-retry.test.d.ts.map +1 -0
- package/dist/handlers/campaign-retry.test.js +111 -0
- package/dist/handlers/campaign-retry.test.js.map +1 -0
- package/dist/handlers/campaign-start.d.ts +10 -0
- package/dist/handlers/campaign-start.d.ts.map +1 -0
- package/dist/handlers/campaign-start.js +54 -0
- package/dist/handlers/campaign-start.js.map +1 -0
- package/dist/handlers/campaign-start.test.d.ts +2 -0
- package/dist/handlers/campaign-start.test.d.ts.map +1 -0
- package/dist/handlers/campaign-start.test.js +119 -0
- package/dist/handlers/campaign-start.test.js.map +1 -0
- package/dist/handlers/campaign-statistics.d.ts +10 -0
- package/dist/handlers/campaign-statistics.d.ts.map +1 -0
- package/dist/handlers/campaign-statistics.js +63 -0
- package/dist/handlers/campaign-statistics.js.map +1 -0
- package/dist/handlers/campaign-statistics.test.d.ts +2 -0
- package/dist/handlers/campaign-statistics.test.d.ts.map +1 -0
- package/dist/handlers/campaign-statistics.test.js +141 -0
- package/dist/handlers/campaign-statistics.test.js.map +1 -0
- package/dist/handlers/campaign-status.d.ts +10 -0
- package/dist/handlers/campaign-status.d.ts.map +1 -0
- package/dist/handlers/campaign-status.js +62 -0
- package/dist/handlers/campaign-status.js.map +1 -0
- package/dist/handlers/campaign-status.test.d.ts +2 -0
- package/dist/handlers/campaign-status.test.d.ts.map +1 -0
- package/dist/handlers/campaign-status.test.js +123 -0
- package/dist/handlers/campaign-status.test.js.map +1 -0
- package/dist/handlers/campaign-stop.d.ts +8 -0
- package/dist/handlers/campaign-stop.d.ts.map +1 -0
- package/dist/handlers/campaign-stop.js +39 -0
- package/dist/handlers/campaign-stop.js.map +1 -0
- package/dist/handlers/campaign-stop.test.d.ts +2 -0
- package/dist/handlers/campaign-stop.test.d.ts.map +1 -0
- package/dist/handlers/campaign-stop.test.js +73 -0
- package/dist/handlers/campaign-stop.test.js.map +1 -0
- package/dist/handlers/campaign-update.d.ts +11 -0
- package/dist/handlers/campaign-update.d.ts.map +1 -0
- package/dist/handlers/campaign-update.js +51 -0
- package/dist/handlers/campaign-update.js.map +1 -0
- package/dist/handlers/campaign-update.test.d.ts +2 -0
- package/dist/handlers/campaign-update.test.d.ts.map +1 -0
- package/dist/handlers/campaign-update.test.js +95 -0
- package/dist/handlers/campaign-update.test.js.map +1 -0
- package/dist/handlers/check-replies.d.ts +9 -0
- package/dist/handlers/check-replies.d.ts.map +1 -0
- package/dist/handlers/check-replies.js +49 -0
- package/dist/handlers/check-replies.js.map +1 -0
- package/dist/handlers/check-replies.test.d.ts +2 -0
- package/dist/handlers/check-replies.test.d.ts.map +1 -0
- package/dist/handlers/check-replies.test.js +138 -0
- package/dist/handlers/check-replies.test.js.map +1 -0
- package/dist/handlers/check-status.d.ts +3 -0
- package/dist/handlers/check-status.d.ts.map +1 -1
- package/dist/handlers/check-status.js +9 -3
- package/dist/handlers/check-status.js.map +1 -1
- package/dist/handlers/check-status.test.js +3 -1
- package/dist/handlers/check-status.test.js.map +1 -1
- package/dist/handlers/describe-actions.d.ts +7 -0
- package/dist/handlers/describe-actions.d.ts.map +1 -0
- package/dist/handlers/describe-actions.js +74 -0
- package/dist/handlers/describe-actions.js.map +1 -0
- package/dist/handlers/describe-actions.test.d.ts +2 -0
- package/dist/handlers/describe-actions.test.d.ts.map +1 -0
- package/dist/handlers/describe-actions.test.js +95 -0
- package/dist/handlers/describe-actions.test.js.map +1 -0
- package/dist/handlers/find-app.d.ts +5 -0
- package/dist/handlers/find-app.d.ts.map +1 -0
- package/dist/handlers/find-app.js +28 -0
- package/dist/handlers/find-app.js.map +1 -0
- package/dist/handlers/find-app.test.d.ts +2 -0
- package/dist/handlers/find-app.test.d.ts.map +1 -0
- package/dist/handlers/find-app.test.js +75 -0
- package/dist/handlers/find-app.test.js.map +1 -0
- package/dist/handlers/import-people-from-urls.d.ts +10 -0
- package/dist/handlers/import-people-from-urls.d.ts.map +1 -0
- package/dist/handlers/import-people-from-urls.js +96 -0
- package/dist/handlers/import-people-from-urls.js.map +1 -0
- package/dist/handlers/import-people-from-urls.test.d.ts +2 -0
- package/dist/handlers/import-people-from-urls.test.d.ts.map +1 -0
- package/dist/handlers/import-people-from-urls.test.js +166 -0
- package/dist/handlers/import-people-from-urls.test.js.map +1 -0
- package/dist/handlers/index.d.ts +26 -1
- package/dist/handlers/index.d.ts.map +1 -1
- package/dist/handlers/index.js +28 -1
- package/dist/handlers/index.js.map +1 -1
- package/dist/handlers/launch-app.d.ts +2 -3
- package/dist/handlers/launch-app.d.ts.map +1 -1
- package/dist/handlers/launch-app.js +7 -4
- package/dist/handlers/launch-app.js.map +1 -1
- package/dist/handlers/launch-app.test.js +8 -6
- package/dist/handlers/launch-app.test.js.map +1 -1
- package/dist/handlers/list-accounts.d.ts +3 -0
- package/dist/handlers/list-accounts.d.ts.map +1 -1
- package/dist/handlers/list-accounts.js +10 -4
- package/dist/handlers/list-accounts.js.map +1 -1
- package/dist/handlers/list-accounts.test.js +4 -13
- package/dist/handlers/list-accounts.test.js.map +1 -1
- package/dist/handlers/person-ids.d.ts +7 -0
- package/dist/handlers/person-ids.d.ts.map +1 -0
- package/dist/handlers/person-ids.js +50 -0
- package/dist/handlers/person-ids.js.map +1 -0
- package/dist/handlers/query-messages.d.ts +10 -0
- package/dist/handlers/query-messages.d.ts.map +1 -0
- package/dist/handlers/query-messages.integration.test.d.ts +2 -0
- package/dist/handlers/query-messages.integration.test.d.ts.map +1 -0
- package/dist/handlers/query-messages.integration.test.js +106 -0
- package/dist/handlers/query-messages.integration.test.js.map +1 -0
- package/dist/handlers/query-messages.js +113 -0
- package/dist/handlers/query-messages.js.map +1 -0
- package/dist/handlers/query-messages.test.d.ts +2 -0
- package/dist/handlers/query-messages.test.d.ts.map +1 -0
- package/dist/handlers/query-messages.test.js +231 -0
- package/dist/handlers/query-messages.test.js.map +1 -0
- package/dist/handlers/query-profile.d.ts +7 -0
- package/dist/handlers/query-profile.d.ts.map +1 -0
- package/dist/handlers/query-profile.js +79 -0
- package/dist/handlers/query-profile.js.map +1 -0
- package/dist/handlers/query-profile.test.d.ts +2 -0
- package/dist/handlers/query-profile.test.d.ts.map +1 -0
- package/dist/handlers/query-profile.test.js +221 -0
- package/dist/handlers/query-profile.test.js.map +1 -0
- package/dist/handlers/query-profiles.d.ts +9 -0
- package/dist/handlers/query-profiles.d.ts.map +1 -0
- package/dist/handlers/query-profiles.js +83 -0
- package/dist/handlers/query-profiles.js.map +1 -0
- package/dist/handlers/query-profiles.test.d.ts +2 -0
- package/dist/handlers/query-profiles.test.d.ts.map +1 -0
- package/dist/handlers/query-profiles.test.js +286 -0
- package/dist/handlers/query-profiles.test.js.map +1 -0
- package/dist/handlers/quit-app.d.ts +2 -3
- package/dist/handlers/quit-app.d.ts.map +1 -1
- package/dist/handlers/quit-app.js +7 -4
- package/dist/handlers/quit-app.js.map +1 -1
- package/dist/handlers/quit-app.test.js +6 -14
- package/dist/handlers/quit-app.test.js.map +1 -1
- package/dist/handlers/scrape-messaging-history.d.ts +8 -0
- package/dist/handlers/scrape-messaging-history.d.ts.map +1 -0
- package/dist/handlers/scrape-messaging-history.js +45 -0
- package/dist/handlers/scrape-messaging-history.js.map +1 -0
- package/dist/handlers/scrape-messaging-history.test.d.ts +2 -0
- package/dist/handlers/scrape-messaging-history.test.d.ts.map +1 -0
- package/dist/handlers/scrape-messaging-history.test.js +101 -0
- package/dist/handlers/scrape-messaging-history.test.js.map +1 -0
- package/dist/handlers/start-instance.d.ts +3 -0
- package/dist/handlers/start-instance.d.ts.map +1 -1
- package/dist/handlers/start-instance.js +11 -5
- package/dist/handlers/start-instance.js.map +1 -1
- package/dist/handlers/start-instance.test.js +13 -38
- package/dist/handlers/start-instance.test.js.map +1 -1
- package/dist/handlers/stop-instance.d.ts +3 -0
- package/dist/handlers/stop-instance.d.ts.map +1 -1
- package/dist/handlers/stop-instance.js +11 -5
- package/dist/handlers/stop-instance.js.map +1 -1
- package/dist/handlers/stop-instance.test.js +14 -30
- package/dist/handlers/stop-instance.test.js.map +1 -1
- package/dist/handlers/testing/mock-helpers.d.ts +56 -0
- package/dist/handlers/testing/mock-helpers.d.ts.map +1 -0
- package/dist/handlers/testing/mock-helpers.js +95 -0
- package/dist/handlers/testing/mock-helpers.js.map +1 -0
- package/dist/program.d.ts.map +1 -1
- package/dist/program.js +284 -8
- package/dist/program.js.map +1 -1
- package/dist/program.test.js +74 -12
- package/dist/program.test.js.map +1 -1
- package/package.json +9 -5
- package/dist/handlers/visit-and-extract.d.ts +0 -5
- package/dist/handlers/visit-and-extract.d.ts.map +0 -1
- package/dist/handlers/visit-and-extract.js +0 -105
- package/dist/handlers/visit-and-extract.js.map +0 -1
- package/dist/handlers/visit-and-extract.test.d.ts +0 -2
- package/dist/handlers/visit-and-extract.test.d.ts.map +0 -1
- package/dist/handlers/visit-and-extract.test.js +0 -279
- package/dist/handlers/visit-and-extract.test.js.map +0 -1
package/README.md
CHANGED
|
@@ -2,16 +2,72 @@
|
|
|
2
2
|
|
|
3
3
|
CLI for [lhremote](https://github.com/alexey-pelykh/lhremote) — LinkedHelper automation toolkit.
|
|
4
4
|
|
|
5
|
+
This package provides a command-line interface that mirrors the full MCP tool surface. Every MCP tool has a corresponding CLI command.
|
|
6
|
+
|
|
7
|
+
Built on [`@lhremote/core`](../core).
|
|
8
|
+
|
|
5
9
|
## Installation
|
|
6
10
|
|
|
11
|
+
End users should install the [`lhremote`](https://www.npmjs.com/package/lhremote) meta-package, which includes both the CLI and MCP server:
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
npm install -g lhremote
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
This provides the `lhremote` binary. See the [root README](https://github.com/alexey-pelykh/lhremote#installation) for full details.
|
|
18
|
+
|
|
19
|
+
Installing `@lhremote/cli` directly is possible but provides the `lhremote-cli` binary instead:
|
|
20
|
+
|
|
7
21
|
```bash
|
|
8
|
-
npm install -g @lhremote/cli
|
|
22
|
+
npm install -g @lhremote/cli # binary: lhremote-cli
|
|
9
23
|
```
|
|
10
24
|
|
|
11
25
|
## Usage
|
|
12
26
|
|
|
13
27
|
```bash
|
|
14
|
-
|
|
28
|
+
# Detect running LinkedHelper
|
|
29
|
+
lhremote find-app --json
|
|
30
|
+
|
|
31
|
+
# List accounts and start an instance
|
|
32
|
+
lhremote list-accounts --cdp-port 9222
|
|
33
|
+
lhremote start-instance 1
|
|
34
|
+
|
|
35
|
+
# Create and run a campaign
|
|
36
|
+
lhremote campaign-create --file campaign.yaml
|
|
37
|
+
lhremote import-people-from-urls 42 --urls-file targets.txt
|
|
38
|
+
lhremote campaign-start 42 --person-ids 100,101,102
|
|
39
|
+
|
|
40
|
+
# Monitor progress
|
|
41
|
+
lhremote campaign-status 42 --include-results
|
|
42
|
+
lhremote campaign-statistics 42
|
|
43
|
+
|
|
44
|
+
# Query results
|
|
45
|
+
lhremote query-messages --person-id 100 --json
|
|
46
|
+
lhremote check-replies --since 2025-01-01T00:00:00Z
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
## Commands
|
|
50
|
+
|
|
51
|
+
| Category | Commands |
|
|
52
|
+
|----------|----------|
|
|
53
|
+
| App Management | `find-app`, `launch-app`, `quit-app` |
|
|
54
|
+
| Account & Instance | `list-accounts`, `start-instance`, `stop-instance`, `check-status` |
|
|
55
|
+
| Campaigns | `campaign-list`, `campaign-create`, `campaign-get`, `campaign-export`, `campaign-update`, `campaign-delete`, `campaign-start`, `campaign-stop` |
|
|
56
|
+
| Campaign Status | `campaign-status`, `campaign-statistics`, `campaign-retry` |
|
|
57
|
+
| Campaign Actions | `campaign-add-action`, `campaign-remove-action`, `campaign-reorder-actions`, `campaign-move-next` |
|
|
58
|
+
| Campaign Targeting | `campaign-exclude-list`, `campaign-exclude-add`, `campaign-exclude-remove`, `import-people-from-urls` |
|
|
59
|
+
| Profiles & Messaging | `query-profile`, `query-profiles`, `query-messages`, `check-replies`, `scrape-messaging-history` |
|
|
60
|
+
| Utilities | `describe-actions` |
|
|
61
|
+
|
|
62
|
+
See the [root README](https://github.com/alexey-pelykh/lhremote#cli-usage) for full command-line usage.
|
|
63
|
+
|
|
64
|
+
## Programmatic Usage
|
|
65
|
+
|
|
66
|
+
```typescript
|
|
67
|
+
import { createProgram } from "@lhremote/cli";
|
|
68
|
+
|
|
69
|
+
const program = createProgram();
|
|
70
|
+
await program.parseAsync(process.argv);
|
|
15
71
|
```
|
|
16
72
|
|
|
17
73
|
## License
|
package/dist/cli.js
CHANGED
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AACA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAE7C,aAAa,EAAE,CAAC,KAAK,EAAE,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaign-actions | campaign-add-action} CLI command. */
|
|
2
|
+
export declare function handleCampaignAddAction(campaignId: number, options: {
|
|
3
|
+
name: string;
|
|
4
|
+
actionType: string;
|
|
5
|
+
description?: string;
|
|
6
|
+
coolDown?: number;
|
|
7
|
+
maxResults?: number;
|
|
8
|
+
actionSettings?: string;
|
|
9
|
+
cdpPort?: number;
|
|
10
|
+
cdpHost?: string;
|
|
11
|
+
allowRemote?: boolean;
|
|
12
|
+
json?: boolean;
|
|
13
|
+
}): Promise<void>;
|
|
14
|
+
//# sourceMappingURL=campaign-add-action.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-add-action.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-add-action.ts"],"names":[],"mappings":"AAWA,uHAAuH;AACvH,wBAAsB,uBAAuB,CAC3C,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE;IACP,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,GACA,OAAO,CAAC,IAAI,CAAC,CAgDf"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { CampaignNotFoundError, DEFAULT_CDP_PORT, errorMessage, campaignAddAction, } from "@lhremote/core";
|
|
4
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaign-actions | campaign-add-action} CLI command. */
|
|
5
|
+
export async function handleCampaignAddAction(campaignId, options) {
|
|
6
|
+
// Parse action settings JSON if provided
|
|
7
|
+
let parsedSettings = {};
|
|
8
|
+
if (options.actionSettings !== undefined) {
|
|
9
|
+
try {
|
|
10
|
+
parsedSettings = JSON.parse(options.actionSettings);
|
|
11
|
+
}
|
|
12
|
+
catch {
|
|
13
|
+
process.stderr.write("Invalid JSON in --action-settings.\n");
|
|
14
|
+
process.exitCode = 1;
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
let result;
|
|
19
|
+
try {
|
|
20
|
+
result = await campaignAddAction({
|
|
21
|
+
campaignId,
|
|
22
|
+
name: options.name,
|
|
23
|
+
actionType: options.actionType,
|
|
24
|
+
description: options.description,
|
|
25
|
+
coolDown: options.coolDown,
|
|
26
|
+
maxActionResultsPerIteration: options.maxResults,
|
|
27
|
+
actionSettings: parsedSettings,
|
|
28
|
+
cdpPort: options.cdpPort ?? DEFAULT_CDP_PORT,
|
|
29
|
+
cdpHost: options.cdpHost,
|
|
30
|
+
allowRemote: options.allowRemote,
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
catch (error) {
|
|
34
|
+
if (error instanceof CampaignNotFoundError) {
|
|
35
|
+
process.stderr.write(`Campaign ${String(campaignId)} not found.\n`);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
const message = errorMessage(error);
|
|
39
|
+
process.stderr.write(`${message}\n`);
|
|
40
|
+
}
|
|
41
|
+
process.exitCode = 1;
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
if (options.json) {
|
|
45
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
process.stdout.write(`Action added: #${result.id} "${result.name}" (${result.config.actionType}) to campaign #${String(campaignId)}\n`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=campaign-add-action.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-add-action.js","sourceRoot":"","sources":["../../src/handlers/campaign-add-action.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,qBAAqB,EACrB,gBAAgB,EAChB,YAAY,EACZ,iBAAiB,GAElB,MAAM,gBAAgB,CAAC;AAExB,uHAAuH;AACvH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAC3C,UAAkB,EAClB,OAWC;IAED,yCAAyC;IACzC,IAAI,cAAc,GAA4B,EAAE,CAAC;IACjD,IAAI,OAAO,CAAC,cAAc,KAAK,SAAS,EAAE,CAAC;QACzC,IAAI,CAAC;YACH,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,cAAc,CAGjD,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC7D,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;YACrB,OAAO;QACT,CAAC;IACH,CAAC;IAED,IAAI,MAA+B,CAAC;IACpC,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,iBAAiB,CAAC;YAC/B,UAAU;YACV,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,UAAU,EAAE,OAAO,CAAC,UAAU;YAC9B,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,4BAA4B,EAAE,OAAO,CAAC,UAAU;YAChD,cAAc,EAAE,cAAc;YAC9B,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,gBAAgB;YAC5C,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,KAAK,YAAY,qBAAqB,EAAE,CAAC;YAC3C,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,MAAM,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;QACtE,CAAC;aAAM,CAAC;YACN,MAAM,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;YACpC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,IAAI,CAAC,CAAC;QACvC,CAAC;QACD,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;IAC/D,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,kBAAkB,MAAM,CAAC,EAAE,KAAK,MAAM,CAAC,IAAI,MAAM,MAAM,CAAC,MAAM,CAAC,UAAU,kBAAkB,MAAM,CAAC,UAAU,CAAC,IAAI,CAClH,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-add-action.test.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-add-action.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
4
|
+
vi.mock("@lhremote/core", async (importOriginal) => {
|
|
5
|
+
const actual = await importOriginal();
|
|
6
|
+
return {
|
|
7
|
+
...actual,
|
|
8
|
+
campaignAddAction: vi.fn(),
|
|
9
|
+
};
|
|
10
|
+
});
|
|
11
|
+
import { CampaignNotFoundError, campaignAddAction, } from "@lhremote/core";
|
|
12
|
+
import { handleCampaignAddAction } from "./campaign-add-action.js";
|
|
13
|
+
import { getStdout } from "./testing/mock-helpers.js";
|
|
14
|
+
const MOCK_RESULT = {
|
|
15
|
+
id: 10,
|
|
16
|
+
campaignId: 1,
|
|
17
|
+
name: "Visit",
|
|
18
|
+
description: null,
|
|
19
|
+
config: {
|
|
20
|
+
id: 100,
|
|
21
|
+
actionType: "VisitAndExtract",
|
|
22
|
+
actionSettings: {},
|
|
23
|
+
coolDown: 60000,
|
|
24
|
+
maxActionResultsPerIteration: 10,
|
|
25
|
+
isDraft: false,
|
|
26
|
+
},
|
|
27
|
+
versionId: 1,
|
|
28
|
+
};
|
|
29
|
+
describe("handleCampaignAddAction", () => {
|
|
30
|
+
const originalExitCode = process.exitCode;
|
|
31
|
+
let stdoutSpy;
|
|
32
|
+
let stderrSpy;
|
|
33
|
+
beforeEach(() => {
|
|
34
|
+
process.exitCode = undefined;
|
|
35
|
+
vi.clearAllMocks();
|
|
36
|
+
stdoutSpy = vi.spyOn(process.stdout, "write").mockReturnValue(true);
|
|
37
|
+
stderrSpy = vi.spyOn(process.stderr, "write").mockReturnValue(true);
|
|
38
|
+
});
|
|
39
|
+
afterEach(() => {
|
|
40
|
+
process.exitCode = originalExitCode;
|
|
41
|
+
vi.restoreAllMocks();
|
|
42
|
+
});
|
|
43
|
+
it("adds action and prints confirmation", async () => {
|
|
44
|
+
vi.mocked(campaignAddAction).mockResolvedValue(MOCK_RESULT);
|
|
45
|
+
await handleCampaignAddAction(1, {
|
|
46
|
+
name: "Visit",
|
|
47
|
+
actionType: "VisitAndExtract",
|
|
48
|
+
});
|
|
49
|
+
expect(process.exitCode).toBeUndefined();
|
|
50
|
+
expect(getStdout(stdoutSpy)).toContain('Action added: #10 "Visit" (VisitAndExtract) to campaign #1');
|
|
51
|
+
});
|
|
52
|
+
it("prints JSON with --json", async () => {
|
|
53
|
+
vi.mocked(campaignAddAction).mockResolvedValue(MOCK_RESULT);
|
|
54
|
+
await handleCampaignAddAction(1, {
|
|
55
|
+
name: "Visit",
|
|
56
|
+
actionType: "VisitAndExtract",
|
|
57
|
+
json: true,
|
|
58
|
+
});
|
|
59
|
+
expect(process.exitCode).toBeUndefined();
|
|
60
|
+
const parsed = JSON.parse(getStdout(stdoutSpy));
|
|
61
|
+
expect(parsed.id).toBe(10);
|
|
62
|
+
expect(parsed.name).toBe("Visit");
|
|
63
|
+
});
|
|
64
|
+
it("passes optional parameters to operation", async () => {
|
|
65
|
+
vi.mocked(campaignAddAction).mockResolvedValue(MOCK_RESULT);
|
|
66
|
+
await handleCampaignAddAction(1, {
|
|
67
|
+
name: "Visit",
|
|
68
|
+
actionType: "VisitAndExtract",
|
|
69
|
+
description: "Visit and extract data",
|
|
70
|
+
coolDown: 30,
|
|
71
|
+
maxResults: 100,
|
|
72
|
+
});
|
|
73
|
+
expect(campaignAddAction).toHaveBeenCalledWith(expect.objectContaining({
|
|
74
|
+
campaignId: 1,
|
|
75
|
+
name: "Visit",
|
|
76
|
+
actionType: "VisitAndExtract",
|
|
77
|
+
description: "Visit and extract data",
|
|
78
|
+
coolDown: 30,
|
|
79
|
+
maxActionResultsPerIteration: 100,
|
|
80
|
+
}));
|
|
81
|
+
});
|
|
82
|
+
it("parses action settings JSON", async () => {
|
|
83
|
+
vi.mocked(campaignAddAction).mockResolvedValue(MOCK_RESULT);
|
|
84
|
+
await handleCampaignAddAction(1, {
|
|
85
|
+
name: "Visit",
|
|
86
|
+
actionType: "VisitAndExtract",
|
|
87
|
+
actionSettings: '{"extractEmails":true}',
|
|
88
|
+
});
|
|
89
|
+
expect(campaignAddAction).toHaveBeenCalledWith(expect.objectContaining({
|
|
90
|
+
actionSettings: { extractEmails: true },
|
|
91
|
+
}));
|
|
92
|
+
});
|
|
93
|
+
it("sets exitCode 1 on invalid action settings JSON", async () => {
|
|
94
|
+
await handleCampaignAddAction(1, {
|
|
95
|
+
name: "Visit",
|
|
96
|
+
actionType: "VisitAndExtract",
|
|
97
|
+
actionSettings: "bad json",
|
|
98
|
+
});
|
|
99
|
+
expect(process.exitCode).toBe(1);
|
|
100
|
+
expect(stderrSpy).toHaveBeenCalledWith("Invalid JSON in --action-settings.\n");
|
|
101
|
+
});
|
|
102
|
+
it("sets exitCode 1 when campaign not found", async () => {
|
|
103
|
+
vi.mocked(campaignAddAction).mockRejectedValue(new CampaignNotFoundError(999));
|
|
104
|
+
await handleCampaignAddAction(999, {
|
|
105
|
+
name: "Visit",
|
|
106
|
+
actionType: "VisitAndExtract",
|
|
107
|
+
});
|
|
108
|
+
expect(process.exitCode).toBe(1);
|
|
109
|
+
expect(stderrSpy).toHaveBeenCalledWith("Campaign 999 not found.\n");
|
|
110
|
+
});
|
|
111
|
+
it("sets exitCode 1 when resolveAccount fails", async () => {
|
|
112
|
+
vi.mocked(campaignAddAction).mockRejectedValue(new Error("timeout"));
|
|
113
|
+
await handleCampaignAddAction(1, {
|
|
114
|
+
name: "Visit",
|
|
115
|
+
actionType: "VisitAndExtract",
|
|
116
|
+
});
|
|
117
|
+
expect(process.exitCode).toBe(1);
|
|
118
|
+
expect(stderrSpy).toHaveBeenCalledWith("timeout\n");
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
//# sourceMappingURL=campaign-add-action.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-add-action.test.js","sourceRoot":"","sources":["../../src/handlers/campaign-add-action.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaigns | campaign-create} CLI command. */
|
|
2
|
+
export declare function handleCampaignCreate(options: {
|
|
3
|
+
file?: string;
|
|
4
|
+
yaml?: string;
|
|
5
|
+
jsonInput?: string;
|
|
6
|
+
cdpPort?: number;
|
|
7
|
+
cdpHost?: string;
|
|
8
|
+
allowRemote?: boolean;
|
|
9
|
+
json?: boolean;
|
|
10
|
+
}): Promise<void>;
|
|
11
|
+
//# sourceMappingURL=campaign-create.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-create.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-create.ts"],"names":[],"mappings":"AAkBA,4GAA4G;AAC5G,wBAAsB,oBAAoB,CAAC,OAAO,EAAE;IAClD,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,GAAG,OAAO,CAAC,IAAI,CAAC,CA+EhB"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { readFileSync } from "node:fs";
|
|
4
|
+
import { CampaignExecutionError, CampaignFormatError, DEFAULT_CDP_PORT, errorMessage, InstanceNotRunningError, parseCampaignJson, parseCampaignYaml, campaignCreate, } from "@lhremote/core";
|
|
5
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaigns | campaign-create} CLI command. */
|
|
6
|
+
export async function handleCampaignCreate(options) {
|
|
7
|
+
// Validate input options
|
|
8
|
+
const inputCount = [options.file, options.yaml, options.jsonInput].filter(Boolean).length;
|
|
9
|
+
if (inputCount === 0) {
|
|
10
|
+
process.stderr.write("One of --file, --yaml, or --json-input is required.\n");
|
|
11
|
+
process.exitCode = 1;
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
if (inputCount > 1) {
|
|
15
|
+
process.stderr.write("Use only one of --file, --yaml, or --json-input.\n");
|
|
16
|
+
process.exitCode = 1;
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
// Read and parse config
|
|
20
|
+
let config;
|
|
21
|
+
try {
|
|
22
|
+
if (options.file) {
|
|
23
|
+
const content = readFileSync(options.file, "utf-8");
|
|
24
|
+
// Detect format from extension
|
|
25
|
+
const isJson = options.file.endsWith(".json");
|
|
26
|
+
config = isJson
|
|
27
|
+
? parseCampaignJson(content)
|
|
28
|
+
: parseCampaignYaml(content);
|
|
29
|
+
}
|
|
30
|
+
else if (options.jsonInput) {
|
|
31
|
+
config = parseCampaignJson(options.jsonInput);
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
// options.yaml is guaranteed to be set by inputCount validation
|
|
35
|
+
config = parseCampaignYaml(options.yaml);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
catch (error) {
|
|
39
|
+
if (error instanceof CampaignFormatError) {
|
|
40
|
+
process.stderr.write(`Invalid campaign configuration: ${error.message}\n`);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
const message = errorMessage(error);
|
|
44
|
+
process.stderr.write(`Failed to parse campaign configuration: ${message}\n`);
|
|
45
|
+
}
|
|
46
|
+
process.exitCode = 1;
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
let result;
|
|
50
|
+
try {
|
|
51
|
+
result = await campaignCreate({
|
|
52
|
+
config,
|
|
53
|
+
cdpPort: options.cdpPort ?? DEFAULT_CDP_PORT,
|
|
54
|
+
cdpHost: options.cdpHost,
|
|
55
|
+
allowRemote: options.allowRemote,
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
catch (error) {
|
|
59
|
+
if (error instanceof CampaignExecutionError) {
|
|
60
|
+
process.stderr.write(`Failed to create campaign: ${error.message}\n`);
|
|
61
|
+
}
|
|
62
|
+
else if (error instanceof InstanceNotRunningError) {
|
|
63
|
+
process.stderr.write(`${error.message}\n`);
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
const message = errorMessage(error);
|
|
67
|
+
process.stderr.write(`${message}\n`);
|
|
68
|
+
}
|
|
69
|
+
process.exitCode = 1;
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
if (options.json) {
|
|
73
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
process.stdout.write(`Campaign created: #${result.id} "${result.name}"\n`);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=campaign-create.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-create.js","sourceRoot":"","sources":["../../src/handlers/campaign-create.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-create.test.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-create.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
4
|
+
vi.mock("@lhremote/core", async (importOriginal) => {
|
|
5
|
+
const actual = await importOriginal();
|
|
6
|
+
return {
|
|
7
|
+
...actual,
|
|
8
|
+
campaignCreate: vi.fn(),
|
|
9
|
+
parseCampaignJson: vi.fn(),
|
|
10
|
+
parseCampaignYaml: vi.fn(),
|
|
11
|
+
};
|
|
12
|
+
});
|
|
13
|
+
vi.mock("node:fs", async (importOriginal) => {
|
|
14
|
+
const actual = await importOriginal();
|
|
15
|
+
return {
|
|
16
|
+
...actual,
|
|
17
|
+
readFileSync: vi.fn(),
|
|
18
|
+
};
|
|
19
|
+
});
|
|
20
|
+
import { CampaignExecutionError, CampaignFormatError, InstanceNotRunningError, campaignCreate, parseCampaignJson, parseCampaignYaml, } from "@lhremote/core";
|
|
21
|
+
import { readFileSync } from "node:fs";
|
|
22
|
+
import { handleCampaignCreate } from "./campaign-create.js";
|
|
23
|
+
import { getStdout } from "./testing/mock-helpers.js";
|
|
24
|
+
const MOCK_CONFIG = { name: "Test Campaign", actions: [] };
|
|
25
|
+
const MOCK_RESULT = {
|
|
26
|
+
id: 1,
|
|
27
|
+
name: "Test Campaign",
|
|
28
|
+
description: null,
|
|
29
|
+
state: "active",
|
|
30
|
+
liAccountId: 1,
|
|
31
|
+
isPaused: false,
|
|
32
|
+
isArchived: false,
|
|
33
|
+
isValid: true,
|
|
34
|
+
createdAt: "2025-01-01T00:00:00Z",
|
|
35
|
+
};
|
|
36
|
+
describe("handleCampaignCreate", () => {
|
|
37
|
+
const originalExitCode = process.exitCode;
|
|
38
|
+
let stdoutSpy;
|
|
39
|
+
let stderrSpy;
|
|
40
|
+
beforeEach(() => {
|
|
41
|
+
process.exitCode = undefined;
|
|
42
|
+
vi.clearAllMocks();
|
|
43
|
+
stdoutSpy = vi.spyOn(process.stdout, "write").mockReturnValue(true);
|
|
44
|
+
stderrSpy = vi.spyOn(process.stderr, "write").mockReturnValue(true);
|
|
45
|
+
});
|
|
46
|
+
afterEach(() => {
|
|
47
|
+
process.exitCode = originalExitCode;
|
|
48
|
+
vi.restoreAllMocks();
|
|
49
|
+
});
|
|
50
|
+
it("creates campaign from --json-input and prints result", async () => {
|
|
51
|
+
vi.mocked(parseCampaignJson).mockReturnValue(MOCK_CONFIG);
|
|
52
|
+
vi.mocked(campaignCreate).mockResolvedValue(MOCK_RESULT);
|
|
53
|
+
await handleCampaignCreate({ jsonInput: '{"name":"Test"}' });
|
|
54
|
+
expect(process.exitCode).toBeUndefined();
|
|
55
|
+
expect(getStdout(stdoutSpy)).toContain('Campaign created: #1 "Test Campaign"');
|
|
56
|
+
expect(parseCampaignJson).toHaveBeenCalledWith('{"name":"Test"}');
|
|
57
|
+
});
|
|
58
|
+
it("creates campaign from --yaml", async () => {
|
|
59
|
+
vi.mocked(parseCampaignYaml).mockReturnValue(MOCK_CONFIG);
|
|
60
|
+
vi.mocked(campaignCreate).mockResolvedValue(MOCK_RESULT);
|
|
61
|
+
await handleCampaignCreate({ yaml: "name: Test" });
|
|
62
|
+
expect(process.exitCode).toBeUndefined();
|
|
63
|
+
expect(parseCampaignYaml).toHaveBeenCalledWith("name: Test");
|
|
64
|
+
});
|
|
65
|
+
it("creates campaign from --file with JSON extension", async () => {
|
|
66
|
+
vi.mocked(readFileSync).mockReturnValue('{"name":"Test"}');
|
|
67
|
+
vi.mocked(parseCampaignJson).mockReturnValue(MOCK_CONFIG);
|
|
68
|
+
vi.mocked(campaignCreate).mockResolvedValue(MOCK_RESULT);
|
|
69
|
+
await handleCampaignCreate({ file: "campaign.json" });
|
|
70
|
+
expect(process.exitCode).toBeUndefined();
|
|
71
|
+
expect(readFileSync).toHaveBeenCalledWith("campaign.json", "utf-8");
|
|
72
|
+
expect(parseCampaignJson).toHaveBeenCalled();
|
|
73
|
+
});
|
|
74
|
+
it("creates campaign from --file with YAML extension", async () => {
|
|
75
|
+
vi.mocked(readFileSync).mockReturnValue("name: Test");
|
|
76
|
+
vi.mocked(parseCampaignYaml).mockReturnValue(MOCK_CONFIG);
|
|
77
|
+
vi.mocked(campaignCreate).mockResolvedValue(MOCK_RESULT);
|
|
78
|
+
await handleCampaignCreate({ file: "campaign.yaml" });
|
|
79
|
+
expect(process.exitCode).toBeUndefined();
|
|
80
|
+
expect(parseCampaignYaml).toHaveBeenCalled();
|
|
81
|
+
});
|
|
82
|
+
it("prints JSON with --json", async () => {
|
|
83
|
+
vi.mocked(parseCampaignJson).mockReturnValue(MOCK_CONFIG);
|
|
84
|
+
vi.mocked(campaignCreate).mockResolvedValue(MOCK_RESULT);
|
|
85
|
+
await handleCampaignCreate({ jsonInput: '{"name":"Test"}', json: true });
|
|
86
|
+
expect(process.exitCode).toBeUndefined();
|
|
87
|
+
const parsed = JSON.parse(getStdout(stdoutSpy));
|
|
88
|
+
expect(parsed.id).toBe(1);
|
|
89
|
+
expect(parsed.name).toBe("Test Campaign");
|
|
90
|
+
});
|
|
91
|
+
it("sets exitCode 1 when no input option provided", async () => {
|
|
92
|
+
await handleCampaignCreate({});
|
|
93
|
+
expect(process.exitCode).toBe(1);
|
|
94
|
+
expect(stderrSpy).toHaveBeenCalledWith("One of --file, --yaml, or --json-input is required.\n");
|
|
95
|
+
});
|
|
96
|
+
it("sets exitCode 1 when multiple input options provided", async () => {
|
|
97
|
+
await handleCampaignCreate({ yaml: "x", jsonInput: "y" });
|
|
98
|
+
expect(process.exitCode).toBe(1);
|
|
99
|
+
expect(stderrSpy).toHaveBeenCalledWith("Use only one of --file, --yaml, or --json-input.\n");
|
|
100
|
+
});
|
|
101
|
+
it("sets exitCode 1 on CampaignFormatError", async () => {
|
|
102
|
+
vi.mocked(parseCampaignJson).mockImplementation(() => {
|
|
103
|
+
throw new CampaignFormatError("missing name");
|
|
104
|
+
});
|
|
105
|
+
await handleCampaignCreate({ jsonInput: "{}" });
|
|
106
|
+
expect(process.exitCode).toBe(1);
|
|
107
|
+
expect(stderrSpy).toHaveBeenCalledWith("Invalid campaign configuration: missing name\n");
|
|
108
|
+
});
|
|
109
|
+
it("sets exitCode 1 on parse error", async () => {
|
|
110
|
+
vi.mocked(parseCampaignJson).mockImplementation(() => {
|
|
111
|
+
throw new SyntaxError("Unexpected token");
|
|
112
|
+
});
|
|
113
|
+
await handleCampaignCreate({ jsonInput: "bad" });
|
|
114
|
+
expect(process.exitCode).toBe(1);
|
|
115
|
+
expect(stderrSpy).toHaveBeenCalledWith(expect.stringContaining("Failed to parse campaign configuration"));
|
|
116
|
+
});
|
|
117
|
+
it("sets exitCode 1 when resolveAccount fails", async () => {
|
|
118
|
+
vi.mocked(parseCampaignJson).mockReturnValue(MOCK_CONFIG);
|
|
119
|
+
vi.mocked(campaignCreate).mockRejectedValue(new Error("No accounts found."));
|
|
120
|
+
await handleCampaignCreate({ jsonInput: '{"name":"Test"}' });
|
|
121
|
+
expect(process.exitCode).toBe(1);
|
|
122
|
+
expect(stderrSpy).toHaveBeenCalledWith("No accounts found.\n");
|
|
123
|
+
});
|
|
124
|
+
it("sets exitCode 1 on CampaignExecutionError", async () => {
|
|
125
|
+
vi.mocked(parseCampaignJson).mockReturnValue(MOCK_CONFIG);
|
|
126
|
+
vi.mocked(campaignCreate).mockRejectedValue(new CampaignExecutionError("duplicate name"));
|
|
127
|
+
await handleCampaignCreate({ jsonInput: '{"name":"Test"}' });
|
|
128
|
+
expect(process.exitCode).toBe(1);
|
|
129
|
+
expect(stderrSpy).toHaveBeenCalledWith("Failed to create campaign: duplicate name\n");
|
|
130
|
+
});
|
|
131
|
+
it("sets exitCode 1 on InstanceNotRunningError", async () => {
|
|
132
|
+
vi.mocked(parseCampaignJson).mockReturnValue(MOCK_CONFIG);
|
|
133
|
+
vi.mocked(campaignCreate).mockRejectedValue(new InstanceNotRunningError("No LinkedHelper instance is running."));
|
|
134
|
+
await handleCampaignCreate({ jsonInput: '{"name":"Test"}' });
|
|
135
|
+
expect(process.exitCode).toBe(1);
|
|
136
|
+
expect(stderrSpy).toHaveBeenCalledWith("No LinkedHelper instance is running.\n");
|
|
137
|
+
});
|
|
138
|
+
});
|
|
139
|
+
//# sourceMappingURL=campaign-create.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-create.test.js","sourceRoot":"","sources":["../../src/handlers/campaign-create.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaigns | campaign-delete} CLI command. */
|
|
2
|
+
export declare function handleCampaignDelete(campaignId: number, options: {
|
|
3
|
+
cdpPort?: number;
|
|
4
|
+
cdpHost?: string;
|
|
5
|
+
allowRemote?: boolean;
|
|
6
|
+
json?: boolean;
|
|
7
|
+
}): Promise<void>;
|
|
8
|
+
//# sourceMappingURL=campaign-delete.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-delete.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-delete.ts"],"names":[],"mappings":"AAaA,4GAA4G;AAC5G,wBAAsB,oBAAoB,CACxC,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE;IACP,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,GACA,OAAO,CAAC,IAAI,CAAC,CA+Bf"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { CampaignExecutionError, CampaignNotFoundError, DEFAULT_CDP_PORT, errorMessage, InstanceNotRunningError, campaignDelete, } from "@lhremote/core";
|
|
4
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaigns | campaign-delete} CLI command. */
|
|
5
|
+
export async function handleCampaignDelete(campaignId, options) {
|
|
6
|
+
let result;
|
|
7
|
+
try {
|
|
8
|
+
result = await campaignDelete({
|
|
9
|
+
campaignId,
|
|
10
|
+
cdpPort: options.cdpPort ?? DEFAULT_CDP_PORT,
|
|
11
|
+
cdpHost: options.cdpHost,
|
|
12
|
+
allowRemote: options.allowRemote,
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
catch (error) {
|
|
16
|
+
if (error instanceof CampaignNotFoundError) {
|
|
17
|
+
process.stderr.write(`Campaign ${String(campaignId)} not found.\n`);
|
|
18
|
+
}
|
|
19
|
+
else if (error instanceof CampaignExecutionError) {
|
|
20
|
+
process.stderr.write(`Failed to delete campaign: ${error.message}\n`);
|
|
21
|
+
}
|
|
22
|
+
else if (error instanceof InstanceNotRunningError) {
|
|
23
|
+
process.stderr.write(`${error.message}\n`);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
const message = errorMessage(error);
|
|
27
|
+
process.stderr.write(`${message}\n`);
|
|
28
|
+
}
|
|
29
|
+
process.exitCode = 1;
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
if (options.json) {
|
|
33
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
process.stdout.write(`Campaign ${String(campaignId)} archived.\n`);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=campaign-delete.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-delete.js","sourceRoot":"","sources":["../../src/handlers/campaign-delete.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,sBAAsB,EACtB,qBAAqB,EACrB,gBAAgB,EAChB,YAAY,EACZ,uBAAuB,EACvB,cAAc,GAEf,MAAM,gBAAgB,CAAC;AAExB,4GAA4G;AAC5G,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,UAAkB,EAClB,OAKC;IAED,IAAI,MAA4B,CAAC;IACjC,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,cAAc,CAAC;YAC5B,UAAU;YACV,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,gBAAgB;YAC5C,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,KAAK,YAAY,qBAAqB,EAAE,CAAC;YAC3C,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,MAAM,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;QACtE,CAAC;aAAM,IAAI,KAAK,YAAY,sBAAsB,EAAE,CAAC;YACnD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,8BAA8B,KAAK,CAAC,OAAO,IAAI,CAAC,CAAC;QACxE,CAAC;aAAM,IAAI,KAAK,YAAY,uBAAuB,EAAE,CAAC;YACpD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,OAAO,IAAI,CAAC,CAAC;QAC7C,CAAC;aAAM,CAAC;YACN,MAAM,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;YACpC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,IAAI,CAAC,CAAC;QACvC,CAAC;QACD,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;IAC/D,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,YAAY,MAAM,CAAC,UAAU,CAAC,cAAc,CAC7C,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-delete.test.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-delete.test.ts"],"names":[],"mappings":""}
|