@lhremote/cli 0.6.0 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -4
- package/dist/handlers/build-url.d.ts +17 -0
- package/dist/handlers/build-url.d.ts.map +1 -0
- package/dist/handlers/build-url.js +90 -0
- package/dist/handlers/build-url.js.map +1 -0
- 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 +3 -1
- 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/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/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/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 +12 -0
- 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 +62 -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 +126 -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.d.ts +10 -0
- package/dist/handlers/get-post.d.ts.map +1 -0
- package/dist/handlers/get-post.js +66 -0
- package/dist/handlers/get-post.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 +56 -0
- package/dist/handlers/get-profile-activity.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/index.d.ts +23 -0
- package/dist/handlers/index.d.ts.map +1 -1
- package/dist/handlers/index.js +23 -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-reference-data.d.ts +5 -0
- package/dist/handlers/list-reference-data.d.ts.map +1 -0
- package/dist/handlers/list-reference-data.js +33 -0
- package/dist/handlers/list-reference-data.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/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/resolve-entity.d.ts +9 -0
- package/dist/handlers/resolve-entity.d.ts.map +1 -0
- package/dist/handlers/resolve-entity.js +48 -0
- package/dist/handlers/resolve-entity.js.map +1 -0
- 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 +61 -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 +105 -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/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 +279 -2
- package/dist/program.js.map +1 -1
- package/dist/program.test.js +24 -1
- package/dist/program.test.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1,65 @@
|
|
|
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, getThrottleStatus: vi.fn() };
|
|
7
|
+
});
|
|
8
|
+
import { getThrottleStatus } from "@lhremote/core";
|
|
9
|
+
import { handleGetThrottleStatus } from "./get-throttle-status.js";
|
|
10
|
+
describe("handleGetThrottleStatus", () => {
|
|
11
|
+
let stdoutChunks;
|
|
12
|
+
let stderrChunks;
|
|
13
|
+
const originalExitCode = process.exitCode;
|
|
14
|
+
beforeEach(() => {
|
|
15
|
+
vi.clearAllMocks();
|
|
16
|
+
stdoutChunks = [];
|
|
17
|
+
stderrChunks = [];
|
|
18
|
+
vi.spyOn(process.stdout, "write").mockImplementation((chunk) => {
|
|
19
|
+
stdoutChunks.push(String(chunk));
|
|
20
|
+
return true;
|
|
21
|
+
});
|
|
22
|
+
vi.spyOn(process.stderr, "write").mockImplementation((chunk) => {
|
|
23
|
+
stderrChunks.push(String(chunk));
|
|
24
|
+
return true;
|
|
25
|
+
});
|
|
26
|
+
process.exitCode = undefined;
|
|
27
|
+
});
|
|
28
|
+
afterEach(() => {
|
|
29
|
+
vi.restoreAllMocks();
|
|
30
|
+
process.exitCode = originalExitCode;
|
|
31
|
+
});
|
|
32
|
+
it("outputs JSON when --json flag is set and not throttled", async () => {
|
|
33
|
+
vi.mocked(getThrottleStatus).mockResolvedValue({ throttled: false, since: null });
|
|
34
|
+
await handleGetThrottleStatus({ json: true });
|
|
35
|
+
const output = JSON.parse(stdoutChunks.join(""));
|
|
36
|
+
expect(output).toEqual({ throttled: false, since: null });
|
|
37
|
+
});
|
|
38
|
+
it("outputs JSON when --json flag is set and throttled", async () => {
|
|
39
|
+
const since = "2026-03-21T10:00:00.000Z";
|
|
40
|
+
vi.mocked(getThrottleStatus).mockResolvedValue({ throttled: true, since });
|
|
41
|
+
await handleGetThrottleStatus({ json: true });
|
|
42
|
+
const output = JSON.parse(stdoutChunks.join(""));
|
|
43
|
+
expect(output).toEqual({ throttled: true, since });
|
|
44
|
+
});
|
|
45
|
+
it("outputs human-readable text when not throttled", async () => {
|
|
46
|
+
vi.mocked(getThrottleStatus).mockResolvedValue({ throttled: false, since: null });
|
|
47
|
+
await handleGetThrottleStatus({});
|
|
48
|
+
expect(stdoutChunks.join("")).toContain("Not throttled.");
|
|
49
|
+
});
|
|
50
|
+
it("outputs human-readable text when throttled", async () => {
|
|
51
|
+
const since = "2026-03-21T10:00:00.000Z";
|
|
52
|
+
vi.mocked(getThrottleStatus).mockResolvedValue({ throttled: true, since });
|
|
53
|
+
await handleGetThrottleStatus({});
|
|
54
|
+
const output = stdoutChunks.join("");
|
|
55
|
+
expect(output).toContain("THROTTLED");
|
|
56
|
+
expect(output).toContain(since);
|
|
57
|
+
});
|
|
58
|
+
it("sets exit code 1 on error", async () => {
|
|
59
|
+
vi.mocked(getThrottleStatus).mockRejectedValue(new Error("instance not running"));
|
|
60
|
+
await handleGetThrottleStatus({});
|
|
61
|
+
expect(process.exitCode).toBe(1);
|
|
62
|
+
expect(stderrChunks.join("")).toContain("instance not running");
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
//# sourceMappingURL=get-throttle-status.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-throttle-status.test.js","sourceRoot":"","sources":["../../src/handlers/get-throttle-status.test.ts"],"names":[],"mappings":"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"}
|
package/dist/handlers/index.d.ts
CHANGED
|
@@ -2,6 +2,7 @@ export { handleAddPeopleToCollection } from "./add-people-to-collection.js";
|
|
|
2
2
|
export { handleCampaignAddAction } from "./campaign-add-action.js";
|
|
3
3
|
export { handleCampaignCreate } from "./campaign-create.js";
|
|
4
4
|
export { handleCampaignDelete } from "./campaign-delete.js";
|
|
5
|
+
export { handleCampaignErase } from "./campaign-erase.js";
|
|
5
6
|
export { handleCampaignExcludeAdd } from "./campaign-exclude-add.js";
|
|
6
7
|
export { handleCampaignExcludeList } from "./campaign-exclude-list.js";
|
|
7
8
|
export { handleCampaignExcludeRemove } from "./campaign-exclude-remove.js";
|
|
@@ -23,23 +24,45 @@ export { handleCampaignUpdate } from "./campaign-update.js";
|
|
|
23
24
|
export { handleCampaignUpdateAction } from "./campaign-update-action.js";
|
|
24
25
|
export { handleCreateCollection } from "./create-collection.js";
|
|
25
26
|
export { handleDeleteCollection } from "./delete-collection.js";
|
|
27
|
+
export { handleDismissErrors } from "./dismiss-errors.js";
|
|
26
28
|
export { handleCheckReplies } from "./check-replies.js";
|
|
29
|
+
export { handleCommentOnPost } from "./comment-on-post.js";
|
|
30
|
+
export { handleEndorseSkills } from "./endorse-skills.js";
|
|
31
|
+
export { handleEnrichProfile } from "./enrich-profile.js";
|
|
32
|
+
export { handleFollowPerson } from "./follow-person.js";
|
|
33
|
+
export { handleLikePersonPosts } from "./like-person-posts.js";
|
|
34
|
+
export { handleMessagePerson } from "./message-person.js";
|
|
35
|
+
export { handleRemoveConnection } from "./remove-connection.js";
|
|
36
|
+
export { handleSendInmail } from "./send-inmail.js";
|
|
37
|
+
export { handleSendInvite } from "./send-invite.js";
|
|
27
38
|
export { handleCollectPeople } from "./collect-people.js";
|
|
28
39
|
export { handleDescribeActions } from "./describe-actions.js";
|
|
29
40
|
export { handleCheckStatus } from "./check-status.js";
|
|
30
41
|
export { handleFindApp } from "./find-app.js";
|
|
42
|
+
export { handleGetActionBudget } from "./get-action-budget.js";
|
|
31
43
|
export { handleGetErrors } from "./get-errors.js";
|
|
44
|
+
export { handleGetFeed } from "./get-feed.js";
|
|
45
|
+
export { handleGetPost } from "./get-post.js";
|
|
46
|
+
export { handleGetPostStats } from "./get-post-stats.js";
|
|
47
|
+
export { handleGetProfileActivity } from "./get-profile-activity.js";
|
|
48
|
+
export { handleGetThrottleStatus } from "./get-throttle-status.js";
|
|
32
49
|
export { handleImportPeopleFromCollection } from "./import-people-from-collection.js";
|
|
33
50
|
export { handleQueryMessages } from "./query-messages.js";
|
|
34
51
|
export { handleQueryProfile } from "./query-profile.js";
|
|
35
52
|
export { handleQueryProfiles } from "./query-profiles.js";
|
|
36
53
|
export { handleQueryProfilesBulk } from "./query-profiles-bulk.js";
|
|
37
54
|
export { handleScrapeMessagingHistory } from "./scrape-messaging-history.js";
|
|
55
|
+
export { handleSearchPosts } from "./search-posts.js";
|
|
38
56
|
export { handleListCollections } from "./list-collections.js";
|
|
39
57
|
export { handleLaunchApp } from "./launch-app.js";
|
|
40
58
|
export { handleListAccounts } from "./list-accounts.js";
|
|
41
59
|
export { handleRemovePeopleFromCollection } from "./remove-people-from-collection.js";
|
|
42
60
|
export { handleQuitApp } from "./quit-app.js";
|
|
61
|
+
export { handleReactToPost } from "./react-to-post.js";
|
|
43
62
|
export { handleStartInstance } from "./start-instance.js";
|
|
44
63
|
export { handleStopInstance } from "./stop-instance.js";
|
|
64
|
+
export { handleVisitProfile } from "./visit-profile.js";
|
|
65
|
+
export { handleBuildUrl } from "./build-url.js";
|
|
66
|
+
export { handleResolveEntity } from "./resolve-entity.js";
|
|
67
|
+
export { handleListReferenceData } from "./list-reference-data.js";
|
|
45
68
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/handlers/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,EAAE,2BAA2B,EAAE,MAAM,8BAA8B,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AACzE,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AACzE,OAAO,EAAE,4BAA4B,EAAE,MAAM,+BAA+B,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,0BAA0B,EAAE,MAAM,8BAA8B,CAAC;AAC1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AACzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,gCAAgC,EAAE,MAAM,oCAAoC,CAAC;AACtF,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,4BAA4B,EAAE,MAAM,+BAA+B,CAAC;AAC7E,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,gCAAgC,EAAE,MAAM,oCAAoC,CAAC;AACtF,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/handlers/index.ts"],"names":[],"mappings":"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"}
|
package/dist/handlers/index.js
CHANGED
|
@@ -4,6 +4,7 @@ export { handleAddPeopleToCollection } from "./add-people-to-collection.js";
|
|
|
4
4
|
export { handleCampaignAddAction } from "./campaign-add-action.js";
|
|
5
5
|
export { handleCampaignCreate } from "./campaign-create.js";
|
|
6
6
|
export { handleCampaignDelete } from "./campaign-delete.js";
|
|
7
|
+
export { handleCampaignErase } from "./campaign-erase.js";
|
|
7
8
|
export { handleCampaignExcludeAdd } from "./campaign-exclude-add.js";
|
|
8
9
|
export { handleCampaignExcludeList } from "./campaign-exclude-list.js";
|
|
9
10
|
export { handleCampaignExcludeRemove } from "./campaign-exclude-remove.js";
|
|
@@ -25,23 +26,45 @@ export { handleCampaignUpdate } from "./campaign-update.js";
|
|
|
25
26
|
export { handleCampaignUpdateAction } from "./campaign-update-action.js";
|
|
26
27
|
export { handleCreateCollection } from "./create-collection.js";
|
|
27
28
|
export { handleDeleteCollection } from "./delete-collection.js";
|
|
29
|
+
export { handleDismissErrors } from "./dismiss-errors.js";
|
|
28
30
|
export { handleCheckReplies } from "./check-replies.js";
|
|
31
|
+
export { handleCommentOnPost } from "./comment-on-post.js";
|
|
32
|
+
export { handleEndorseSkills } from "./endorse-skills.js";
|
|
33
|
+
export { handleEnrichProfile } from "./enrich-profile.js";
|
|
34
|
+
export { handleFollowPerson } from "./follow-person.js";
|
|
35
|
+
export { handleLikePersonPosts } from "./like-person-posts.js";
|
|
36
|
+
export { handleMessagePerson } from "./message-person.js";
|
|
37
|
+
export { handleRemoveConnection } from "./remove-connection.js";
|
|
38
|
+
export { handleSendInmail } from "./send-inmail.js";
|
|
39
|
+
export { handleSendInvite } from "./send-invite.js";
|
|
29
40
|
export { handleCollectPeople } from "./collect-people.js";
|
|
30
41
|
export { handleDescribeActions } from "./describe-actions.js";
|
|
31
42
|
export { handleCheckStatus } from "./check-status.js";
|
|
32
43
|
export { handleFindApp } from "./find-app.js";
|
|
44
|
+
export { handleGetActionBudget } from "./get-action-budget.js";
|
|
33
45
|
export { handleGetErrors } from "./get-errors.js";
|
|
46
|
+
export { handleGetFeed } from "./get-feed.js";
|
|
47
|
+
export { handleGetPost } from "./get-post.js";
|
|
48
|
+
export { handleGetPostStats } from "./get-post-stats.js";
|
|
49
|
+
export { handleGetProfileActivity } from "./get-profile-activity.js";
|
|
50
|
+
export { handleGetThrottleStatus } from "./get-throttle-status.js";
|
|
34
51
|
export { handleImportPeopleFromCollection } from "./import-people-from-collection.js";
|
|
35
52
|
export { handleQueryMessages } from "./query-messages.js";
|
|
36
53
|
export { handleQueryProfile } from "./query-profile.js";
|
|
37
54
|
export { handleQueryProfiles } from "./query-profiles.js";
|
|
38
55
|
export { handleQueryProfilesBulk } from "./query-profiles-bulk.js";
|
|
39
56
|
export { handleScrapeMessagingHistory } from "./scrape-messaging-history.js";
|
|
57
|
+
export { handleSearchPosts } from "./search-posts.js";
|
|
40
58
|
export { handleListCollections } from "./list-collections.js";
|
|
41
59
|
export { handleLaunchApp } from "./launch-app.js";
|
|
42
60
|
export { handleListAccounts } from "./list-accounts.js";
|
|
43
61
|
export { handleRemovePeopleFromCollection } from "./remove-people-from-collection.js";
|
|
44
62
|
export { handleQuitApp } from "./quit-app.js";
|
|
63
|
+
export { handleReactToPost } from "./react-to-post.js";
|
|
45
64
|
export { handleStartInstance } from "./start-instance.js";
|
|
46
65
|
export { handleStopInstance } from "./stop-instance.js";
|
|
66
|
+
export { handleVisitProfile } from "./visit-profile.js";
|
|
67
|
+
export { handleBuildUrl } from "./build-url.js";
|
|
68
|
+
export { handleResolveEntity } from "./resolve-entity.js";
|
|
69
|
+
export { handleListReferenceData } from "./list-reference-data.js";
|
|
47
70
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/handlers/index.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,EAAE,2BAA2B,EAAE,MAAM,8BAA8B,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AACzE,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AACzE,OAAO,EAAE,4BAA4B,EAAE,MAAM,+BAA+B,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,0BAA0B,EAAE,MAAM,8BAA8B,CAAC;AAC1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AACzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,gCAAgC,EAAE,MAAM,oCAAoC,CAAC;AACtF,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,4BAA4B,EAAE,MAAM,+BAA+B,CAAC;AAC7E,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,gCAAgC,EAAE,MAAM,oCAAoC,CAAC;AACtF,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/handlers/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#like-person-posts | like-person-posts} CLI command. */
|
|
2
|
+
export declare function handleLikePersonPosts(options: {
|
|
3
|
+
personId?: number;
|
|
4
|
+
url?: string;
|
|
5
|
+
numberOfArticles?: number;
|
|
6
|
+
numberOfPosts?: number;
|
|
7
|
+
maxAgeOfArticles?: number;
|
|
8
|
+
maxAgeOfPosts?: number;
|
|
9
|
+
shouldAddComment?: boolean;
|
|
10
|
+
messageTemplate?: string;
|
|
11
|
+
skipIfNotLiked?: boolean;
|
|
12
|
+
keepCampaign?: boolean;
|
|
13
|
+
cdpPort?: number;
|
|
14
|
+
cdpHost?: string;
|
|
15
|
+
allowRemote?: boolean;
|
|
16
|
+
json?: boolean;
|
|
17
|
+
}): Promise<void>;
|
|
18
|
+
//# sourceMappingURL=like-person-posts.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"like-person-posts.d.ts","sourceRoot":"","sources":["../../src/handlers/like-person-posts.ts"],"names":[],"mappings":"AAYA,sHAAsH;AACtH,wBAAsB,qBAAqB,CAAC,OAAO,EAAE;IACnD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,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,CAsDhB"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { DEFAULT_CDP_PORT, errorMessage, likePersonPosts, CampaignExecutionError, CampaignTimeoutError, } from "@lhremote/core";
|
|
4
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#like-person-posts | like-person-posts} CLI command. */
|
|
5
|
+
export async function handleLikePersonPosts(options) {
|
|
6
|
+
if ((options.personId == null) === (options.url == null)) {
|
|
7
|
+
process.stderr.write("Exactly one of --person-id or --url must be provided.\n");
|
|
8
|
+
process.exitCode = 1;
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
11
|
+
let parsedMessageTemplate;
|
|
12
|
+
if (options.messageTemplate) {
|
|
13
|
+
try {
|
|
14
|
+
parsedMessageTemplate = JSON.parse(options.messageTemplate);
|
|
15
|
+
}
|
|
16
|
+
catch {
|
|
17
|
+
process.stderr.write("Invalid JSON in --message-template.\n");
|
|
18
|
+
process.exitCode = 1;
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
process.stderr.write("Liking person posts...\n");
|
|
23
|
+
let result;
|
|
24
|
+
try {
|
|
25
|
+
result = await likePersonPosts({
|
|
26
|
+
personId: options.personId,
|
|
27
|
+
url: options.url,
|
|
28
|
+
numberOfArticles: options.numberOfArticles,
|
|
29
|
+
numberOfPosts: options.numberOfPosts,
|
|
30
|
+
maxAgeOfArticles: options.maxAgeOfArticles,
|
|
31
|
+
maxAgeOfPosts: options.maxAgeOfPosts,
|
|
32
|
+
shouldAddComment: options.shouldAddComment,
|
|
33
|
+
messageTemplate: parsedMessageTemplate,
|
|
34
|
+
skipIfNotLiked: options.skipIfNotLiked,
|
|
35
|
+
keepCampaign: options.keepCampaign,
|
|
36
|
+
cdpPort: options.cdpPort ?? DEFAULT_CDP_PORT,
|
|
37
|
+
cdpHost: options.cdpHost,
|
|
38
|
+
allowRemote: options.allowRemote,
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
catch (error) {
|
|
42
|
+
if (error instanceof CampaignExecutionError || error instanceof CampaignTimeoutError) {
|
|
43
|
+
process.stderr.write(`${error.message}\n`);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
process.stderr.write(`${errorMessage(error)}\n`);
|
|
47
|
+
}
|
|
48
|
+
process.exitCode = 1;
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
process.stderr.write("Done.\n");
|
|
52
|
+
if (options.json) {
|
|
53
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
process.stdout.write(`Like posts ${result.success ? "succeeded" : "failed"} (person #${String(result.personId)})\n`);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=like-person-posts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"like-person-posts.js","sourceRoot":"","sources":["../../src/handlers/like-person-posts.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,gBAAgB,EAChB,YAAY,EACZ,eAAe,EAEf,sBAAsB,EACtB,oBAAoB,GACrB,MAAM,gBAAgB,CAAC;AAExB,sHAAsH;AACtH,MAAM,CAAC,KAAK,UAAU,qBAAqB,CAAC,OAe3C;IACC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,EAAE,CAAC;QACzD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,yDAAyD,CAAC,CAAC;QAChF,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,IAAI,qBAA0D,CAAC;IAC/D,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;QAC5B,IAAI,CAAC;YACH,qBAAqB,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,eAAe,CAA4B,CAAC;QACzF,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,uCAAuC,CAAC,CAAC;YAC9D,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;YACrB,OAAO;QACT,CAAC;IACH,CAAC;IAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;IAEjD,IAAI,MAA6B,CAAC;IAClC,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,eAAe,CAAC;YAC7B,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;YAC1C,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;YAC1C,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;YAC1C,eAAe,EAAE,qBAAqB;YACtC,cAAc,EAAE,OAAO,CAAC,cAAc;YACtC,YAAY,EAAE,OAAO,CAAC,YAAY;YAClC,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,sBAAsB,IAAI,KAAK,YAAY,oBAAoB,EAAE,CAAC;YACrF,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,OAAO,IAAI,CAAC,CAAC;QAC7C,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACnD,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,cAAc,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,QAAQ,aAAa,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"like-person-posts.test.d.ts","sourceRoot":"","sources":["../../src/handlers/like-person-posts.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,71 @@
|
|
|
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
|
+
likePersonPosts: vi.fn(),
|
|
9
|
+
};
|
|
10
|
+
});
|
|
11
|
+
import { CampaignExecutionError, CampaignTimeoutError, likePersonPosts, } from "@lhremote/core";
|
|
12
|
+
import { handleLikePersonPosts } from "./like-person-posts.js";
|
|
13
|
+
import { getStderr, getStdout } from "./testing/mock-helpers.js";
|
|
14
|
+
const MOCK_RESULT = {
|
|
15
|
+
success: true,
|
|
16
|
+
personId: 100,
|
|
17
|
+
results: [{ id: 1, actionVersionId: 1, personId: 100, result: 1, platform: null, createdAt: "2026-01-01T00:00:00Z", profile: null }],
|
|
18
|
+
};
|
|
19
|
+
describe("handleLikePersonPosts", () => {
|
|
20
|
+
let stdoutSpy;
|
|
21
|
+
let stderrSpy;
|
|
22
|
+
beforeEach(() => {
|
|
23
|
+
vi.clearAllMocks();
|
|
24
|
+
process.exitCode = undefined;
|
|
25
|
+
stdoutSpy = vi.spyOn(process.stdout, "write").mockReturnValue(true);
|
|
26
|
+
stderrSpy = vi.spyOn(process.stderr, "write").mockReturnValue(true);
|
|
27
|
+
});
|
|
28
|
+
afterEach(() => {
|
|
29
|
+
vi.restoreAllMocks();
|
|
30
|
+
});
|
|
31
|
+
it("outputs JSON result on success", async () => {
|
|
32
|
+
vi.mocked(likePersonPosts).mockResolvedValue(MOCK_RESULT);
|
|
33
|
+
await handleLikePersonPosts({ personId: 100, numberOfPosts: 3, json: true });
|
|
34
|
+
expect(process.exitCode).toBeUndefined();
|
|
35
|
+
const stdout = getStdout(stdoutSpy);
|
|
36
|
+
const parsed = JSON.parse(stdout);
|
|
37
|
+
expect(parsed.success).toBe(true);
|
|
38
|
+
expect(parsed.personId).toBe(100);
|
|
39
|
+
});
|
|
40
|
+
it("outputs human-readable result on success", async () => {
|
|
41
|
+
vi.mocked(likePersonPosts).mockResolvedValue(MOCK_RESULT);
|
|
42
|
+
await handleLikePersonPosts({ personId: 100, numberOfPosts: 3 });
|
|
43
|
+
expect(process.exitCode).toBeUndefined();
|
|
44
|
+
expect(getStdout(stdoutSpy)).toContain("succeeded");
|
|
45
|
+
});
|
|
46
|
+
it("returns error when neither personId nor url provided", async () => {
|
|
47
|
+
await handleLikePersonPosts({});
|
|
48
|
+
expect(process.exitCode).toBe(1);
|
|
49
|
+
expect(getStderr(stderrSpy)).toContain("Exactly one of --person-id or --url");
|
|
50
|
+
expect(likePersonPosts).not.toHaveBeenCalled();
|
|
51
|
+
});
|
|
52
|
+
it("returns error for invalid JSON in messageTemplate", async () => {
|
|
53
|
+
await handleLikePersonPosts({ personId: 100, messageTemplate: "not json" });
|
|
54
|
+
expect(process.exitCode).toBe(1);
|
|
55
|
+
expect(getStderr(stderrSpy)).toContain("Invalid JSON in --message-template");
|
|
56
|
+
expect(likePersonPosts).not.toHaveBeenCalled();
|
|
57
|
+
});
|
|
58
|
+
it("handles CampaignExecutionError", async () => {
|
|
59
|
+
vi.mocked(likePersonPosts).mockRejectedValue(new CampaignExecutionError("Person 100 not found"));
|
|
60
|
+
await handleLikePersonPosts({ personId: 100 });
|
|
61
|
+
expect(process.exitCode).toBe(1);
|
|
62
|
+
expect(getStderr(stderrSpy)).toContain("Person 100 not found");
|
|
63
|
+
});
|
|
64
|
+
it("handles CampaignTimeoutError", async () => {
|
|
65
|
+
vi.mocked(likePersonPosts).mockRejectedValue(new CampaignTimeoutError("Timed out", 42));
|
|
66
|
+
await handleLikePersonPosts({ personId: 100 });
|
|
67
|
+
expect(process.exitCode).toBe(1);
|
|
68
|
+
expect(getStderr(stderrSpy)).toContain("Timed out");
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
//# sourceMappingURL=like-person-posts.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"like-person-posts.test.js","sourceRoot":"","sources":["../../src/handlers/like-person-posts.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#list-reference-data | list-reference-data} CLI command. */
|
|
2
|
+
export declare function handleListReferenceData(dataType: string, options: {
|
|
3
|
+
json?: boolean;
|
|
4
|
+
}): void;
|
|
5
|
+
//# sourceMappingURL=list-reference-data.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list-reference-data.d.ts","sourceRoot":"","sources":["../../src/handlers/list-reference-data.ts"],"names":[],"mappings":"AAkBA,0HAA0H;AAC1H,wBAAgB,uBAAuB,CACrC,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE;IACP,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,GACA,IAAI,CA6BN"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { getLinkedInReferenceData, isReferenceDataType, } from "@lhremote/core";
|
|
4
|
+
const VALID_DATA_TYPES = [
|
|
5
|
+
"INDUSTRY",
|
|
6
|
+
"SENIORITY",
|
|
7
|
+
"FUNCTION",
|
|
8
|
+
"COMPANY_SIZE",
|
|
9
|
+
"CONNECTION_DEGREE",
|
|
10
|
+
"PROFILE_LANGUAGE",
|
|
11
|
+
];
|
|
12
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#list-reference-data | list-reference-data} CLI command. */
|
|
13
|
+
export function handleListReferenceData(dataType, options) {
|
|
14
|
+
if (!isReferenceDataType(dataType)) {
|
|
15
|
+
process.stderr.write(`Unknown reference data type: ${dataType}\n` +
|
|
16
|
+
`Valid types: ${VALID_DATA_TYPES.join(", ")}\n`);
|
|
17
|
+
process.exitCode = 1;
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const items = getLinkedInReferenceData(dataType);
|
|
21
|
+
if (options.json) {
|
|
22
|
+
process.stdout.write(JSON.stringify({ dataType, items }, null, 2) + "\n");
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
process.stdout.write(`${dataType} (${String(items.length)} entries):\n\n`);
|
|
26
|
+
for (const item of items) {
|
|
27
|
+
// Each entry type has different key names; normalise for display
|
|
28
|
+
const entries = Object.entries(item);
|
|
29
|
+
const parts = entries.map(([key, value]) => `${key}: ${String(value)}`);
|
|
30
|
+
process.stdout.write(` ${parts.join(", ")}\n`);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=list-reference-data.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list-reference-data.js","sourceRoot":"","sources":["../../src/handlers/list-reference-data.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAEL,wBAAwB,EACxB,mBAAmB,GACpB,MAAM,gBAAgB,CAAC;AAExB,MAAM,gBAAgB,GAAiC;IACrD,UAAU;IACV,WAAW;IACX,UAAU;IACV,cAAc;IACd,mBAAmB;IACnB,kBAAkB;CACnB,CAAC;AAEF,0HAA0H;AAC1H,MAAM,UAAU,uBAAuB,CACrC,QAAgB,EAChB,OAEC;IAED,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,EAAE,CAAC;QACnC,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,gCAAgC,QAAQ,IAAI;YAC1C,gBAAgB,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAClD,CAAC;QACF,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,MAAM,KAAK,GAAG,wBAAwB,CAAC,QAAQ,CAAC,CAAC;IAEjD,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CACpD,CAAC;QACF,OAAO;IACT,CAAC;IAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,QAAQ,KAAK,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;IAE3E,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,iEAAiE;QACjE,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,IAA0C,CAAC,CAAC;QAC3E,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CACvB,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,KAAK,MAAM,CAAC,KAAK,CAAC,EAAE,CAC7C,CAAC;QACF,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClD,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#message-person | message-person} CLI command. */
|
|
2
|
+
export declare function handleMessagePerson(options: {
|
|
3
|
+
personId?: number;
|
|
4
|
+
url?: string;
|
|
5
|
+
messageTemplate: string;
|
|
6
|
+
subjectTemplate?: string;
|
|
7
|
+
rejectIfReplied?: boolean;
|
|
8
|
+
rejectIfMessaged?: boolean;
|
|
9
|
+
keepCampaign?: boolean;
|
|
10
|
+
cdpPort?: number;
|
|
11
|
+
cdpHost?: string;
|
|
12
|
+
allowRemote?: boolean;
|
|
13
|
+
json?: boolean;
|
|
14
|
+
}): Promise<void>;
|
|
15
|
+
//# sourceMappingURL=message-person.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message-person.d.ts","sourceRoot":"","sources":["../../src/handlers/message-person.ts"],"names":[],"mappings":"AAYA,gHAAgH;AAChH,wBAAsB,mBAAmB,CAAC,OAAO,EAAE;IACjD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,eAAe,EAAE,MAAM,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,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,CA4DhB"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { DEFAULT_CDP_PORT, errorMessage, messagePerson, CampaignExecutionError, CampaignTimeoutError, } from "@lhremote/core";
|
|
4
|
+
/** Handle the {@link https://github.com/alexey-pelykh/lhremote#message-person | message-person} CLI command. */
|
|
5
|
+
export async function handleMessagePerson(options) {
|
|
6
|
+
if ((options.personId == null) === (options.url == null)) {
|
|
7
|
+
process.stderr.write("Exactly one of --person-id or --url must be provided.\n");
|
|
8
|
+
process.exitCode = 1;
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
11
|
+
let parsedMessageTemplate;
|
|
12
|
+
try {
|
|
13
|
+
parsedMessageTemplate = JSON.parse(options.messageTemplate);
|
|
14
|
+
}
|
|
15
|
+
catch {
|
|
16
|
+
process.stderr.write("Invalid JSON in --message-template.\n");
|
|
17
|
+
process.exitCode = 1;
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
let parsedSubjectTemplate;
|
|
21
|
+
if (options.subjectTemplate) {
|
|
22
|
+
try {
|
|
23
|
+
parsedSubjectTemplate = JSON.parse(options.subjectTemplate);
|
|
24
|
+
}
|
|
25
|
+
catch {
|
|
26
|
+
process.stderr.write("Invalid JSON in --subject-template.\n");
|
|
27
|
+
process.exitCode = 1;
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
process.stderr.write("Sending message...\n");
|
|
32
|
+
let result;
|
|
33
|
+
try {
|
|
34
|
+
result = await messagePerson({
|
|
35
|
+
personId: options.personId,
|
|
36
|
+
url: options.url,
|
|
37
|
+
messageTemplate: parsedMessageTemplate,
|
|
38
|
+
subjectTemplate: parsedSubjectTemplate,
|
|
39
|
+
rejectIfReplied: options.rejectIfReplied,
|
|
40
|
+
rejectIfMessaged: options.rejectIfMessaged,
|
|
41
|
+
keepCampaign: options.keepCampaign,
|
|
42
|
+
cdpPort: options.cdpPort ?? DEFAULT_CDP_PORT,
|
|
43
|
+
cdpHost: options.cdpHost,
|
|
44
|
+
allowRemote: options.allowRemote,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
catch (error) {
|
|
48
|
+
if (error instanceof CampaignExecutionError || error instanceof CampaignTimeoutError) {
|
|
49
|
+
process.stderr.write(`${error.message}\n`);
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
process.stderr.write(`${errorMessage(error)}\n`);
|
|
53
|
+
}
|
|
54
|
+
process.exitCode = 1;
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
process.stderr.write("Done.\n");
|
|
58
|
+
if (options.json) {
|
|
59
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
process.stdout.write(`Message ${result.success ? "sent" : "failed"} (person #${String(result.personId)})\n`);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=message-person.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message-person.js","sourceRoot":"","sources":["../../src/handlers/message-person.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message-person.test.d.ts","sourceRoot":"","sources":["../../src/handlers/message-person.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,77 @@
|
|
|
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
|
+
messagePerson: vi.fn(),
|
|
9
|
+
};
|
|
10
|
+
});
|
|
11
|
+
import { CampaignExecutionError, CampaignTimeoutError, messagePerson, } from "@lhremote/core";
|
|
12
|
+
import { handleMessagePerson } from "./message-person.js";
|
|
13
|
+
import { getStderr, getStdout } from "./testing/mock-helpers.js";
|
|
14
|
+
const MOCK_RESULT = {
|
|
15
|
+
success: true,
|
|
16
|
+
personId: 100,
|
|
17
|
+
results: [{ id: 1, actionVersionId: 1, personId: 100, result: 1, platform: null, createdAt: "2026-01-01T00:00:00Z", profile: null }],
|
|
18
|
+
};
|
|
19
|
+
describe("handleMessagePerson", () => {
|
|
20
|
+
let stdoutSpy;
|
|
21
|
+
let stderrSpy;
|
|
22
|
+
beforeEach(() => {
|
|
23
|
+
vi.clearAllMocks();
|
|
24
|
+
process.exitCode = undefined;
|
|
25
|
+
stdoutSpy = vi.spyOn(process.stdout, "write").mockReturnValue(true);
|
|
26
|
+
stderrSpy = vi.spyOn(process.stderr, "write").mockReturnValue(true);
|
|
27
|
+
});
|
|
28
|
+
afterEach(() => {
|
|
29
|
+
vi.restoreAllMocks();
|
|
30
|
+
});
|
|
31
|
+
it("outputs JSON result on success", async () => {
|
|
32
|
+
vi.mocked(messagePerson).mockResolvedValue(MOCK_RESULT);
|
|
33
|
+
await handleMessagePerson({ personId: 100, messageTemplate: '{"type":"text","value":"Hello"}', json: true });
|
|
34
|
+
expect(process.exitCode).toBeUndefined();
|
|
35
|
+
const stdout = getStdout(stdoutSpy);
|
|
36
|
+
const parsed = JSON.parse(stdout);
|
|
37
|
+
expect(parsed.success).toBe(true);
|
|
38
|
+
expect(parsed.personId).toBe(100);
|
|
39
|
+
});
|
|
40
|
+
it("outputs human-readable result on success", async () => {
|
|
41
|
+
vi.mocked(messagePerson).mockResolvedValue(MOCK_RESULT);
|
|
42
|
+
await handleMessagePerson({ personId: 100, messageTemplate: '{"type":"text","value":"Hello"}' });
|
|
43
|
+
expect(process.exitCode).toBeUndefined();
|
|
44
|
+
expect(getStdout(stdoutSpy)).toContain("sent");
|
|
45
|
+
});
|
|
46
|
+
it("returns error when neither personId nor url provided", async () => {
|
|
47
|
+
await handleMessagePerson({ messageTemplate: '{"type":"text","value":"Hello"}' });
|
|
48
|
+
expect(process.exitCode).toBe(1);
|
|
49
|
+
expect(getStderr(stderrSpy)).toContain("Exactly one of --person-id or --url");
|
|
50
|
+
expect(messagePerson).not.toHaveBeenCalled();
|
|
51
|
+
});
|
|
52
|
+
it("returns error for invalid JSON in messageTemplate", async () => {
|
|
53
|
+
await handleMessagePerson({ personId: 100, messageTemplate: "not json" });
|
|
54
|
+
expect(process.exitCode).toBe(1);
|
|
55
|
+
expect(getStderr(stderrSpy)).toContain("Invalid JSON in --message-template");
|
|
56
|
+
expect(messagePerson).not.toHaveBeenCalled();
|
|
57
|
+
});
|
|
58
|
+
it("returns error for invalid JSON in subjectTemplate", async () => {
|
|
59
|
+
await handleMessagePerson({ personId: 100, messageTemplate: '{"type":"text","value":"Hello"}', subjectTemplate: "not json" });
|
|
60
|
+
expect(process.exitCode).toBe(1);
|
|
61
|
+
expect(getStderr(stderrSpy)).toContain("Invalid JSON in --subject-template");
|
|
62
|
+
expect(messagePerson).not.toHaveBeenCalled();
|
|
63
|
+
});
|
|
64
|
+
it("handles CampaignExecutionError", async () => {
|
|
65
|
+
vi.mocked(messagePerson).mockRejectedValue(new CampaignExecutionError("Person 100 not found"));
|
|
66
|
+
await handleMessagePerson({ personId: 100, messageTemplate: '{"type":"text","value":"Hello"}' });
|
|
67
|
+
expect(process.exitCode).toBe(1);
|
|
68
|
+
expect(getStderr(stderrSpy)).toContain("Person 100 not found");
|
|
69
|
+
});
|
|
70
|
+
it("handles CampaignTimeoutError", async () => {
|
|
71
|
+
vi.mocked(messagePerson).mockRejectedValue(new CampaignTimeoutError("Timed out", 42));
|
|
72
|
+
await handleMessagePerson({ personId: 100, messageTemplate: '{"type":"text","value":"Hello"}' });
|
|
73
|
+
expect(process.exitCode).toBe(1);
|
|
74
|
+
expect(getStderr(stderrSpy)).toContain("Timed out");
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
//# sourceMappingURL=message-person.test.js.map
|