@lhremote/cli 0.7.0 → 0.9.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/dist/handlers/add-people-to-collection.d.ts.map +1 -1
- package/dist/handlers/add-people-to-collection.js +2 -2
- package/dist/handlers/add-people-to-collection.js.map +1 -1
- package/dist/handlers/build-url.test.d.ts +2 -0
- package/dist/handlers/build-url.test.d.ts.map +1 -0
- package/dist/handlers/build-url.test.js +119 -0
- package/dist/handlers/build-url.test.js.map +1 -0
- package/dist/handlers/campaign-add-action.d.ts.map +1 -1
- package/dist/handlers/campaign-add-action.js +2 -2
- package/dist/handlers/campaign-add-action.js.map +1 -1
- package/dist/handlers/campaign-create.d.ts.map +1 -1
- package/dist/handlers/campaign-create.js +2 -2
- package/dist/handlers/campaign-create.js.map +1 -1
- package/dist/handlers/campaign-delete.d.ts +1 -0
- package/dist/handlers/campaign-delete.d.ts.map +1 -1
- package/dist/handlers/campaign-delete.js +5 -3
- package/dist/handlers/campaign-delete.js.map +1 -1
- package/dist/handlers/campaign-delete.test.js +25 -0
- package/dist/handlers/campaign-delete.test.js.map +1 -1
- package/dist/handlers/campaign-erase.d.ts +8 -0
- package/dist/handlers/campaign-erase.d.ts.map +1 -0
- package/dist/handlers/campaign-erase.js +39 -0
- package/dist/handlers/campaign-erase.js.map +1 -0
- package/dist/handlers/campaign-erase.test.d.ts +2 -0
- package/dist/handlers/campaign-erase.test.d.ts.map +1 -0
- package/dist/handlers/campaign-erase.test.js +71 -0
- package/dist/handlers/campaign-erase.test.js.map +1 -0
- package/dist/handlers/campaign-exclude-add.d.ts.map +1 -1
- package/dist/handlers/campaign-exclude-add.js +2 -2
- package/dist/handlers/campaign-exclude-add.js.map +1 -1
- package/dist/handlers/campaign-exclude-list.d.ts.map +1 -1
- package/dist/handlers/campaign-exclude-list.js +2 -2
- package/dist/handlers/campaign-exclude-list.js.map +1 -1
- package/dist/handlers/campaign-exclude-remove.d.ts.map +1 -1
- package/dist/handlers/campaign-exclude-remove.js +2 -2
- package/dist/handlers/campaign-exclude-remove.js.map +1 -1
- package/dist/handlers/campaign-export.d.ts.map +1 -1
- package/dist/handlers/campaign-export.js +2 -2
- package/dist/handlers/campaign-export.js.map +1 -1
- package/dist/handlers/campaign-get.d.ts.map +1 -1
- package/dist/handlers/campaign-get.js +2 -2
- package/dist/handlers/campaign-get.js.map +1 -1
- package/dist/handlers/campaign-list-people.d.ts.map +1 -1
- package/dist/handlers/campaign-list-people.js +2 -2
- package/dist/handlers/campaign-list-people.js.map +1 -1
- package/dist/handlers/campaign-move-next.d.ts.map +1 -1
- package/dist/handlers/campaign-move-next.js +2 -2
- package/dist/handlers/campaign-move-next.js.map +1 -1
- package/dist/handlers/campaign-remove-action.d.ts.map +1 -1
- package/dist/handlers/campaign-remove-action.js +2 -2
- package/dist/handlers/campaign-remove-action.js.map +1 -1
- package/dist/handlers/campaign-remove-people.d.ts.map +1 -1
- package/dist/handlers/campaign-remove-people.js +2 -2
- package/dist/handlers/campaign-remove-people.js.map +1 -1
- package/dist/handlers/campaign-reorder-actions.d.ts.map +1 -1
- package/dist/handlers/campaign-reorder-actions.js +2 -2
- package/dist/handlers/campaign-reorder-actions.js.map +1 -1
- package/dist/handlers/campaign-retry.d.ts.map +1 -1
- package/dist/handlers/campaign-retry.js +2 -2
- package/dist/handlers/campaign-retry.js.map +1 -1
- package/dist/handlers/campaign-start.d.ts.map +1 -1
- package/dist/handlers/campaign-start.js +2 -2
- package/dist/handlers/campaign-start.js.map +1 -1
- package/dist/handlers/campaign-statistics.d.ts.map +1 -1
- package/dist/handlers/campaign-statistics.js +2 -2
- package/dist/handlers/campaign-statistics.js.map +1 -1
- package/dist/handlers/campaign-status.d.ts.map +1 -1
- package/dist/handlers/campaign-status.js +2 -2
- package/dist/handlers/campaign-status.js.map +1 -1
- package/dist/handlers/campaign-stop.d.ts.map +1 -1
- package/dist/handlers/campaign-stop.js +2 -2
- package/dist/handlers/campaign-stop.js.map +1 -1
- package/dist/handlers/campaign-update-action.d.ts.map +1 -1
- package/dist/handlers/campaign-update-action.js +2 -2
- package/dist/handlers/campaign-update-action.js.map +1 -1
- package/dist/handlers/campaign-update.d.ts.map +1 -1
- package/dist/handlers/campaign-update.js +2 -2
- package/dist/handlers/campaign-update.js.map +1 -1
- package/dist/handlers/check-replies.d.ts +2 -0
- package/dist/handlers/check-replies.d.ts.map +1 -1
- package/dist/handlers/check-replies.js +9 -2
- package/dist/handlers/check-replies.js.map +1 -1
- package/dist/handlers/check-replies.test.js +25 -8
- package/dist/handlers/check-replies.test.js.map +1 -1
- package/dist/handlers/check-status.d.ts.map +1 -1
- package/dist/handlers/check-status.js +6 -6
- package/dist/handlers/check-status.js.map +1 -1
- package/dist/handlers/collect-people.d.ts.map +1 -1
- package/dist/handlers/collect-people.js +2 -2
- package/dist/handlers/collect-people.js.map +1 -1
- package/dist/handlers/comment-on-post.d.ts +10 -0
- package/dist/handlers/comment-on-post.d.ts.map +1 -0
- package/dist/handlers/comment-on-post.js +37 -0
- package/dist/handlers/comment-on-post.js.map +1 -0
- package/dist/handlers/comment-on-post.test.d.ts +2 -0
- package/dist/handlers/comment-on-post.test.d.ts.map +1 -0
- package/dist/handlers/comment-on-post.test.js +75 -0
- package/dist/handlers/comment-on-post.test.js.map +1 -0
- package/dist/handlers/create-collection.d.ts.map +1 -1
- package/dist/handlers/create-collection.js +2 -2
- package/dist/handlers/create-collection.js.map +1 -1
- package/dist/handlers/delete-collection.d.ts.map +1 -1
- package/dist/handlers/delete-collection.js +2 -2
- package/dist/handlers/delete-collection.js.map +1 -1
- package/dist/handlers/dismiss-errors.d.ts +8 -0
- package/dist/handlers/dismiss-errors.d.ts.map +1 -0
- package/dist/handlers/dismiss-errors.js +28 -0
- package/dist/handlers/dismiss-errors.js.map +1 -0
- package/dist/handlers/dismiss-errors.test.d.ts +2 -0
- package/dist/handlers/dismiss-errors.test.d.ts.map +1 -0
- package/dist/handlers/dismiss-errors.test.js +90 -0
- package/dist/handlers/dismiss-errors.test.js.map +1 -0
- package/dist/handlers/endorse-skills.d.ts +14 -0
- package/dist/handlers/endorse-skills.d.ts.map +1 -0
- package/dist/handlers/endorse-skills.js +44 -0
- package/dist/handlers/endorse-skills.js.map +1 -0
- package/dist/handlers/endorse-skills.test.d.ts +2 -0
- package/dist/handlers/endorse-skills.test.d.ts.map +1 -0
- package/dist/handlers/endorse-skills.test.js +65 -0
- package/dist/handlers/endorse-skills.test.js.map +1 -0
- package/dist/handlers/enrich-profile.d.ts +16 -0
- package/dist/handlers/enrich-profile.d.ts.map +1 -0
- package/dist/handlers/enrich-profile.js +51 -0
- package/dist/handlers/enrich-profile.js.map +1 -0
- package/dist/handlers/enrich-profile.test.d.ts +2 -0
- package/dist/handlers/enrich-profile.test.d.ts.map +1 -0
- package/dist/handlers/enrich-profile.test.js +65 -0
- package/dist/handlers/enrich-profile.test.js.map +1 -0
- package/dist/handlers/find-app.js +1 -1
- package/dist/handlers/find-app.js.map +1 -1
- package/dist/handlers/find-app.test.js +4 -4
- package/dist/handlers/find-app.test.js.map +1 -1
- package/dist/handlers/follow-person.d.ts +13 -0
- package/dist/handlers/follow-person.d.ts.map +1 -0
- package/dist/handlers/follow-person.js +45 -0
- package/dist/handlers/follow-person.js.map +1 -0
- package/dist/handlers/follow-person.test.d.ts +2 -0
- package/dist/handlers/follow-person.test.d.ts.map +1 -0
- package/dist/handlers/follow-person.test.js +65 -0
- package/dist/handlers/follow-person.test.js.map +1 -0
- package/dist/handlers/get-action-budget.d.ts +8 -0
- package/dist/handlers/get-action-budget.d.ts.map +1 -0
- package/dist/handlers/get-action-budget.js +46 -0
- package/dist/handlers/get-action-budget.js.map +1 -0
- package/dist/handlers/get-action-budget.test.d.ts +2 -0
- package/dist/handlers/get-action-budget.test.d.ts.map +1 -0
- package/dist/handlers/get-action-budget.test.js +69 -0
- package/dist/handlers/get-action-budget.test.js.map +1 -0
- package/dist/handlers/get-errors.d.ts.map +1 -1
- package/dist/handlers/get-errors.js +14 -2
- package/dist/handlers/get-errors.js.map +1 -1
- package/dist/handlers/get-errors.test.js +25 -0
- package/dist/handlers/get-errors.test.js.map +1 -1
- package/dist/handlers/get-feed.d.ts +10 -0
- package/dist/handlers/get-feed.d.ts.map +1 -0
- package/dist/handlers/get-feed.js +64 -0
- package/dist/handlers/get-feed.js.map +1 -0
- package/dist/handlers/get-feed.test.d.ts +2 -0
- package/dist/handlers/get-feed.test.d.ts.map +1 -0
- package/dist/handlers/get-feed.test.js +124 -0
- package/dist/handlers/get-feed.test.js.map +1 -0
- package/dist/handlers/get-post-stats.d.ts +8 -0
- package/dist/handlers/get-post-stats.d.ts.map +1 -0
- package/dist/handlers/get-post-stats.js +37 -0
- package/dist/handlers/get-post-stats.js.map +1 -0
- package/dist/handlers/get-post-stats.test.d.ts +2 -0
- package/dist/handlers/get-post-stats.test.d.ts.map +1 -0
- package/dist/handlers/get-post-stats.test.js +79 -0
- package/dist/handlers/get-post-stats.test.js.map +1 -0
- package/dist/handlers/get-post.d.ts +9 -0
- package/dist/handlers/get-post.d.ts.map +1 -0
- package/dist/handlers/get-post.js +65 -0
- package/dist/handlers/get-post.js.map +1 -0
- package/dist/handlers/get-post.test.d.ts +2 -0
- package/dist/handlers/get-post.test.d.ts.map +1 -0
- package/dist/handlers/get-post.test.js +124 -0
- package/dist/handlers/get-post.test.js.map +1 -0
- package/dist/handlers/get-profile-activity.d.ts +10 -0
- package/dist/handlers/get-profile-activity.d.ts.map +1 -0
- package/dist/handlers/get-profile-activity.js +60 -0
- package/dist/handlers/get-profile-activity.js.map +1 -0
- package/dist/handlers/get-profile-activity.test.d.ts +2 -0
- package/dist/handlers/get-profile-activity.test.d.ts.map +1 -0
- package/dist/handlers/get-profile-activity.test.js +127 -0
- package/dist/handlers/get-profile-activity.test.js.map +1 -0
- package/dist/handlers/get-throttle-status.d.ts +8 -0
- package/dist/handlers/get-throttle-status.d.ts.map +1 -0
- package/dist/handlers/get-throttle-status.js +33 -0
- package/dist/handlers/get-throttle-status.js.map +1 -0
- package/dist/handlers/get-throttle-status.test.d.ts +2 -0
- package/dist/handlers/get-throttle-status.test.d.ts.map +1 -0
- package/dist/handlers/get-throttle-status.test.js +65 -0
- package/dist/handlers/get-throttle-status.test.js.map +1 -0
- package/dist/handlers/import-people-from-collection.d.ts.map +1 -1
- package/dist/handlers/import-people-from-collection.js +2 -2
- package/dist/handlers/import-people-from-collection.js.map +1 -1
- package/dist/handlers/import-people-from-urls.d.ts.map +1 -1
- package/dist/handlers/import-people-from-urls.js +2 -2
- package/dist/handlers/import-people-from-urls.js.map +1 -1
- package/dist/handlers/index.d.ts +20 -0
- package/dist/handlers/index.d.ts.map +1 -1
- package/dist/handlers/index.js +20 -0
- package/dist/handlers/index.js.map +1 -1
- package/dist/handlers/like-person-posts.d.ts +18 -0
- package/dist/handlers/like-person-posts.d.ts.map +1 -0
- package/dist/handlers/like-person-posts.js +59 -0
- package/dist/handlers/like-person-posts.js.map +1 -0
- package/dist/handlers/like-person-posts.test.d.ts +2 -0
- package/dist/handlers/like-person-posts.test.d.ts.map +1 -0
- package/dist/handlers/like-person-posts.test.js +71 -0
- package/dist/handlers/like-person-posts.test.js.map +1 -0
- package/dist/handlers/list-accounts.d.ts.map +1 -1
- package/dist/handlers/list-accounts.js +12 -2
- package/dist/handlers/list-accounts.js.map +1 -1
- package/dist/handlers/list-accounts.test.js +3 -1
- package/dist/handlers/list-accounts.test.js.map +1 -1
- package/dist/handlers/list-reference-data.test.d.ts +2 -0
- package/dist/handlers/list-reference-data.test.d.ts.map +1 -0
- package/dist/handlers/list-reference-data.test.js +62 -0
- package/dist/handlers/list-reference-data.test.js.map +1 -0
- package/dist/handlers/message-person.d.ts +15 -0
- package/dist/handlers/message-person.d.ts.map +1 -0
- package/dist/handlers/message-person.js +65 -0
- package/dist/handlers/message-person.js.map +1 -0
- package/dist/handlers/message-person.test.d.ts +2 -0
- package/dist/handlers/message-person.test.d.ts.map +1 -0
- package/dist/handlers/message-person.test.js +77 -0
- package/dist/handlers/message-person.test.js.map +1 -0
- package/dist/handlers/query-messages.integration.test.js +24 -3
- package/dist/handlers/query-messages.integration.test.js.map +1 -1
- package/dist/handlers/react-to-post.d.ts +9 -0
- package/dist/handlers/react-to-post.d.ts.map +1 -0
- package/dist/handlers/react-to-post.js +30 -0
- package/dist/handlers/react-to-post.js.map +1 -0
- package/dist/handlers/react-to-post.test.d.ts +2 -0
- package/dist/handlers/react-to-post.test.d.ts.map +1 -0
- package/dist/handlers/react-to-post.test.js +53 -0
- package/dist/handlers/react-to-post.test.js.map +1 -0
- package/dist/handlers/remove-connection.d.ts +11 -0
- package/dist/handlers/remove-connection.d.ts.map +1 -0
- package/dist/handlers/remove-connection.js +41 -0
- package/dist/handlers/remove-connection.js.map +1 -0
- package/dist/handlers/remove-connection.test.d.ts +2 -0
- package/dist/handlers/remove-connection.test.d.ts.map +1 -0
- package/dist/handlers/remove-connection.test.js +65 -0
- package/dist/handlers/remove-connection.test.js.map +1 -0
- package/dist/handlers/remove-people-from-collection.d.ts.map +1 -1
- package/dist/handlers/remove-people-from-collection.js +2 -2
- package/dist/handlers/remove-people-from-collection.js.map +1 -1
- package/dist/handlers/resolve-entity.d.ts.map +1 -1
- package/dist/handlers/resolve-entity.js +2 -2
- package/dist/handlers/resolve-entity.js.map +1 -1
- package/dist/handlers/resolve-entity.test.d.ts +2 -0
- package/dist/handlers/resolve-entity.test.d.ts.map +1 -0
- package/dist/handlers/resolve-entity.test.js +93 -0
- package/dist/handlers/resolve-entity.test.js.map +1 -0
- package/dist/handlers/scrape-messaging-history.d.ts +1 -0
- package/dist/handlers/scrape-messaging-history.d.ts.map +1 -1
- package/dist/handlers/scrape-messaging-history.js +3 -2
- package/dist/handlers/scrape-messaging-history.js.map +1 -1
- package/dist/handlers/search-posts.d.ts +10 -0
- package/dist/handlers/search-posts.d.ts.map +1 -0
- package/dist/handlers/search-posts.js +56 -0
- package/dist/handlers/search-posts.js.map +1 -0
- package/dist/handlers/search-posts.test.d.ts +2 -0
- package/dist/handlers/search-posts.test.d.ts.map +1 -0
- package/dist/handlers/search-posts.test.js +112 -0
- package/dist/handlers/search-posts.test.js.map +1 -0
- package/dist/handlers/send-inmail.d.ts +15 -0
- package/dist/handlers/send-inmail.d.ts.map +1 -0
- package/dist/handlers/send-inmail.js +65 -0
- package/dist/handlers/send-inmail.js.map +1 -0
- package/dist/handlers/send-inmail.test.d.ts +2 -0
- package/dist/handlers/send-inmail.test.d.ts.map +1 -0
- package/dist/handlers/send-inmail.test.js +77 -0
- package/dist/handlers/send-inmail.test.js.map +1 -0
- package/dist/handlers/send-invite.d.ts +13 -0
- package/dist/handlers/send-invite.d.ts.map +1 -0
- package/dist/handlers/send-invite.js +54 -0
- package/dist/handlers/send-invite.js.map +1 -0
- package/dist/handlers/send-invite.test.d.ts +2 -0
- package/dist/handlers/send-invite.test.d.ts.map +1 -0
- package/dist/handlers/send-invite.test.js +71 -0
- package/dist/handlers/send-invite.test.js.map +1 -0
- package/dist/handlers/start-instance.d.ts.map +1 -1
- package/dist/handlers/start-instance.js +11 -2
- package/dist/handlers/start-instance.js.map +1 -1
- package/dist/handlers/start-instance.test.js +3 -1
- package/dist/handlers/start-instance.test.js.map +1 -1
- package/dist/handlers/stop-instance.d.ts.map +1 -1
- package/dist/handlers/stop-instance.js +11 -2
- package/dist/handlers/stop-instance.js.map +1 -1
- package/dist/handlers/stop-instance.test.js +3 -1
- package/dist/handlers/stop-instance.test.js.map +1 -1
- package/dist/handlers/visit-profile.d.ts +11 -0
- package/dist/handlers/visit-profile.d.ts.map +1 -0
- package/dist/handlers/visit-profile.js +93 -0
- package/dist/handlers/visit-profile.js.map +1 -0
- package/dist/handlers/visit-profile.test.d.ts +2 -0
- package/dist/handlers/visit-profile.test.d.ts.map +1 -0
- package/dist/handlers/visit-profile.test.js +169 -0
- package/dist/handlers/visit-profile.test.js.map +1 -0
- package/dist/program.d.ts.map +1 -1
- package/dist/program.js +281 -37
- package/dist/program.js.map +1 -1
- package/dist/program.test.js +21 -1
- package/dist/program.test.js.map +1 -1
- package/package.json +2 -2
|
@@ -50,9 +50,14 @@ describe("handleCheckReplies", () => {
|
|
|
50
50
|
process.exitCode = originalExitCode;
|
|
51
51
|
vi.restoreAllMocks();
|
|
52
52
|
});
|
|
53
|
+
it("prints error when no person IDs provided", async () => {
|
|
54
|
+
await handleCheckReplies({ personId: [] });
|
|
55
|
+
expect(process.exitCode).toBe(1);
|
|
56
|
+
expect(getStderr(stderrSpy)).toContain("at least one --person-id is required");
|
|
57
|
+
});
|
|
53
58
|
it("prints JSON with --json", async () => {
|
|
54
59
|
vi.mocked(checkReplies).mockResolvedValue(MOCK_RESULT);
|
|
55
|
-
await handleCheckReplies({ json: true });
|
|
60
|
+
await handleCheckReplies({ personId: [456], json: true });
|
|
56
61
|
expect(process.exitCode).toBeUndefined();
|
|
57
62
|
const output = JSON.parse(getStdout(stdoutSpy));
|
|
58
63
|
expect(output.newMessages).toEqual(MOCK_CONVERSATIONS);
|
|
@@ -61,7 +66,7 @@ describe("handleCheckReplies", () => {
|
|
|
61
66
|
});
|
|
62
67
|
it("prints human-readable output by default", async () => {
|
|
63
68
|
vi.mocked(checkReplies).mockResolvedValue(MOCK_RESULT);
|
|
64
|
-
await handleCheckReplies({});
|
|
69
|
+
await handleCheckReplies({ personId: [456] });
|
|
65
70
|
expect(process.exitCode).toBeUndefined();
|
|
66
71
|
const output = getStdout(stdoutSpy);
|
|
67
72
|
expect(output).toContain("1 new message found:");
|
|
@@ -70,7 +75,7 @@ describe("handleCheckReplies", () => {
|
|
|
70
75
|
});
|
|
71
76
|
it("prints progress to stderr", async () => {
|
|
72
77
|
vi.mocked(checkReplies).mockResolvedValue(MOCK_RESULT);
|
|
73
|
-
await handleCheckReplies({});
|
|
78
|
+
await handleCheckReplies({ personId: [456] });
|
|
74
79
|
const stderr = getStderr(stderrSpy);
|
|
75
80
|
expect(stderr).toContain("Checking for new replies...");
|
|
76
81
|
expect(stderr).toContain("Done.");
|
|
@@ -81,7 +86,7 @@ describe("handleCheckReplies", () => {
|
|
|
81
86
|
totalNew: 0,
|
|
82
87
|
checkedAt: "2025-01-15T12:00:00Z",
|
|
83
88
|
});
|
|
84
|
-
await handleCheckReplies({});
|
|
89
|
+
await handleCheckReplies({ personId: [456] });
|
|
85
90
|
expect(getStdout(stdoutSpy)).toContain("No new messages found.");
|
|
86
91
|
});
|
|
87
92
|
it("passes since parameter when provided", async () => {
|
|
@@ -90,20 +95,32 @@ describe("handleCheckReplies", () => {
|
|
|
90
95
|
totalNew: 0,
|
|
91
96
|
checkedAt: "2025-01-15T12:00:00Z",
|
|
92
97
|
});
|
|
93
|
-
await handleCheckReplies({ since: "2025-01-14T00:00:00Z" });
|
|
98
|
+
await handleCheckReplies({ personId: [456], since: "2025-01-14T00:00:00Z" });
|
|
94
99
|
expect(checkReplies).toHaveBeenCalledWith(expect.objectContaining({
|
|
100
|
+
personIds: [456],
|
|
95
101
|
since: "2025-01-14T00:00:00Z",
|
|
96
102
|
}));
|
|
97
103
|
});
|
|
104
|
+
it("passes personIds to core operation", async () => {
|
|
105
|
+
vi.mocked(checkReplies).mockResolvedValue({
|
|
106
|
+
newMessages: [],
|
|
107
|
+
totalNew: 0,
|
|
108
|
+
checkedAt: "2025-01-15T12:00:00Z",
|
|
109
|
+
});
|
|
110
|
+
await handleCheckReplies({ personId: [100, 200] });
|
|
111
|
+
expect(checkReplies).toHaveBeenCalledWith(expect.objectContaining({
|
|
112
|
+
personIds: [100, 200],
|
|
113
|
+
}));
|
|
114
|
+
});
|
|
98
115
|
it("sets exitCode on error", async () => {
|
|
99
116
|
vi.mocked(checkReplies).mockRejectedValue(new Error("No accounts found."));
|
|
100
|
-
await handleCheckReplies({});
|
|
117
|
+
await handleCheckReplies({ personId: [456] });
|
|
101
118
|
expect(process.exitCode).toBe(1);
|
|
102
119
|
expect(getStderr(stderrSpy)).toContain("No accounts found.");
|
|
103
120
|
});
|
|
104
121
|
it("sets exitCode when no instance running", async () => {
|
|
105
122
|
vi.mocked(checkReplies).mockRejectedValue(new InstanceNotRunningError("No LinkedHelper instance is running. Use start-instance first."));
|
|
106
|
-
await handleCheckReplies({});
|
|
123
|
+
await handleCheckReplies({ personId: [456] });
|
|
107
124
|
expect(process.exitCode).toBe(1);
|
|
108
125
|
expect(getStderr(stderrSpy)).toContain("No LinkedHelper instance is running. Use start-instance first.");
|
|
109
126
|
});
|
|
@@ -131,7 +148,7 @@ describe("handleCheckReplies", () => {
|
|
|
131
148
|
totalNew: 2,
|
|
132
149
|
checkedAt: "2025-01-15T12:00:00Z",
|
|
133
150
|
});
|
|
134
|
-
await handleCheckReplies({});
|
|
151
|
+
await handleCheckReplies({ personId: [1] });
|
|
135
152
|
expect(getStdout(stdoutSpy)).toContain("2 new messages found:");
|
|
136
153
|
});
|
|
137
154
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-replies.test.js","sourceRoot":"","sources":["../../src/handlers/check-replies.test.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAEzE,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE;IACjD,MAAM,MAAM,GAAG,MAAM,cAAc,EAAmC,CAAC;IACvE,OAAO;QACL,GAAG,MAAM;QACT,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE;KACtB,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,OAAO,EAGL,uBAAuB,EACvB,YAAY,GACb,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAEjE,MAAM,kBAAkB,GAA2B;IACjD;QACE,MAAM,EAAE,GAAG;QACX,QAAQ,EAAE,GAAG;QACb,UAAU,EAAE,UAAU;QACtB,QAAQ,EAAE;YACR;gBACE,EAAE,EAAE,GAAG;gBACP,IAAI,EAAE,kBAAkB;gBACxB,IAAI,EAAE,0BAA0B;gBAChC,OAAO,EAAE,IAAI;gBACb,MAAM,EAAE,sBAAsB;gBAC9B,gBAAgB,EAAE,CAAC;gBACnB,cAAc,EAAE,GAAG;gBACnB,eAAe,EAAE,MAAM;gBACvB,cAAc,EAAE,KAAK;aACtB;SACF;KACF;CACF,CAAC;AAEF,MAAM,WAAW,GAAuB;IACtC,WAAW,EAAE,kBAAkB;IAC/B,QAAQ,EAAE,CAAC;IACX,SAAS,EAAE,sBAAsB;CAClC,CAAC;AAEF,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,MAAM,gBAAgB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAC1C,IAAI,SAAsC,CAAC;IAC3C,IAAI,SAAsC,CAAC;IAE3C,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,CAAC,QAAQ,GAAG,SAAS,CAAC;QAC7B,EAAE,CAAC,aAAa,EAAE,CAAC;QACnB,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QACpE,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,CAAC,QAAQ,GAAG,gBAAgB,CAAC;QACpC,EAAE,CAAC,eAAe,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE;QACvC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAEvD,MAAM,kBAAkB,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"check-replies.test.js","sourceRoot":"","sources":["../../src/handlers/check-replies.test.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAEzE,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE;IACjD,MAAM,MAAM,GAAG,MAAM,cAAc,EAAmC,CAAC;IACvE,OAAO;QACL,GAAG,MAAM;QACT,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE;KACtB,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,OAAO,EAGL,uBAAuB,EACvB,YAAY,GACb,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAEjE,MAAM,kBAAkB,GAA2B;IACjD;QACE,MAAM,EAAE,GAAG;QACX,QAAQ,EAAE,GAAG;QACb,UAAU,EAAE,UAAU;QACtB,QAAQ,EAAE;YACR;gBACE,EAAE,EAAE,GAAG;gBACP,IAAI,EAAE,kBAAkB;gBACxB,IAAI,EAAE,0BAA0B;gBAChC,OAAO,EAAE,IAAI;gBACb,MAAM,EAAE,sBAAsB;gBAC9B,gBAAgB,EAAE,CAAC;gBACnB,cAAc,EAAE,GAAG;gBACnB,eAAe,EAAE,MAAM;gBACvB,cAAc,EAAE,KAAK;aACtB;SACF;KACF;CACF,CAAC;AAEF,MAAM,WAAW,GAAuB;IACtC,WAAW,EAAE,kBAAkB;IAC/B,QAAQ,EAAE,CAAC;IACX,SAAS,EAAE,sBAAsB;CAClC,CAAC;AAEF,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,MAAM,gBAAgB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAC1C,IAAI,SAAsC,CAAC;IAC3C,IAAI,SAAsC,CAAC;IAE3C,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,CAAC,QAAQ,GAAG,SAAS,CAAC;QAC7B,EAAE,CAAC,aAAa,EAAE,CAAC;QACnB,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QACpE,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,CAAC,QAAQ,GAAG,gBAAgB,CAAC;QACpC,EAAE,CAAC,eAAe,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE,KAAK,IAAI,EAAE;QACxD,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QAE3C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,sCAAsC,CAAC,CAAC;IACjF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE;QACvC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAEvD,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QAE1D,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,aAAa,EAAE,CAAC;QACzC,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC;QAChD,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC;QACvD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAEvD,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,aAAa,EAAE,CAAC;QACzC,MAAM,MAAM,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;QACjD,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,oCAAoC,CAAC,CAAC;QAC/D,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QACzC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAEvD,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAE9C,MAAM,MAAM,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,6BAA6B,CAAC,CAAC;QACxD,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,KAAK,IAAI,EAAE;QACnD,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC;YACxC,WAAW,EAAE,EAAE;YACf,QAAQ,EAAE,CAAC;YACX,SAAS,EAAE,sBAAsB;SAClC,CAAC,CAAC;QAEH,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAE9C,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC;YACxC,WAAW,EAAE,EAAE;YACf,QAAQ,EAAE,CAAC;YACX,SAAS,EAAE,sBAAsB;SAClC,CAAC,CAAC;QAEH,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,sBAAsB,EAAE,CAAC,CAAC;QAE7E,MAAM,CAAC,YAAY,CAAC,CAAC,oBAAoB,CACvC,MAAM,CAAC,gBAAgB,CAAC;YACtB,SAAS,EAAE,CAAC,GAAG,CAAC;YAChB,KAAK,EAAE,sBAAsB;SAC9B,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAClD,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC;YACxC,WAAW,EAAE,EAAE;YACf,QAAQ,EAAE,CAAC;YACX,SAAS,EAAE,sBAAsB;SAClC,CAAC,CAAC;QAEH,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;QAEnD,MAAM,CAAC,YAAY,CAAC,CAAC,oBAAoB,CACvC,MAAM,CAAC,gBAAgB,CAAC;YACtB,SAAS,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;SACtB,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE,KAAK,IAAI,EAAE;QACtC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CACvC,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAChC,CAAC;QAEF,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CACvC,IAAI,uBAAuB,CACzB,gEAAgE,CACjE,CACF,CAAC;QAEF,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CACpC,gEAAgE,CACjE,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAClD,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC;YACxC,WAAW,EAAE;gBACX;oBACE,MAAM,EAAE,CAAC;oBACT,QAAQ,EAAE,CAAC;oBACX,UAAU,EAAE,OAAO;oBACnB,QAAQ,EAAE;wBACR;4BACE,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI;4BACnD,MAAM,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,CAAC;4BACnD,cAAc,EAAE,CAAC,EAAE,eAAe,EAAE,OAAO,EAAE,cAAc,EAAE,IAAI;yBAClE;wBACD;4BACE,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI;4BACnD,MAAM,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,CAAC;4BACnD,cAAc,EAAE,CAAC,EAAE,eAAe,EAAE,OAAO,EAAE,cAAc,EAAE,IAAI;yBAClE;qBACF;iBACF;aACF;YACD,QAAQ,EAAE,CAAC;YACX,SAAS,EAAE,sBAAsB;SAClC,CAAC,CAAC;QAEH,MAAM,kBAAkB,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAE5C,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-status.d.ts","sourceRoot":"","sources":["../../src/handlers/check-status.ts"],"names":[],"mappings":"AAKA,iHAAiH;AACjH,wBAAsB,iBAAiB,CAAC,OAAO,EAAE;IAC/C,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,
|
|
1
|
+
{"version":3,"file":"check-status.d.ts","sourceRoot":"","sources":["../../src/handlers/check-status.ts"],"names":[],"mappings":"AAKA,iHAAiH;AACjH,wBAAsB,iBAAiB,CAAC,OAAO,EAAE;IAC/C,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,CAoDhB"}
|
|
@@ -1,13 +1,10 @@
|
|
|
1
1
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
2
|
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
-
import { checkStatus, errorMessage } from "@lhremote/core";
|
|
3
|
+
import { buildCdpOptions, checkStatus, errorMessage } from "@lhremote/core";
|
|
4
4
|
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#account--instance | check-status} CLI command. */
|
|
5
5
|
export async function handleCheckStatus(options) {
|
|
6
6
|
try {
|
|
7
|
-
const report = await checkStatus(options.cdpPort,
|
|
8
|
-
...(options.cdpHost !== undefined && { host: options.cdpHost }),
|
|
9
|
-
...(options.allowRemote !== undefined && { allowRemote: options.allowRemote }),
|
|
10
|
-
});
|
|
7
|
+
const report = await checkStatus(options.cdpPort, buildCdpOptions(options));
|
|
11
8
|
if (options.json) {
|
|
12
9
|
process.stdout.write(JSON.stringify(report, null, 2) + "\n");
|
|
13
10
|
return;
|
|
@@ -16,9 +13,12 @@ export async function handleCheckStatus(options) {
|
|
|
16
13
|
if (report.launcher.reachable) {
|
|
17
14
|
process.stdout.write(`Launcher: reachable on port ${String(report.launcher.port)}\n`);
|
|
18
15
|
}
|
|
19
|
-
else {
|
|
16
|
+
else if (report.launcher.port !== null) {
|
|
20
17
|
process.stdout.write(`Launcher: not reachable on port ${String(report.launcher.port)}\n`);
|
|
21
18
|
}
|
|
19
|
+
else {
|
|
20
|
+
process.stdout.write("Launcher: not available\n");
|
|
21
|
+
}
|
|
22
22
|
// Instance status
|
|
23
23
|
if (report.instances.length === 0) {
|
|
24
24
|
process.stdout.write("Instances: none\n");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-status.js","sourceRoot":"","sources":["../../src/handlers/check-status.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"check-status.js","sourceRoot":"","sources":["../../src/handlers/check-status.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE5E,iHAAiH;AACjH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,OAKvC;IACC,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,OAAO,CAAC,OAAO,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC;QAE5E,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;YAC7D,OAAO;QACT,CAAC;QAED,kBAAkB;QAClB,IAAI,MAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;YAC9B,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,+BAA+B,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAChE,CAAC;QACJ,CAAC;aAAM,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,KAAK,IAAI,EAAE,CAAC;YACzC,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,mCAAmC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CACpE,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;QACpD,CAAC;QAED,kBAAkB;QAClB,IAAI,MAAM,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;QAC5C,CAAC;aAAM,CAAC;YACN,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;gBACxC,MAAM,IAAI,GACR,QAAQ,CAAC,OAAO,KAAK,IAAI;oBACvB,CAAC,CAAC,YAAY,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;oBACxC,CAAC,CAAC,aAAa,CAAC;gBACpB,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,aAAa,QAAQ,CAAC,WAAW,KAAK,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,OAAO,IAAI,IAAI,CAChF,CAAC;YACJ,CAAC;QACH,CAAC;QAED,kBAAkB;QAClB,IAAI,MAAM,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACN,KAAK,MAAM,EAAE,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;gBAClC,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,qBAAqB,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,MAAM,CAAC,EAAE,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC,IAAI,IAAI,CACjG,CAAC;YACJ,CAAC;QACH,CAAC;IACH,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;IACvB,CAAC;AACH,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"collect-people.d.ts","sourceRoot":"","sources":["../../src/handlers/collect-people.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"collect-people.d.ts","sourceRoot":"","sources":["../../src/handlers/collect-people.ts"],"names":[],"mappings":"AAUA,gHAAgH;AAChH,wBAAsB,mBAAmB,CACvC,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE;IACP,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,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,CAkCf"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
2
|
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
-
import { CollectionBusyError, CollectionError,
|
|
3
|
+
import { CollectionBusyError, CollectionError, collectPeople, errorMessage, } from "@lhremote/core";
|
|
4
4
|
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#collect-people | collect-people} CLI command. */
|
|
5
5
|
export async function handleCollectPeople(campaignId, sourceUrl, options) {
|
|
6
6
|
try {
|
|
@@ -11,7 +11,7 @@ export async function handleCollectPeople(campaignId, sourceUrl, options) {
|
|
|
11
11
|
...(options.maxPages !== undefined && { maxPages: options.maxPages }),
|
|
12
12
|
...(options.pageSize !== undefined && { pageSize: options.pageSize }),
|
|
13
13
|
...(options.sourceType !== undefined && { sourceType: options.sourceType }),
|
|
14
|
-
cdpPort: options.cdpPort
|
|
14
|
+
cdpPort: options.cdpPort,
|
|
15
15
|
...(options.cdpHost !== undefined && { cdpHost: options.cdpHost }),
|
|
16
16
|
...(options.allowRemote !== undefined && { allowRemote: options.allowRemote }),
|
|
17
17
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"collect-people.js","sourceRoot":"","sources":["../../src/handlers/collect-people.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,mBAAmB,EACnB,eAAe,EACf,
|
|
1
|
+
{"version":3,"file":"collect-people.js","sourceRoot":"","sources":["../../src/handlers/collect-people.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,mBAAmB,EACnB,eAAe,EACf,aAAa,EACb,YAAY,GACb,MAAM,gBAAgB,CAAC;AAExB,gHAAgH;AAChH,MAAM,CAAC,KAAK,UAAU,mBAAmB,CACvC,UAAkB,EAClB,SAAiB,EACjB,OASC;IAED,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC;YACjC,UAAU;YACV,SAAS;YACT,GAAG,CAAC,OAAO,CAAC,KAAK,KAAK,SAAS,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,CAAC;YAC5D,GAAG,CAAC,OAAO,CAAC,QAAQ,KAAK,SAAS,IAAI,EAAE,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrE,GAAG,CAAC,OAAO,CAAC,QAAQ,KAAK,SAAS,IAAI,EAAE,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrE,GAAG,CAAC,OAAO,CAAC,UAAU,KAAK,SAAS,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC,UAAU,EAAE,CAAC;YAC3E,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,GAAG,CAAC,OAAO,CAAC,OAAO,KAAK,SAAS,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC;YAClE,GAAG,CAAC,OAAO,CAAC,WAAW,KAAK,SAAS,IAAI,EAAE,WAAW,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC;SAC/E,CAAC,CAAC;QAEH,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;QAC/D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,8BAA8B,MAAM,CAAC,UAAU,mBAAmB,MAAM,CAAC,UAAU,CAAC,KAAK,CAC1F,CAAC;QACJ,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,KAAK,YAAY,mBAAmB,EAAE,CAAC;YACzC,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,6CAA6C,KAAK,CAAC,WAAW,MAAM,CACrE,CAAC;QACJ,CAAC;aAAM,IAAI,KAAK,YAAY,eAAe,EAAE,CAAC;YAC5C,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;IACvB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#comment-on-post | comment-on-post} CLI command. */
|
|
2
|
+
export declare function handleCommentOnPost(options: {
|
|
3
|
+
url: string;
|
|
4
|
+
text: string;
|
|
5
|
+
cdpPort?: number;
|
|
6
|
+
cdpHost?: string;
|
|
7
|
+
allowRemote?: boolean;
|
|
8
|
+
json?: boolean;
|
|
9
|
+
}): Promise<void>;
|
|
10
|
+
//# sourceMappingURL=comment-on-post.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"comment-on-post.d.ts","sourceRoot":"","sources":["../../src/handlers/comment-on-post.ts"],"names":[],"mappings":"AAUA,kHAAkH;AAClH,wBAAsB,mBAAmB,CAAC,OAAO,EAAE;IACjD,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,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+BhB"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { BudgetExceededError, errorMessage, commentOnPost, } from "@lhremote/core";
|
|
4
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#comment-on-post | comment-on-post} CLI command. */
|
|
5
|
+
export async function handleCommentOnPost(options) {
|
|
6
|
+
process.stderr.write("Posting comment...\n");
|
|
7
|
+
let result;
|
|
8
|
+
try {
|
|
9
|
+
result = await commentOnPost({
|
|
10
|
+
postUrl: options.url,
|
|
11
|
+
text: options.text,
|
|
12
|
+
cdpPort: options.cdpPort,
|
|
13
|
+
cdpHost: options.cdpHost,
|
|
14
|
+
allowRemote: options.allowRemote,
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
if (error instanceof BudgetExceededError) {
|
|
19
|
+
process.stderr.write(`${error.message}\n`);
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
const message = errorMessage(error);
|
|
23
|
+
process.stderr.write(`${message}\n`);
|
|
24
|
+
}
|
|
25
|
+
process.exitCode = 1;
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
process.stderr.write("Done.\n");
|
|
29
|
+
if (options.json) {
|
|
30
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
process.stdout.write(`Comment posted on ${result.postUrl}\n`);
|
|
34
|
+
process.stdout.write(`Text: ${result.commentText}\n`);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=comment-on-post.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"comment-on-post.js","sourceRoot":"","sources":["../../src/handlers/comment-on-post.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,mBAAmB,EACnB,YAAY,EACZ,aAAa,GAEd,MAAM,gBAAgB,CAAC;AAExB,kHAAkH;AAClH,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,OAOzC;IACC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC;IAE7C,IAAI,MAA2B,CAAC;IAChC,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,aAAa,CAAC;YAC3B,OAAO,EAAE,OAAO,CAAC,GAAG;YACpB,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,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,mBAAmB,EAAE,CAAC;YACzC,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,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IAEhC,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,CAAC,qBAAqB,MAAM,CAAC,OAAO,IAAI,CAAC,CAAC;QAC9D,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,MAAM,CAAC,WAAW,IAAI,CAAC,CAAC;IACxD,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"comment-on-post.test.d.ts","sourceRoot":"","sources":["../../src/handlers/comment-on-post.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,75 @@
|
|
|
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 { ...actual, commentOnPost: vi.fn() };
|
|
7
|
+
});
|
|
8
|
+
import { BudgetExceededError, commentOnPost, } from "@lhremote/core";
|
|
9
|
+
import { handleCommentOnPost } from "./comment-on-post.js";
|
|
10
|
+
import { getStderr, getStdout } from "./testing/mock-helpers.js";
|
|
11
|
+
const MOCK_RESULT = {
|
|
12
|
+
success: true,
|
|
13
|
+
postUrl: "https://www.linkedin.com/feed/update/urn:li:activity:123/",
|
|
14
|
+
commentText: "Great post!",
|
|
15
|
+
};
|
|
16
|
+
describe("handleCommentOnPost", () => {
|
|
17
|
+
const originalExitCode = process.exitCode;
|
|
18
|
+
let stdoutSpy;
|
|
19
|
+
let stderrSpy;
|
|
20
|
+
beforeEach(() => {
|
|
21
|
+
process.exitCode = undefined;
|
|
22
|
+
vi.clearAllMocks();
|
|
23
|
+
stdoutSpy = vi.spyOn(process.stdout, "write").mockReturnValue(true);
|
|
24
|
+
stderrSpy = vi.spyOn(process.stderr, "write").mockReturnValue(true);
|
|
25
|
+
});
|
|
26
|
+
afterEach(() => {
|
|
27
|
+
process.exitCode = originalExitCode;
|
|
28
|
+
vi.restoreAllMocks();
|
|
29
|
+
});
|
|
30
|
+
it("prints human-readable output on success", async () => {
|
|
31
|
+
vi.mocked(commentOnPost).mockResolvedValue(MOCK_RESULT);
|
|
32
|
+
await handleCommentOnPost({
|
|
33
|
+
url: "https://www.linkedin.com/feed/update/urn:li:activity:123/",
|
|
34
|
+
text: "Great post!",
|
|
35
|
+
});
|
|
36
|
+
expect(process.exitCode).toBeUndefined();
|
|
37
|
+
const stderr = getStderr(stderrSpy);
|
|
38
|
+
expect(stderr).toContain("Posting comment...");
|
|
39
|
+
expect(stderr).toContain("Done.");
|
|
40
|
+
const stdout = getStdout(stdoutSpy);
|
|
41
|
+
expect(stdout).toContain("https://www.linkedin.com/feed/update/urn:li:activity:123/");
|
|
42
|
+
expect(stdout).toContain("Great post!");
|
|
43
|
+
});
|
|
44
|
+
it("prints JSON with --json", async () => {
|
|
45
|
+
vi.mocked(commentOnPost).mockResolvedValue(MOCK_RESULT);
|
|
46
|
+
await handleCommentOnPost({
|
|
47
|
+
url: "https://www.linkedin.com/feed/update/urn:li:activity:123/",
|
|
48
|
+
text: "Great post!",
|
|
49
|
+
json: true,
|
|
50
|
+
});
|
|
51
|
+
expect(process.exitCode).toBeUndefined();
|
|
52
|
+
const output = JSON.parse(getStdout(stdoutSpy));
|
|
53
|
+
expect(output.postUrl).toBe("https://www.linkedin.com/feed/update/urn:li:activity:123/");
|
|
54
|
+
expect(output.commentText).toBe("Great post!");
|
|
55
|
+
});
|
|
56
|
+
it("handles BudgetExceededError", async () => {
|
|
57
|
+
vi.mocked(commentOnPost).mockRejectedValue(new BudgetExceededError("PostComment", 10, 10));
|
|
58
|
+
await handleCommentOnPost({
|
|
59
|
+
url: "https://www.linkedin.com/feed/update/urn:li:activity:123/",
|
|
60
|
+
text: "Great post!",
|
|
61
|
+
});
|
|
62
|
+
expect(process.exitCode).toBe(1);
|
|
63
|
+
expect(getStderr(stderrSpy)).toContain("PostComment");
|
|
64
|
+
});
|
|
65
|
+
it("sets exitCode on generic error", async () => {
|
|
66
|
+
vi.mocked(commentOnPost).mockRejectedValue(new Error("connection refused"));
|
|
67
|
+
await handleCommentOnPost({
|
|
68
|
+
url: "https://www.linkedin.com/feed/update/urn:li:activity:123/",
|
|
69
|
+
text: "Great post!",
|
|
70
|
+
});
|
|
71
|
+
expect(process.exitCode).toBe(1);
|
|
72
|
+
expect(getStderr(stderrSpy)).toContain("connection refused");
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
//# sourceMappingURL=comment-on-post.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"comment-on-post.test.js","sourceRoot":"","sources":["../../src/handlers/comment-on-post.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-collection.d.ts","sourceRoot":"","sources":["../../src/handlers/create-collection.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"create-collection.d.ts","sourceRoot":"","sources":["../../src/handlers/create-collection.ts"],"names":[],"mappings":"AAQA,sHAAsH;AACtH,wBAAsB,sBAAsB,CAC1C,IAAI,EAAE,MAAM,EACZ,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,CAqBf"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
2
|
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
-
import {
|
|
3
|
+
import { createCollection, errorMessage, } from "@lhremote/core";
|
|
4
4
|
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#create-collection | create-collection} CLI command. */
|
|
5
5
|
export async function handleCreateCollection(name, options) {
|
|
6
6
|
try {
|
|
7
7
|
const result = await createCollection({
|
|
8
8
|
name,
|
|
9
|
-
cdpPort: options.cdpPort
|
|
9
|
+
cdpPort: options.cdpPort,
|
|
10
10
|
cdpHost: options.cdpHost,
|
|
11
11
|
allowRemote: options.allowRemote,
|
|
12
12
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-collection.js","sourceRoot":"","sources":["../../src/handlers/create-collection.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,gBAAgB,EAChB,
|
|
1
|
+
{"version":3,"file":"create-collection.js","sourceRoot":"","sources":["../../src/handlers/create-collection.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,gBAAgB,EAChB,YAAY,GACb,MAAM,gBAAgB,CAAC;AAExB,sHAAsH;AACtH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAC1C,IAAY,EACZ,OAKC;IAED,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC;YACpC,IAAI;YACJ,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC,CAAC;QAEH,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;QAC/D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,uBAAuB,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,MAAM,CAAC,IAAI,MAAM,CACzE,CAAC;QACJ,CAAC;IACH,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;IACvB,CAAC;AACH,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-collection.d.ts","sourceRoot":"","sources":["../../src/handlers/delete-collection.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"delete-collection.d.ts","sourceRoot":"","sources":["../../src/handlers/delete-collection.ts"],"names":[],"mappings":"AAQA,sHAAsH;AACtH,wBAAsB,sBAAsB,CAC1C,YAAY,EAAE,MAAM,EACpB,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,CA2Bf"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
2
|
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
-
import {
|
|
3
|
+
import { deleteCollection, errorMessage, } from "@lhremote/core";
|
|
4
4
|
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#delete-collection | delete-collection} CLI command. */
|
|
5
5
|
export async function handleDeleteCollection(collectionId, options) {
|
|
6
6
|
try {
|
|
7
7
|
const result = await deleteCollection({
|
|
8
8
|
collectionId,
|
|
9
|
-
cdpPort: options.cdpPort
|
|
9
|
+
cdpPort: options.cdpPort,
|
|
10
10
|
cdpHost: options.cdpHost,
|
|
11
11
|
allowRemote: options.allowRemote,
|
|
12
12
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-collection.js","sourceRoot":"","sources":["../../src/handlers/delete-collection.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,gBAAgB,EAChB,
|
|
1
|
+
{"version":3,"file":"delete-collection.js","sourceRoot":"","sources":["../../src/handlers/delete-collection.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,gBAAgB,EAChB,YAAY,GACb,MAAM,gBAAgB,CAAC;AAExB,sHAAsH;AACtH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAC1C,YAAoB,EACpB,OAKC;IAED,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC;YACpC,YAAY;YACZ,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC,CAAC;QAEH,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;QAC/D,CAAC;aAAM,CAAC;YACN,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;gBACnB,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,uBAAuB,MAAM,CAAC,YAAY,CAAC,KAAK,CACjD,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,eAAe,MAAM,CAAC,YAAY,CAAC,eAAe,CACnD,CAAC;YACJ,CAAC;QACH,CAAC;IACH,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;IACvB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#dismiss-errors | dismiss-errors} CLI command. */
|
|
2
|
+
export declare function handleDismissErrors(options: {
|
|
3
|
+
cdpPort?: number;
|
|
4
|
+
cdpHost?: string;
|
|
5
|
+
allowRemote?: boolean;
|
|
6
|
+
json?: boolean;
|
|
7
|
+
}): Promise<void>;
|
|
8
|
+
//# sourceMappingURL=dismiss-errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dismiss-errors.d.ts","sourceRoot":"","sources":["../../src/handlers/dismiss-errors.ts"],"names":[],"mappings":"AAKA,gHAAgH;AAChH,wBAAsB,mBAAmB,CAAC,OAAO,EAAE;IACjD,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,CA8BhB"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { dismissErrors, errorMessage } from "@lhremote/core";
|
|
4
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#dismiss-errors | dismiss-errors} CLI command. */
|
|
5
|
+
export async function handleDismissErrors(options) {
|
|
6
|
+
try {
|
|
7
|
+
const result = await dismissErrors({
|
|
8
|
+
cdpPort: options.cdpPort,
|
|
9
|
+
cdpHost: options.cdpHost,
|
|
10
|
+
allowRemote: options.allowRemote,
|
|
11
|
+
});
|
|
12
|
+
if (options.json) {
|
|
13
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
process.stdout.write(`Account: ${String(result.accountId)}\n`);
|
|
17
|
+
process.stdout.write(`Dismissed: ${String(result.dismissed)}\n`);
|
|
18
|
+
if (result.nonDismissable > 0) {
|
|
19
|
+
process.stdout.write(`Non-dismissable: ${String(result.nonDismissable)}\n`);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
catch (error) {
|
|
23
|
+
const message = errorMessage(error);
|
|
24
|
+
process.stderr.write(`${message}\n`);
|
|
25
|
+
process.exitCode = 1;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=dismiss-errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dismiss-errors.js","sourceRoot":"","sources":["../../src/handlers/dismiss-errors.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE7D,gHAAgH;AAChH,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,OAKzC;IACC,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC;YACjC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC,CAAC;QAEH,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;YAC7D,OAAO;QACT,CAAC;QAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,YAAY,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CACzC,CAAC;QACF,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,cAAc,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAC3C,CAAC;QAEF,IAAI,MAAM,CAAC,cAAc,GAAG,CAAC,EAAE,CAAC;YAC9B,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,oBAAoB,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,CACtD,CAAC;QACJ,CAAC;IACH,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;IACvB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dismiss-errors.test.d.ts","sourceRoot":"","sources":["../../src/handlers/dismiss-errors.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,90 @@
|
|
|
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
|
+
dismissErrors: vi.fn(),
|
|
9
|
+
};
|
|
10
|
+
});
|
|
11
|
+
import { dismissErrors } from "@lhremote/core";
|
|
12
|
+
import { handleDismissErrors } from "./dismiss-errors.js";
|
|
13
|
+
const mockedDismissErrors = vi.mocked(dismissErrors);
|
|
14
|
+
describe("handleDismissErrors", () => {
|
|
15
|
+
const originalExitCode = process.exitCode;
|
|
16
|
+
beforeEach(() => {
|
|
17
|
+
process.exitCode = undefined;
|
|
18
|
+
vi.clearAllMocks();
|
|
19
|
+
});
|
|
20
|
+
afterEach(() => {
|
|
21
|
+
process.exitCode = originalExitCode;
|
|
22
|
+
vi.restoreAllMocks();
|
|
23
|
+
});
|
|
24
|
+
it("prints JSON with --json", async () => {
|
|
25
|
+
const stdoutSpy = vi
|
|
26
|
+
.spyOn(process.stdout, "write")
|
|
27
|
+
.mockReturnValue(true);
|
|
28
|
+
const output = {
|
|
29
|
+
accountId: 1,
|
|
30
|
+
dismissed: 2,
|
|
31
|
+
nonDismissable: 0,
|
|
32
|
+
};
|
|
33
|
+
mockedDismissErrors.mockResolvedValue(output);
|
|
34
|
+
await handleDismissErrors({ json: true });
|
|
35
|
+
expect(process.exitCode).toBeUndefined();
|
|
36
|
+
const text = stdoutSpy.mock.calls
|
|
37
|
+
.map((call) => String(call[0]))
|
|
38
|
+
.join("");
|
|
39
|
+
expect(JSON.parse(text)).toEqual(output);
|
|
40
|
+
});
|
|
41
|
+
it("prints human-friendly output when popups dismissed", async () => {
|
|
42
|
+
const stdoutSpy = vi
|
|
43
|
+
.spyOn(process.stdout, "write")
|
|
44
|
+
.mockReturnValue(true);
|
|
45
|
+
mockedDismissErrors.mockResolvedValue({
|
|
46
|
+
accountId: 1,
|
|
47
|
+
dismissed: 2,
|
|
48
|
+
nonDismissable: 0,
|
|
49
|
+
});
|
|
50
|
+
await handleDismissErrors({});
|
|
51
|
+
expect(process.exitCode).toBeUndefined();
|
|
52
|
+
expect(stdoutSpy).toHaveBeenCalledWith("Account: 1\n");
|
|
53
|
+
expect(stdoutSpy).toHaveBeenCalledWith("Dismissed: 2\n");
|
|
54
|
+
});
|
|
55
|
+
it("prints non-dismissable count when present", async () => {
|
|
56
|
+
const stdoutSpy = vi
|
|
57
|
+
.spyOn(process.stdout, "write")
|
|
58
|
+
.mockReturnValue(true);
|
|
59
|
+
mockedDismissErrors.mockResolvedValue({
|
|
60
|
+
accountId: 1,
|
|
61
|
+
dismissed: 0,
|
|
62
|
+
nonDismissable: 3,
|
|
63
|
+
});
|
|
64
|
+
await handleDismissErrors({});
|
|
65
|
+
expect(stdoutSpy).toHaveBeenCalledWith("Non-dismissable: 3\n");
|
|
66
|
+
});
|
|
67
|
+
it("hides non-dismissable line when zero", async () => {
|
|
68
|
+
const stdoutSpy = vi
|
|
69
|
+
.spyOn(process.stdout, "write")
|
|
70
|
+
.mockReturnValue(true);
|
|
71
|
+
mockedDismissErrors.mockResolvedValue({
|
|
72
|
+
accountId: 1,
|
|
73
|
+
dismissed: 1,
|
|
74
|
+
nonDismissable: 0,
|
|
75
|
+
});
|
|
76
|
+
await handleDismissErrors({});
|
|
77
|
+
const calls = stdoutSpy.mock.calls.map((c) => String(c[0]));
|
|
78
|
+
expect(calls).not.toContain(expect.stringContaining("Non-dismissable"));
|
|
79
|
+
});
|
|
80
|
+
it("sets exitCode 1 on error", async () => {
|
|
81
|
+
const stderrSpy = vi
|
|
82
|
+
.spyOn(process.stderr, "write")
|
|
83
|
+
.mockReturnValue(true);
|
|
84
|
+
mockedDismissErrors.mockRejectedValue(new Error("unexpected"));
|
|
85
|
+
await handleDismissErrors({});
|
|
86
|
+
expect(process.exitCode).toBe(1);
|
|
87
|
+
expect(stderrSpy).toHaveBeenCalledWith("unexpected\n");
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
//# sourceMappingURL=dismiss-errors.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dismiss-errors.test.js","sourceRoot":"","sources":["../../src/handlers/dismiss-errors.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#endorse-skills | endorse-skills} CLI command. */
|
|
2
|
+
export declare function handleEndorseSkills(options: {
|
|
3
|
+
personId?: number;
|
|
4
|
+
url?: string;
|
|
5
|
+
skillNames?: string[];
|
|
6
|
+
limit?: number;
|
|
7
|
+
skipIfNotEndorsable?: boolean;
|
|
8
|
+
keepCampaign?: boolean;
|
|
9
|
+
cdpPort?: number;
|
|
10
|
+
cdpHost?: string;
|
|
11
|
+
allowRemote?: boolean;
|
|
12
|
+
json?: boolean;
|
|
13
|
+
}): Promise<void>;
|
|
14
|
+
//# sourceMappingURL=endorse-skills.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"endorse-skills.d.ts","sourceRoot":"","sources":["../../src/handlers/endorse-skills.ts"],"names":[],"mappings":"AAWA,gHAAgH;AAChH,wBAAsB,mBAAmB,CAAC,OAAO,EAAE;IACjD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,YAAY,CAAC,EAAE,OAAO,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,GAAG,OAAO,CAAC,IAAI,CAAC,CAuChB"}
|