@lhremote/cli 0.0.0 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +661 -0
- package/README.md +58 -2
- package/dist/cli.js +4 -2
- 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 +8 -0
- package/dist/handlers/check-status.d.ts.map +1 -0
- package/dist/handlers/check-status.js +50 -0
- package/dist/handlers/check-status.js.map +1 -0
- package/dist/handlers/check-status.test.d.ts +2 -0
- package/dist/handlers/check-status.test.d.ts.map +1 -0
- package/dist/handlers/check-status.test.js +112 -0
- package/dist/handlers/check-status.test.js.map +1 -0
- 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 +33 -0
- package/dist/handlers/index.d.ts.map +1 -0
- package/dist/handlers/index.js +35 -0
- package/dist/handlers/index.js.map +1 -0
- package/dist/handlers/launch-app.d.ts +3 -0
- package/dist/handlers/launch-app.d.ts.map +1 -0
- package/dist/handlers/launch-app.js +18 -0
- package/dist/handlers/launch-app.js.map +1 -0
- package/dist/handlers/launch-app.test.d.ts +2 -0
- package/dist/handlers/launch-app.test.d.ts.map +1 -0
- package/dist/handlers/launch-app.test.js +64 -0
- package/dist/handlers/launch-app.test.js.map +1 -0
- package/dist/handlers/list-accounts.d.ts +8 -0
- package/dist/handlers/list-accounts.d.ts.map +1 -0
- package/dist/handlers/list-accounts.js +43 -0
- package/dist/handlers/list-accounts.js.map +1 -0
- package/dist/handlers/list-accounts.test.d.ts +2 -0
- package/dist/handlers/list-accounts.test.d.ts.map +1 -0
- package/dist/handlers/list-accounts.test.js +87 -0
- package/dist/handlers/list-accounts.test.js.map +1 -0
- 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 +3 -0
- package/dist/handlers/quit-app.d.ts.map +1 -0
- package/dist/handlers/quit-app.js +18 -0
- package/dist/handlers/quit-app.js.map +1 -0
- package/dist/handlers/quit-app.test.d.ts +2 -0
- package/dist/handlers/quit-app.test.d.ts.map +1 -0
- package/dist/handlers/quit-app.test.js +60 -0
- package/dist/handlers/quit-app.test.js.map +1 -0
- 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 +7 -0
- package/dist/handlers/start-instance.d.ts.map +1 -0
- package/dist/handlers/start-instance.js +42 -0
- package/dist/handlers/start-instance.js.map +1 -0
- package/dist/handlers/start-instance.test.d.ts +2 -0
- package/dist/handlers/start-instance.test.d.ts.map +1 -0
- package/dist/handlers/start-instance.test.js +97 -0
- package/dist/handlers/start-instance.test.js.map +1 -0
- package/dist/handlers/stop-instance.d.ts +7 -0
- package/dist/handlers/stop-instance.d.ts.map +1 -0
- package/dist/handlers/stop-instance.js +34 -0
- package/dist/handlers/stop-instance.js.map +1 -0
- package/dist/handlers/stop-instance.test.d.ts +2 -0
- package/dist/handlers/stop-instance.test.d.ts.map +1 -0
- package/dist/handlers/stop-instance.test.js +66 -0
- package/dist/handlers/stop-instance.test.js.map +1 -0
- 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 +6 -0
- package/dist/program.d.ts.map +1 -0
- package/dist/program.js +341 -0
- package/dist/program.js.map +1 -0
- package/dist/program.test.d.ts +2 -0
- package/dist/program.test.d.ts.map +1 -0
- package/dist/program.test.js +154 -0
- package/dist/program.test.js.map +1 -0
- package/package.json +27 -13
|
@@ -0,0 +1,129 @@
|
|
|
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
|
+
DatabaseClient: vi.fn(),
|
|
9
|
+
CampaignRepository: vi.fn(),
|
|
10
|
+
discoverAllDatabases: vi.fn(),
|
|
11
|
+
};
|
|
12
|
+
});
|
|
13
|
+
import { CampaignRepository } from "@lhremote/core";
|
|
14
|
+
import { handleCampaignList } from "./campaign-list.js";
|
|
15
|
+
import { getStdout, mockDb, mockDiscovery } from "./testing/mock-helpers.js";
|
|
16
|
+
const MOCK_CAMPAIGNS = [
|
|
17
|
+
{
|
|
18
|
+
id: 1,
|
|
19
|
+
name: "Outreach Q1",
|
|
20
|
+
state: "active",
|
|
21
|
+
liAccountId: 42,
|
|
22
|
+
actionCount: 3,
|
|
23
|
+
createdAt: "2025-01-01T00:00:00Z",
|
|
24
|
+
description: "Q1 outreach campaign",
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
id: 2,
|
|
28
|
+
name: "Follow-Up",
|
|
29
|
+
state: "paused",
|
|
30
|
+
liAccountId: 42,
|
|
31
|
+
actionCount: 1,
|
|
32
|
+
createdAt: "2025-01-02T00:00:00Z",
|
|
33
|
+
description: null,
|
|
34
|
+
},
|
|
35
|
+
];
|
|
36
|
+
function mockRepo(campaigns = MOCK_CAMPAIGNS) {
|
|
37
|
+
vi.mocked(CampaignRepository).mockImplementation(function () {
|
|
38
|
+
return {
|
|
39
|
+
listCampaigns: vi.fn().mockReturnValue(campaigns),
|
|
40
|
+
};
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
function setupSuccessPath() {
|
|
44
|
+
mockDiscovery();
|
|
45
|
+
mockDb();
|
|
46
|
+
mockRepo();
|
|
47
|
+
}
|
|
48
|
+
describe("handleCampaignList", () => {
|
|
49
|
+
const originalExitCode = process.exitCode;
|
|
50
|
+
let stdoutSpy;
|
|
51
|
+
let stderrSpy;
|
|
52
|
+
beforeEach(() => {
|
|
53
|
+
process.exitCode = undefined;
|
|
54
|
+
vi.clearAllMocks();
|
|
55
|
+
stdoutSpy = vi.spyOn(process.stdout, "write").mockReturnValue(true);
|
|
56
|
+
stderrSpy = vi.spyOn(process.stderr, "write").mockReturnValue(true);
|
|
57
|
+
});
|
|
58
|
+
afterEach(() => {
|
|
59
|
+
process.exitCode = originalExitCode;
|
|
60
|
+
vi.restoreAllMocks();
|
|
61
|
+
});
|
|
62
|
+
it("prints JSON with --json", async () => {
|
|
63
|
+
setupSuccessPath();
|
|
64
|
+
await handleCampaignList({ json: true });
|
|
65
|
+
expect(process.exitCode).toBeUndefined();
|
|
66
|
+
const parsed = JSON.parse(getStdout(stdoutSpy));
|
|
67
|
+
expect(parsed.campaigns).toHaveLength(2);
|
|
68
|
+
expect(parsed.total).toBe(2);
|
|
69
|
+
});
|
|
70
|
+
it("prints human-readable output", async () => {
|
|
71
|
+
setupSuccessPath();
|
|
72
|
+
await handleCampaignList({});
|
|
73
|
+
expect(process.exitCode).toBeUndefined();
|
|
74
|
+
const output = getStdout(stdoutSpy);
|
|
75
|
+
expect(output).toContain("Campaigns (2 total):");
|
|
76
|
+
expect(output).toContain("#1 Outreach Q1");
|
|
77
|
+
expect(output).toContain("[active]");
|
|
78
|
+
expect(output).toContain("3 actions");
|
|
79
|
+
expect(output).toContain("Q1 outreach campaign");
|
|
80
|
+
expect(output).toContain("#2 Follow-Up");
|
|
81
|
+
expect(output).toContain("[paused]");
|
|
82
|
+
});
|
|
83
|
+
it("prints 'No campaigns found' when empty", async () => {
|
|
84
|
+
mockDiscovery();
|
|
85
|
+
mockDb();
|
|
86
|
+
mockRepo([]);
|
|
87
|
+
await handleCampaignList({});
|
|
88
|
+
expect(process.exitCode).toBeUndefined();
|
|
89
|
+
expect(getStdout(stdoutSpy)).toContain("No campaigns found.");
|
|
90
|
+
});
|
|
91
|
+
it("sets exitCode 1 when no databases found", async () => {
|
|
92
|
+
mockDiscovery(new Map());
|
|
93
|
+
await handleCampaignList({});
|
|
94
|
+
expect(process.exitCode).toBe(1);
|
|
95
|
+
expect(stderrSpy).toHaveBeenCalledWith("No LinkedHelper databases found.\n");
|
|
96
|
+
});
|
|
97
|
+
it("passes includeArchived option to repository", async () => {
|
|
98
|
+
mockDiscovery();
|
|
99
|
+
mockDb();
|
|
100
|
+
const listCampaigns = vi.fn().mockReturnValue([]);
|
|
101
|
+
vi.mocked(CampaignRepository).mockImplementation(function () {
|
|
102
|
+
return { listCampaigns };
|
|
103
|
+
});
|
|
104
|
+
await handleCampaignList({ includeArchived: true });
|
|
105
|
+
expect(listCampaigns).toHaveBeenCalledWith({ includeArchived: true });
|
|
106
|
+
});
|
|
107
|
+
it("closes database after listing", async () => {
|
|
108
|
+
mockDiscovery();
|
|
109
|
+
const { close } = mockDb();
|
|
110
|
+
mockRepo();
|
|
111
|
+
await handleCampaignList({});
|
|
112
|
+
expect(close).toHaveBeenCalledOnce();
|
|
113
|
+
});
|
|
114
|
+
it("sets exitCode 1 on database error", async () => {
|
|
115
|
+
mockDiscovery();
|
|
116
|
+
mockDb();
|
|
117
|
+
vi.mocked(CampaignRepository).mockImplementation(function () {
|
|
118
|
+
return {
|
|
119
|
+
listCampaigns: vi.fn().mockImplementation(() => {
|
|
120
|
+
throw new Error("database locked");
|
|
121
|
+
}),
|
|
122
|
+
};
|
|
123
|
+
});
|
|
124
|
+
await handleCampaignList({});
|
|
125
|
+
expect(process.exitCode).toBe(1);
|
|
126
|
+
expect(stderrSpy).toHaveBeenCalledWith(expect.stringContaining("database locked"));
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
//# sourceMappingURL=campaign-list.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-list.test.js","sourceRoot":"","sources":["../../src/handlers/campaign-list.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaign-actions | campaign-move-next} CLI command. */
|
|
2
|
+
export declare function handleCampaignMoveNext(campaignId: number, actionId: number, options: {
|
|
3
|
+
personIds?: string;
|
|
4
|
+
personIdsFile?: string;
|
|
5
|
+
cdpPort?: number;
|
|
6
|
+
cdpHost?: string;
|
|
7
|
+
allowRemote?: boolean;
|
|
8
|
+
json?: boolean;
|
|
9
|
+
}): Promise<void>;
|
|
10
|
+
//# sourceMappingURL=campaign-move-next.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-move-next.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-move-next.ts"],"names":[],"mappings":"AAeA,sHAAsH;AACtH,wBAAsB,sBAAsB,CAC1C,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE;IACP,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,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+Cf"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { ActionNotFoundError, CampaignNotFoundError, DEFAULT_CDP_PORT, errorMessage, NoNextActionError, campaignMoveNext, } from "@lhremote/core";
|
|
4
|
+
import { resolvePersonIds } from "./person-ids.js";
|
|
5
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaign-actions | campaign-move-next} CLI command. */
|
|
6
|
+
export async function handleCampaignMoveNext(campaignId, actionId, options) {
|
|
7
|
+
let personIds;
|
|
8
|
+
try {
|
|
9
|
+
personIds = resolvePersonIds(options);
|
|
10
|
+
}
|
|
11
|
+
catch (error) {
|
|
12
|
+
const message = errorMessage(error);
|
|
13
|
+
process.stderr.write(`${message}\n`);
|
|
14
|
+
process.exitCode = 1;
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
let result;
|
|
18
|
+
try {
|
|
19
|
+
result = await campaignMoveNext({
|
|
20
|
+
campaignId,
|
|
21
|
+
actionId,
|
|
22
|
+
personIds,
|
|
23
|
+
cdpPort: options.cdpPort ?? DEFAULT_CDP_PORT,
|
|
24
|
+
cdpHost: options.cdpHost,
|
|
25
|
+
allowRemote: options.allowRemote,
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
catch (error) {
|
|
29
|
+
if (error instanceof CampaignNotFoundError) {
|
|
30
|
+
process.stderr.write(`Campaign ${String(campaignId)} not found.\n`);
|
|
31
|
+
}
|
|
32
|
+
else if (error instanceof ActionNotFoundError) {
|
|
33
|
+
process.stderr.write(`Action ${String(actionId)} not found in campaign ${String(campaignId)}.\n`);
|
|
34
|
+
}
|
|
35
|
+
else if (error instanceof NoNextActionError) {
|
|
36
|
+
process.stderr.write(`Action ${String(actionId)} is the last action in campaign ${String(campaignId)}.\n`);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
const message = errorMessage(error);
|
|
40
|
+
process.stderr.write(`${message}\n`);
|
|
41
|
+
}
|
|
42
|
+
process.exitCode = 1;
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
if (options.json) {
|
|
46
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
process.stdout.write(`Campaign ${String(campaignId)}: ${String(result.personsMoved)} persons moved from action ${String(actionId)} to action ${String(result.toActionId)}.\n`);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=campaign-move-next.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-move-next.js","sourceRoot":"","sources":["../../src/handlers/campaign-move-next.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,mBAAmB,EACnB,qBAAqB,EACrB,gBAAgB,EAChB,YAAY,EACZ,iBAAiB,EACjB,gBAAgB,GAEjB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAEnD,sHAAsH;AACtH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAC1C,UAAkB,EAClB,QAAgB,EAChB,OAOC;IAED,IAAI,SAAmB,CAAC;IACxB,IAAI,CAAC;QACH,SAAS,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;QACpC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,IAAI,CAAC,CAAC;QACrC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,IAAI,MAA8B,CAAC;IACnC,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,gBAAgB,CAAC;YAC9B,UAAU;YACV,QAAQ;YACR,SAAS;YACT,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,mBAAmB,EAAE,CAAC;YAChD,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,UAAU,MAAM,CAAC,QAAQ,CAAC,0BAA0B,MAAM,CAAC,UAAU,CAAC,KAAK,CAC5E,CAAC;QACJ,CAAC;aAAM,IAAI,KAAK,YAAY,iBAAiB,EAAE,CAAC;YAC9C,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,UAAU,MAAM,CAAC,QAAQ,CAAC,mCAAmC,MAAM,CAAC,UAAU,CAAC,KAAK,CACrF,CAAC;QACJ,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,KAAK,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,8BAA8B,MAAM,CAAC,QAAQ,CAAC,cAAc,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CACzJ,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-move-next.test.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-move-next.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,127 @@
|
|
|
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
|
+
campaignMoveNext: vi.fn(),
|
|
9
|
+
};
|
|
10
|
+
});
|
|
11
|
+
vi.mock("node:fs", async (importOriginal) => {
|
|
12
|
+
const actual = await importOriginal();
|
|
13
|
+
return {
|
|
14
|
+
...actual,
|
|
15
|
+
readFileSync: vi.fn(),
|
|
16
|
+
};
|
|
17
|
+
});
|
|
18
|
+
import { ActionNotFoundError, CampaignNotFoundError, NoNextActionError, campaignMoveNext, } from "@lhremote/core";
|
|
19
|
+
import { readFileSync } from "node:fs";
|
|
20
|
+
import { handleCampaignMoveNext } from "./campaign-move-next.js";
|
|
21
|
+
import { getStdout } from "./testing/mock-helpers.js";
|
|
22
|
+
function mockResult(personsMoved) {
|
|
23
|
+
return {
|
|
24
|
+
success: true,
|
|
25
|
+
campaignId: 1,
|
|
26
|
+
fromActionId: 10,
|
|
27
|
+
toActionId: 11,
|
|
28
|
+
personsMoved,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
describe("handleCampaignMoveNext", () => {
|
|
32
|
+
const originalExitCode = process.exitCode;
|
|
33
|
+
let stdoutSpy;
|
|
34
|
+
let stderrSpy;
|
|
35
|
+
beforeEach(() => {
|
|
36
|
+
process.exitCode = undefined;
|
|
37
|
+
vi.clearAllMocks();
|
|
38
|
+
stdoutSpy = vi.spyOn(process.stdout, "write").mockReturnValue(true);
|
|
39
|
+
stderrSpy = vi.spyOn(process.stderr, "write").mockReturnValue(true);
|
|
40
|
+
});
|
|
41
|
+
afterEach(() => {
|
|
42
|
+
process.exitCode = originalExitCode;
|
|
43
|
+
vi.restoreAllMocks();
|
|
44
|
+
});
|
|
45
|
+
it("moves persons to next action with --person-ids", async () => {
|
|
46
|
+
vi.mocked(campaignMoveNext).mockResolvedValue(mockResult(2));
|
|
47
|
+
await handleCampaignMoveNext(1, 10, { personIds: "100,200" });
|
|
48
|
+
expect(process.exitCode).toBeUndefined();
|
|
49
|
+
expect(getStdout(stdoutSpy)).toContain("Campaign 1: 2 persons moved from action 10 to action 11.");
|
|
50
|
+
});
|
|
51
|
+
it("moves persons with --person-ids-file", async () => {
|
|
52
|
+
vi.mocked(readFileSync).mockReturnValue("100\n200\n300");
|
|
53
|
+
vi.mocked(campaignMoveNext).mockResolvedValue(mockResult(3));
|
|
54
|
+
await handleCampaignMoveNext(1, 10, { personIdsFile: "ids.txt" });
|
|
55
|
+
expect(process.exitCode).toBeUndefined();
|
|
56
|
+
expect(getStdout(stdoutSpy)).toContain("3 persons moved");
|
|
57
|
+
});
|
|
58
|
+
it("prints JSON with --json", async () => {
|
|
59
|
+
vi.mocked(campaignMoveNext).mockResolvedValue(mockResult(1));
|
|
60
|
+
await handleCampaignMoveNext(1, 10, { personIds: "100", json: true });
|
|
61
|
+
expect(process.exitCode).toBeUndefined();
|
|
62
|
+
const parsed = JSON.parse(getStdout(stdoutSpy));
|
|
63
|
+
expect(parsed.success).toBe(true);
|
|
64
|
+
expect(parsed.campaignId).toBe(1);
|
|
65
|
+
expect(parsed.fromActionId).toBe(10);
|
|
66
|
+
expect(parsed.toActionId).toBe(11);
|
|
67
|
+
expect(parsed.personsMoved).toBe(1);
|
|
68
|
+
});
|
|
69
|
+
it("passes person IDs to operation", async () => {
|
|
70
|
+
vi.mocked(campaignMoveNext).mockResolvedValue(mockResult(2));
|
|
71
|
+
await handleCampaignMoveNext(1, 10, { personIds: "100,200" });
|
|
72
|
+
expect(campaignMoveNext).toHaveBeenCalledWith(expect.objectContaining({
|
|
73
|
+
campaignId: 1,
|
|
74
|
+
actionId: 10,
|
|
75
|
+
personIds: [100, 200],
|
|
76
|
+
}));
|
|
77
|
+
});
|
|
78
|
+
it("sets exitCode 1 when both person-ids options provided", async () => {
|
|
79
|
+
await handleCampaignMoveNext(1, 10, {
|
|
80
|
+
personIds: "100",
|
|
81
|
+
personIdsFile: "ids.txt",
|
|
82
|
+
});
|
|
83
|
+
expect(process.exitCode).toBe(1);
|
|
84
|
+
expect(stderrSpy).toHaveBeenCalledWith("Use only one of --person-ids or --person-ids-file.\n");
|
|
85
|
+
});
|
|
86
|
+
it("sets exitCode 1 when no person-ids option provided", async () => {
|
|
87
|
+
await handleCampaignMoveNext(1, 10, {});
|
|
88
|
+
expect(process.exitCode).toBe(1);
|
|
89
|
+
expect(stderrSpy).toHaveBeenCalledWith("Either --person-ids or --person-ids-file is required.\n");
|
|
90
|
+
});
|
|
91
|
+
it("sets exitCode 1 when person IDs are empty", async () => {
|
|
92
|
+
vi.mocked(readFileSync).mockReturnValue("");
|
|
93
|
+
await handleCampaignMoveNext(1, 10, { personIdsFile: "empty.txt" });
|
|
94
|
+
expect(process.exitCode).toBe(1);
|
|
95
|
+
expect(stderrSpy).toHaveBeenCalledWith("No person IDs provided.\n");
|
|
96
|
+
});
|
|
97
|
+
it("sets exitCode 1 on invalid person ID", async () => {
|
|
98
|
+
await handleCampaignMoveNext(1, 10, { personIds: "100,abc" });
|
|
99
|
+
expect(process.exitCode).toBe(1);
|
|
100
|
+
expect(stderrSpy).toHaveBeenCalledWith(expect.stringContaining('Invalid person ID: "abc"'));
|
|
101
|
+
});
|
|
102
|
+
it("sets exitCode 1 when campaign not found", async () => {
|
|
103
|
+
vi.mocked(campaignMoveNext).mockRejectedValue(new CampaignNotFoundError(999));
|
|
104
|
+
await handleCampaignMoveNext(999, 10, { personIds: "100" });
|
|
105
|
+
expect(process.exitCode).toBe(1);
|
|
106
|
+
expect(stderrSpy).toHaveBeenCalledWith("Campaign 999 not found.\n");
|
|
107
|
+
});
|
|
108
|
+
it("sets exitCode 1 when action not found", async () => {
|
|
109
|
+
vi.mocked(campaignMoveNext).mockRejectedValue(new ActionNotFoundError(99, 1));
|
|
110
|
+
await handleCampaignMoveNext(1, 99, { personIds: "100" });
|
|
111
|
+
expect(process.exitCode).toBe(1);
|
|
112
|
+
expect(stderrSpy).toHaveBeenCalledWith("Action 99 not found in campaign 1.\n");
|
|
113
|
+
});
|
|
114
|
+
it("sets exitCode 1 when no next action", async () => {
|
|
115
|
+
vi.mocked(campaignMoveNext).mockRejectedValue(new NoNextActionError(10, 1));
|
|
116
|
+
await handleCampaignMoveNext(1, 10, { personIds: "100" });
|
|
117
|
+
expect(process.exitCode).toBe(1);
|
|
118
|
+
expect(stderrSpy).toHaveBeenCalledWith("Action 10 is the last action in campaign 1.\n");
|
|
119
|
+
});
|
|
120
|
+
it("sets exitCode 1 when resolveAccount fails", async () => {
|
|
121
|
+
vi.mocked(campaignMoveNext).mockRejectedValue(new Error("timeout"));
|
|
122
|
+
await handleCampaignMoveNext(1, 10, { personIds: "100" });
|
|
123
|
+
expect(process.exitCode).toBe(1);
|
|
124
|
+
expect(stderrSpy).toHaveBeenCalledWith("timeout\n");
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
//# sourceMappingURL=campaign-move-next.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-move-next.test.js","sourceRoot":"","sources":["../../src/handlers/campaign-move-next.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaign-actions | campaign-remove-action} CLI command. */
|
|
2
|
+
export declare function handleCampaignRemoveAction(campaignId: number, actionId: number, options: {
|
|
3
|
+
cdpPort?: number;
|
|
4
|
+
cdpHost?: string;
|
|
5
|
+
allowRemote?: boolean;
|
|
6
|
+
json?: boolean;
|
|
7
|
+
}): Promise<void>;
|
|
8
|
+
//# sourceMappingURL=campaign-remove-action.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-remove-action.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-remove-action.ts"],"names":[],"mappings":"AAcA,0HAA0H;AAC1H,wBAAsB,0BAA0B,CAC9C,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,MAAM,EAChB,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,CAoCf"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { ActionNotFoundError, CampaignExecutionError, CampaignNotFoundError, DEFAULT_CDP_PORT, errorMessage, InstanceNotRunningError, campaignRemoveAction, } from "@lhremote/core";
|
|
4
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaign-actions | campaign-remove-action} CLI command. */
|
|
5
|
+
export async function handleCampaignRemoveAction(campaignId, actionId, options) {
|
|
6
|
+
let result;
|
|
7
|
+
try {
|
|
8
|
+
result = await campaignRemoveAction({
|
|
9
|
+
campaignId,
|
|
10
|
+
actionId,
|
|
11
|
+
cdpPort: options.cdpPort ?? DEFAULT_CDP_PORT,
|
|
12
|
+
cdpHost: options.cdpHost,
|
|
13
|
+
allowRemote: options.allowRemote,
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
catch (error) {
|
|
17
|
+
if (error instanceof CampaignNotFoundError) {
|
|
18
|
+
process.stderr.write(`Campaign ${String(campaignId)} not found.\n`);
|
|
19
|
+
}
|
|
20
|
+
else if (error instanceof ActionNotFoundError) {
|
|
21
|
+
process.stderr.write(`Action ${String(actionId)} not found in campaign ${String(campaignId)}.\n`);
|
|
22
|
+
}
|
|
23
|
+
else if (error instanceof CampaignExecutionError) {
|
|
24
|
+
process.stderr.write(`Failed to remove action: ${error.message}\n`);
|
|
25
|
+
}
|
|
26
|
+
else if (error instanceof InstanceNotRunningError) {
|
|
27
|
+
process.stderr.write(`${error.message}\n`);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
const message = errorMessage(error);
|
|
31
|
+
process.stderr.write(`${message}\n`);
|
|
32
|
+
}
|
|
33
|
+
process.exitCode = 1;
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
if (options.json) {
|
|
37
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
process.stdout.write(`Action ${String(actionId)} removed from campaign ${String(campaignId)}.\n`);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=campaign-remove-action.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-remove-action.js","sourceRoot":"","sources":["../../src/handlers/campaign-remove-action.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,mBAAmB,EACnB,sBAAsB,EACtB,qBAAqB,EACrB,gBAAgB,EAChB,YAAY,EACZ,uBAAuB,EACvB,oBAAoB,GAErB,MAAM,gBAAgB,CAAC;AAExB,0HAA0H;AAC1H,MAAM,CAAC,KAAK,UAAU,0BAA0B,CAC9C,UAAkB,EAClB,QAAgB,EAChB,OAKC;IAED,IAAI,MAAkC,CAAC;IACvC,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,oBAAoB,CAAC;YAClC,UAAU;YACV,QAAQ;YACR,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,mBAAmB,EAAE,CAAC;YAChD,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,UAAU,MAAM,CAAC,QAAQ,CAAC,0BAA0B,MAAM,CAAC,UAAU,CAAC,KAAK,CAC5E,CAAC;QACJ,CAAC;aAAM,IAAI,KAAK,YAAY,sBAAsB,EAAE,CAAC;YACnD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,KAAK,CAAC,OAAO,IAAI,CAAC,CAAC;QACtE,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,UAAU,MAAM,CAAC,QAAQ,CAAC,0BAA0B,MAAM,CAAC,UAAU,CAAC,KAAK,CAC5E,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-remove-action.test.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-remove-action.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,79 @@
|
|
|
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
|
+
campaignRemoveAction: vi.fn(),
|
|
9
|
+
};
|
|
10
|
+
});
|
|
11
|
+
import { ActionNotFoundError, CampaignExecutionError, CampaignNotFoundError, InstanceNotRunningError, campaignRemoveAction, } from "@lhremote/core";
|
|
12
|
+
import { handleCampaignRemoveAction } from "./campaign-remove-action.js";
|
|
13
|
+
import { getStdout } from "./testing/mock-helpers.js";
|
|
14
|
+
const MOCK_RESULT = {
|
|
15
|
+
success: true,
|
|
16
|
+
campaignId: 1,
|
|
17
|
+
removedActionId: 10,
|
|
18
|
+
};
|
|
19
|
+
describe("handleCampaignRemoveAction", () => {
|
|
20
|
+
const originalExitCode = process.exitCode;
|
|
21
|
+
let stdoutSpy;
|
|
22
|
+
let stderrSpy;
|
|
23
|
+
beforeEach(() => {
|
|
24
|
+
process.exitCode = undefined;
|
|
25
|
+
vi.clearAllMocks();
|
|
26
|
+
stdoutSpy = vi.spyOn(process.stdout, "write").mockReturnValue(true);
|
|
27
|
+
stderrSpy = vi.spyOn(process.stderr, "write").mockReturnValue(true);
|
|
28
|
+
});
|
|
29
|
+
afterEach(() => {
|
|
30
|
+
process.exitCode = originalExitCode;
|
|
31
|
+
vi.restoreAllMocks();
|
|
32
|
+
});
|
|
33
|
+
it("removes action and prints confirmation", async () => {
|
|
34
|
+
vi.mocked(campaignRemoveAction).mockResolvedValue(MOCK_RESULT);
|
|
35
|
+
await handleCampaignRemoveAction(1, 10, {});
|
|
36
|
+
expect(process.exitCode).toBeUndefined();
|
|
37
|
+
expect(getStdout(stdoutSpy)).toContain("Action 10 removed from campaign 1.");
|
|
38
|
+
});
|
|
39
|
+
it("prints JSON with --json", async () => {
|
|
40
|
+
vi.mocked(campaignRemoveAction).mockResolvedValue(MOCK_RESULT);
|
|
41
|
+
await handleCampaignRemoveAction(1, 10, { json: true });
|
|
42
|
+
expect(process.exitCode).toBeUndefined();
|
|
43
|
+
const parsed = JSON.parse(getStdout(stdoutSpy));
|
|
44
|
+
expect(parsed.success).toBe(true);
|
|
45
|
+
expect(parsed.campaignId).toBe(1);
|
|
46
|
+
expect(parsed.removedActionId).toBe(10);
|
|
47
|
+
});
|
|
48
|
+
it("sets exitCode 1 when campaign not found", async () => {
|
|
49
|
+
vi.mocked(campaignRemoveAction).mockRejectedValue(new CampaignNotFoundError(999));
|
|
50
|
+
await handleCampaignRemoveAction(999, 10, {});
|
|
51
|
+
expect(process.exitCode).toBe(1);
|
|
52
|
+
expect(stderrSpy).toHaveBeenCalledWith("Campaign 999 not found.\n");
|
|
53
|
+
});
|
|
54
|
+
it("sets exitCode 1 when action not found", async () => {
|
|
55
|
+
vi.mocked(campaignRemoveAction).mockRejectedValue(new ActionNotFoundError(99, 1));
|
|
56
|
+
await handleCampaignRemoveAction(1, 99, {});
|
|
57
|
+
expect(process.exitCode).toBe(1);
|
|
58
|
+
expect(stderrSpy).toHaveBeenCalledWith("Action 99 not found in campaign 1.\n");
|
|
59
|
+
});
|
|
60
|
+
it("sets exitCode 1 on CampaignExecutionError", async () => {
|
|
61
|
+
vi.mocked(campaignRemoveAction).mockRejectedValue(new CampaignExecutionError("in use"));
|
|
62
|
+
await handleCampaignRemoveAction(1, 10, {});
|
|
63
|
+
expect(process.exitCode).toBe(1);
|
|
64
|
+
expect(stderrSpy).toHaveBeenCalledWith("Failed to remove action: in use\n");
|
|
65
|
+
});
|
|
66
|
+
it("sets exitCode 1 on InstanceNotRunningError", async () => {
|
|
67
|
+
vi.mocked(campaignRemoveAction).mockRejectedValue(new InstanceNotRunningError("No LinkedHelper instance is running."));
|
|
68
|
+
await handleCampaignRemoveAction(1, 10, {});
|
|
69
|
+
expect(process.exitCode).toBe(1);
|
|
70
|
+
expect(stderrSpy).toHaveBeenCalledWith("No LinkedHelper instance is running.\n");
|
|
71
|
+
});
|
|
72
|
+
it("sets exitCode 1 when resolveAccount fails", async () => {
|
|
73
|
+
vi.mocked(campaignRemoveAction).mockRejectedValue(new Error("timeout"));
|
|
74
|
+
await handleCampaignRemoveAction(1, 10, {});
|
|
75
|
+
expect(process.exitCode).toBe(1);
|
|
76
|
+
expect(stderrSpy).toHaveBeenCalledWith("timeout\n");
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
//# sourceMappingURL=campaign-remove-action.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-remove-action.test.js","sourceRoot":"","sources":["../../src/handlers/campaign-remove-action.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaign-actions | campaign-reorder-actions} CLI command. */
|
|
2
|
+
export declare function handleCampaignReorderActions(campaignId: number, options: {
|
|
3
|
+
actionIds: string;
|
|
4
|
+
cdpPort?: number;
|
|
5
|
+
cdpHost?: string;
|
|
6
|
+
allowRemote?: boolean;
|
|
7
|
+
json?: boolean;
|
|
8
|
+
}): Promise<void>;
|
|
9
|
+
//# sourceMappingURL=campaign-reorder-actions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-reorder-actions.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-reorder-actions.ts"],"names":[],"mappings":"AAcA,4HAA4H;AAC5H,wBAAsB,4BAA4B,CAChD,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE;IACP,SAAS,EAAE,MAAM,CAAC;IAClB,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,CAoEf"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { ActionNotFoundError, CampaignExecutionError, CampaignNotFoundError, DEFAULT_CDP_PORT, errorMessage, InstanceNotRunningError, campaignReorderActions, } from "@lhremote/core";
|
|
4
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#campaign-actions | campaign-reorder-actions} CLI command. */
|
|
5
|
+
export async function handleCampaignReorderActions(campaignId, options) {
|
|
6
|
+
// Parse action IDs
|
|
7
|
+
const actionIds = options.actionIds
|
|
8
|
+
.split(",")
|
|
9
|
+
.map((s) => {
|
|
10
|
+
const n = Number(s.trim());
|
|
11
|
+
if (!Number.isInteger(n) || n <= 0) {
|
|
12
|
+
process.stderr.write(`Invalid action ID: "${s.trim()}". Expected positive integers.\n`);
|
|
13
|
+
process.exitCode = 1;
|
|
14
|
+
return NaN;
|
|
15
|
+
}
|
|
16
|
+
return n;
|
|
17
|
+
});
|
|
18
|
+
if (actionIds.some((n) => Number.isNaN(n))) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
if (actionIds.length === 0) {
|
|
22
|
+
process.stderr.write("No action IDs provided.\n");
|
|
23
|
+
process.exitCode = 1;
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
let result;
|
|
27
|
+
try {
|
|
28
|
+
result = await campaignReorderActions({
|
|
29
|
+
campaignId,
|
|
30
|
+
actionIds,
|
|
31
|
+
cdpPort: options.cdpPort ?? DEFAULT_CDP_PORT,
|
|
32
|
+
cdpHost: options.cdpHost,
|
|
33
|
+
allowRemote: options.allowRemote,
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
catch (error) {
|
|
37
|
+
if (error instanceof CampaignNotFoundError) {
|
|
38
|
+
process.stderr.write(`Campaign ${String(campaignId)} not found.\n`);
|
|
39
|
+
}
|
|
40
|
+
else if (error instanceof ActionNotFoundError) {
|
|
41
|
+
process.stderr.write(`One or more action IDs not found in campaign ${String(campaignId)}.\n`);
|
|
42
|
+
}
|
|
43
|
+
else if (error instanceof CampaignExecutionError) {
|
|
44
|
+
process.stderr.write(`Failed to reorder actions: ${error.message}\n`);
|
|
45
|
+
}
|
|
46
|
+
else if (error instanceof InstanceNotRunningError) {
|
|
47
|
+
process.stderr.write(`${error.message}\n`);
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
const message = errorMessage(error);
|
|
51
|
+
process.stderr.write(`${message}\n`);
|
|
52
|
+
}
|
|
53
|
+
process.exitCode = 1;
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
if (options.json) {
|
|
57
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
process.stdout.write(`Actions reordered in campaign ${String(campaignId)}.\n`);
|
|
61
|
+
for (const action of result.actions) {
|
|
62
|
+
process.stdout.write(` #${action.id} "${action.name}" (${action.config.actionType})\n`);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=campaign-reorder-actions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-reorder-actions.js","sourceRoot":"","sources":["../../src/handlers/campaign-reorder-actions.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"campaign-reorder-actions.test.d.ts","sourceRoot":"","sources":["../../src/handlers/campaign-reorder-actions.test.ts"],"names":[],"mappings":""}
|