@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.
Files changed (308) hide show
  1. package/dist/handlers/add-people-to-collection.d.ts.map +1 -1
  2. package/dist/handlers/add-people-to-collection.js +2 -2
  3. package/dist/handlers/add-people-to-collection.js.map +1 -1
  4. package/dist/handlers/build-url.test.d.ts +2 -0
  5. package/dist/handlers/build-url.test.d.ts.map +1 -0
  6. package/dist/handlers/build-url.test.js +119 -0
  7. package/dist/handlers/build-url.test.js.map +1 -0
  8. package/dist/handlers/campaign-add-action.d.ts.map +1 -1
  9. package/dist/handlers/campaign-add-action.js +2 -2
  10. package/dist/handlers/campaign-add-action.js.map +1 -1
  11. package/dist/handlers/campaign-create.d.ts.map +1 -1
  12. package/dist/handlers/campaign-create.js +2 -2
  13. package/dist/handlers/campaign-create.js.map +1 -1
  14. package/dist/handlers/campaign-delete.d.ts +1 -0
  15. package/dist/handlers/campaign-delete.d.ts.map +1 -1
  16. package/dist/handlers/campaign-delete.js +5 -3
  17. package/dist/handlers/campaign-delete.js.map +1 -1
  18. package/dist/handlers/campaign-delete.test.js +25 -0
  19. package/dist/handlers/campaign-delete.test.js.map +1 -1
  20. package/dist/handlers/campaign-erase.d.ts +8 -0
  21. package/dist/handlers/campaign-erase.d.ts.map +1 -0
  22. package/dist/handlers/campaign-erase.js +39 -0
  23. package/dist/handlers/campaign-erase.js.map +1 -0
  24. package/dist/handlers/campaign-erase.test.d.ts +2 -0
  25. package/dist/handlers/campaign-erase.test.d.ts.map +1 -0
  26. package/dist/handlers/campaign-erase.test.js +71 -0
  27. package/dist/handlers/campaign-erase.test.js.map +1 -0
  28. package/dist/handlers/campaign-exclude-add.d.ts.map +1 -1
  29. package/dist/handlers/campaign-exclude-add.js +2 -2
  30. package/dist/handlers/campaign-exclude-add.js.map +1 -1
  31. package/dist/handlers/campaign-exclude-list.d.ts.map +1 -1
  32. package/dist/handlers/campaign-exclude-list.js +2 -2
  33. package/dist/handlers/campaign-exclude-list.js.map +1 -1
  34. package/dist/handlers/campaign-exclude-remove.d.ts.map +1 -1
  35. package/dist/handlers/campaign-exclude-remove.js +2 -2
  36. package/dist/handlers/campaign-exclude-remove.js.map +1 -1
  37. package/dist/handlers/campaign-export.d.ts.map +1 -1
  38. package/dist/handlers/campaign-export.js +2 -2
  39. package/dist/handlers/campaign-export.js.map +1 -1
  40. package/dist/handlers/campaign-get.d.ts.map +1 -1
  41. package/dist/handlers/campaign-get.js +2 -2
  42. package/dist/handlers/campaign-get.js.map +1 -1
  43. package/dist/handlers/campaign-list-people.d.ts.map +1 -1
  44. package/dist/handlers/campaign-list-people.js +2 -2
  45. package/dist/handlers/campaign-list-people.js.map +1 -1
  46. package/dist/handlers/campaign-move-next.d.ts.map +1 -1
  47. package/dist/handlers/campaign-move-next.js +2 -2
  48. package/dist/handlers/campaign-move-next.js.map +1 -1
  49. package/dist/handlers/campaign-remove-action.d.ts.map +1 -1
  50. package/dist/handlers/campaign-remove-action.js +2 -2
  51. package/dist/handlers/campaign-remove-action.js.map +1 -1
  52. package/dist/handlers/campaign-remove-people.d.ts.map +1 -1
  53. package/dist/handlers/campaign-remove-people.js +2 -2
  54. package/dist/handlers/campaign-remove-people.js.map +1 -1
  55. package/dist/handlers/campaign-reorder-actions.d.ts.map +1 -1
  56. package/dist/handlers/campaign-reorder-actions.js +2 -2
  57. package/dist/handlers/campaign-reorder-actions.js.map +1 -1
  58. package/dist/handlers/campaign-retry.d.ts.map +1 -1
  59. package/dist/handlers/campaign-retry.js +2 -2
  60. package/dist/handlers/campaign-retry.js.map +1 -1
  61. package/dist/handlers/campaign-start.d.ts.map +1 -1
  62. package/dist/handlers/campaign-start.js +2 -2
  63. package/dist/handlers/campaign-start.js.map +1 -1
  64. package/dist/handlers/campaign-statistics.d.ts.map +1 -1
  65. package/dist/handlers/campaign-statistics.js +2 -2
  66. package/dist/handlers/campaign-statistics.js.map +1 -1
  67. package/dist/handlers/campaign-status.d.ts.map +1 -1
  68. package/dist/handlers/campaign-status.js +2 -2
  69. package/dist/handlers/campaign-status.js.map +1 -1
  70. package/dist/handlers/campaign-stop.d.ts.map +1 -1
  71. package/dist/handlers/campaign-stop.js +2 -2
  72. package/dist/handlers/campaign-stop.js.map +1 -1
  73. package/dist/handlers/campaign-update-action.d.ts.map +1 -1
  74. package/dist/handlers/campaign-update-action.js +2 -2
  75. package/dist/handlers/campaign-update-action.js.map +1 -1
  76. package/dist/handlers/campaign-update.d.ts.map +1 -1
  77. package/dist/handlers/campaign-update.js +2 -2
  78. package/dist/handlers/campaign-update.js.map +1 -1
  79. package/dist/handlers/check-replies.d.ts +2 -0
  80. package/dist/handlers/check-replies.d.ts.map +1 -1
  81. package/dist/handlers/check-replies.js +9 -2
  82. package/dist/handlers/check-replies.js.map +1 -1
  83. package/dist/handlers/check-replies.test.js +25 -8
  84. package/dist/handlers/check-replies.test.js.map +1 -1
  85. package/dist/handlers/check-status.d.ts.map +1 -1
  86. package/dist/handlers/check-status.js +6 -6
  87. package/dist/handlers/check-status.js.map +1 -1
  88. package/dist/handlers/collect-people.d.ts.map +1 -1
  89. package/dist/handlers/collect-people.js +2 -2
  90. package/dist/handlers/collect-people.js.map +1 -1
  91. package/dist/handlers/comment-on-post.d.ts +10 -0
  92. package/dist/handlers/comment-on-post.d.ts.map +1 -0
  93. package/dist/handlers/comment-on-post.js +37 -0
  94. package/dist/handlers/comment-on-post.js.map +1 -0
  95. package/dist/handlers/comment-on-post.test.d.ts +2 -0
  96. package/dist/handlers/comment-on-post.test.d.ts.map +1 -0
  97. package/dist/handlers/comment-on-post.test.js +75 -0
  98. package/dist/handlers/comment-on-post.test.js.map +1 -0
  99. package/dist/handlers/create-collection.d.ts.map +1 -1
  100. package/dist/handlers/create-collection.js +2 -2
  101. package/dist/handlers/create-collection.js.map +1 -1
  102. package/dist/handlers/delete-collection.d.ts.map +1 -1
  103. package/dist/handlers/delete-collection.js +2 -2
  104. package/dist/handlers/delete-collection.js.map +1 -1
  105. package/dist/handlers/dismiss-errors.d.ts +8 -0
  106. package/dist/handlers/dismiss-errors.d.ts.map +1 -0
  107. package/dist/handlers/dismiss-errors.js +28 -0
  108. package/dist/handlers/dismiss-errors.js.map +1 -0
  109. package/dist/handlers/dismiss-errors.test.d.ts +2 -0
  110. package/dist/handlers/dismiss-errors.test.d.ts.map +1 -0
  111. package/dist/handlers/dismiss-errors.test.js +90 -0
  112. package/dist/handlers/dismiss-errors.test.js.map +1 -0
  113. package/dist/handlers/endorse-skills.d.ts +14 -0
  114. package/dist/handlers/endorse-skills.d.ts.map +1 -0
  115. package/dist/handlers/endorse-skills.js +44 -0
  116. package/dist/handlers/endorse-skills.js.map +1 -0
  117. package/dist/handlers/endorse-skills.test.d.ts +2 -0
  118. package/dist/handlers/endorse-skills.test.d.ts.map +1 -0
  119. package/dist/handlers/endorse-skills.test.js +65 -0
  120. package/dist/handlers/endorse-skills.test.js.map +1 -0
  121. package/dist/handlers/enrich-profile.d.ts +16 -0
  122. package/dist/handlers/enrich-profile.d.ts.map +1 -0
  123. package/dist/handlers/enrich-profile.js +51 -0
  124. package/dist/handlers/enrich-profile.js.map +1 -0
  125. package/dist/handlers/enrich-profile.test.d.ts +2 -0
  126. package/dist/handlers/enrich-profile.test.d.ts.map +1 -0
  127. package/dist/handlers/enrich-profile.test.js +65 -0
  128. package/dist/handlers/enrich-profile.test.js.map +1 -0
  129. package/dist/handlers/find-app.js +1 -1
  130. package/dist/handlers/find-app.js.map +1 -1
  131. package/dist/handlers/find-app.test.js +4 -4
  132. package/dist/handlers/find-app.test.js.map +1 -1
  133. package/dist/handlers/follow-person.d.ts +13 -0
  134. package/dist/handlers/follow-person.d.ts.map +1 -0
  135. package/dist/handlers/follow-person.js +45 -0
  136. package/dist/handlers/follow-person.js.map +1 -0
  137. package/dist/handlers/follow-person.test.d.ts +2 -0
  138. package/dist/handlers/follow-person.test.d.ts.map +1 -0
  139. package/dist/handlers/follow-person.test.js +65 -0
  140. package/dist/handlers/follow-person.test.js.map +1 -0
  141. package/dist/handlers/get-action-budget.d.ts +8 -0
  142. package/dist/handlers/get-action-budget.d.ts.map +1 -0
  143. package/dist/handlers/get-action-budget.js +46 -0
  144. package/dist/handlers/get-action-budget.js.map +1 -0
  145. package/dist/handlers/get-action-budget.test.d.ts +2 -0
  146. package/dist/handlers/get-action-budget.test.d.ts.map +1 -0
  147. package/dist/handlers/get-action-budget.test.js +69 -0
  148. package/dist/handlers/get-action-budget.test.js.map +1 -0
  149. package/dist/handlers/get-errors.d.ts.map +1 -1
  150. package/dist/handlers/get-errors.js +14 -2
  151. package/dist/handlers/get-errors.js.map +1 -1
  152. package/dist/handlers/get-errors.test.js +25 -0
  153. package/dist/handlers/get-errors.test.js.map +1 -1
  154. package/dist/handlers/get-feed.d.ts +10 -0
  155. package/dist/handlers/get-feed.d.ts.map +1 -0
  156. package/dist/handlers/get-feed.js +64 -0
  157. package/dist/handlers/get-feed.js.map +1 -0
  158. package/dist/handlers/get-feed.test.d.ts +2 -0
  159. package/dist/handlers/get-feed.test.d.ts.map +1 -0
  160. package/dist/handlers/get-feed.test.js +124 -0
  161. package/dist/handlers/get-feed.test.js.map +1 -0
  162. package/dist/handlers/get-post-stats.d.ts +8 -0
  163. package/dist/handlers/get-post-stats.d.ts.map +1 -0
  164. package/dist/handlers/get-post-stats.js +37 -0
  165. package/dist/handlers/get-post-stats.js.map +1 -0
  166. package/dist/handlers/get-post-stats.test.d.ts +2 -0
  167. package/dist/handlers/get-post-stats.test.d.ts.map +1 -0
  168. package/dist/handlers/get-post-stats.test.js +79 -0
  169. package/dist/handlers/get-post-stats.test.js.map +1 -0
  170. package/dist/handlers/get-post.d.ts +9 -0
  171. package/dist/handlers/get-post.d.ts.map +1 -0
  172. package/dist/handlers/get-post.js +65 -0
  173. package/dist/handlers/get-post.js.map +1 -0
  174. package/dist/handlers/get-post.test.d.ts +2 -0
  175. package/dist/handlers/get-post.test.d.ts.map +1 -0
  176. package/dist/handlers/get-post.test.js +124 -0
  177. package/dist/handlers/get-post.test.js.map +1 -0
  178. package/dist/handlers/get-profile-activity.d.ts +10 -0
  179. package/dist/handlers/get-profile-activity.d.ts.map +1 -0
  180. package/dist/handlers/get-profile-activity.js +60 -0
  181. package/dist/handlers/get-profile-activity.js.map +1 -0
  182. package/dist/handlers/get-profile-activity.test.d.ts +2 -0
  183. package/dist/handlers/get-profile-activity.test.d.ts.map +1 -0
  184. package/dist/handlers/get-profile-activity.test.js +127 -0
  185. package/dist/handlers/get-profile-activity.test.js.map +1 -0
  186. package/dist/handlers/get-throttle-status.d.ts +8 -0
  187. package/dist/handlers/get-throttle-status.d.ts.map +1 -0
  188. package/dist/handlers/get-throttle-status.js +33 -0
  189. package/dist/handlers/get-throttle-status.js.map +1 -0
  190. package/dist/handlers/get-throttle-status.test.d.ts +2 -0
  191. package/dist/handlers/get-throttle-status.test.d.ts.map +1 -0
  192. package/dist/handlers/get-throttle-status.test.js +65 -0
  193. package/dist/handlers/get-throttle-status.test.js.map +1 -0
  194. package/dist/handlers/import-people-from-collection.d.ts.map +1 -1
  195. package/dist/handlers/import-people-from-collection.js +2 -2
  196. package/dist/handlers/import-people-from-collection.js.map +1 -1
  197. package/dist/handlers/import-people-from-urls.d.ts.map +1 -1
  198. package/dist/handlers/import-people-from-urls.js +2 -2
  199. package/dist/handlers/import-people-from-urls.js.map +1 -1
  200. package/dist/handlers/index.d.ts +20 -0
  201. package/dist/handlers/index.d.ts.map +1 -1
  202. package/dist/handlers/index.js +20 -0
  203. package/dist/handlers/index.js.map +1 -1
  204. package/dist/handlers/like-person-posts.d.ts +18 -0
  205. package/dist/handlers/like-person-posts.d.ts.map +1 -0
  206. package/dist/handlers/like-person-posts.js +59 -0
  207. package/dist/handlers/like-person-posts.js.map +1 -0
  208. package/dist/handlers/like-person-posts.test.d.ts +2 -0
  209. package/dist/handlers/like-person-posts.test.d.ts.map +1 -0
  210. package/dist/handlers/like-person-posts.test.js +71 -0
  211. package/dist/handlers/like-person-posts.test.js.map +1 -0
  212. package/dist/handlers/list-accounts.d.ts.map +1 -1
  213. package/dist/handlers/list-accounts.js +12 -2
  214. package/dist/handlers/list-accounts.js.map +1 -1
  215. package/dist/handlers/list-accounts.test.js +3 -1
  216. package/dist/handlers/list-accounts.test.js.map +1 -1
  217. package/dist/handlers/list-reference-data.test.d.ts +2 -0
  218. package/dist/handlers/list-reference-data.test.d.ts.map +1 -0
  219. package/dist/handlers/list-reference-data.test.js +62 -0
  220. package/dist/handlers/list-reference-data.test.js.map +1 -0
  221. package/dist/handlers/message-person.d.ts +15 -0
  222. package/dist/handlers/message-person.d.ts.map +1 -0
  223. package/dist/handlers/message-person.js +65 -0
  224. package/dist/handlers/message-person.js.map +1 -0
  225. package/dist/handlers/message-person.test.d.ts +2 -0
  226. package/dist/handlers/message-person.test.d.ts.map +1 -0
  227. package/dist/handlers/message-person.test.js +77 -0
  228. package/dist/handlers/message-person.test.js.map +1 -0
  229. package/dist/handlers/query-messages.integration.test.js +24 -3
  230. package/dist/handlers/query-messages.integration.test.js.map +1 -1
  231. package/dist/handlers/react-to-post.d.ts +9 -0
  232. package/dist/handlers/react-to-post.d.ts.map +1 -0
  233. package/dist/handlers/react-to-post.js +30 -0
  234. package/dist/handlers/react-to-post.js.map +1 -0
  235. package/dist/handlers/react-to-post.test.d.ts +2 -0
  236. package/dist/handlers/react-to-post.test.d.ts.map +1 -0
  237. package/dist/handlers/react-to-post.test.js +53 -0
  238. package/dist/handlers/react-to-post.test.js.map +1 -0
  239. package/dist/handlers/remove-connection.d.ts +11 -0
  240. package/dist/handlers/remove-connection.d.ts.map +1 -0
  241. package/dist/handlers/remove-connection.js +41 -0
  242. package/dist/handlers/remove-connection.js.map +1 -0
  243. package/dist/handlers/remove-connection.test.d.ts +2 -0
  244. package/dist/handlers/remove-connection.test.d.ts.map +1 -0
  245. package/dist/handlers/remove-connection.test.js +65 -0
  246. package/dist/handlers/remove-connection.test.js.map +1 -0
  247. package/dist/handlers/remove-people-from-collection.d.ts.map +1 -1
  248. package/dist/handlers/remove-people-from-collection.js +2 -2
  249. package/dist/handlers/remove-people-from-collection.js.map +1 -1
  250. package/dist/handlers/resolve-entity.d.ts.map +1 -1
  251. package/dist/handlers/resolve-entity.js +2 -2
  252. package/dist/handlers/resolve-entity.js.map +1 -1
  253. package/dist/handlers/resolve-entity.test.d.ts +2 -0
  254. package/dist/handlers/resolve-entity.test.d.ts.map +1 -0
  255. package/dist/handlers/resolve-entity.test.js +93 -0
  256. package/dist/handlers/resolve-entity.test.js.map +1 -0
  257. package/dist/handlers/scrape-messaging-history.d.ts +1 -0
  258. package/dist/handlers/scrape-messaging-history.d.ts.map +1 -1
  259. package/dist/handlers/scrape-messaging-history.js +3 -2
  260. package/dist/handlers/scrape-messaging-history.js.map +1 -1
  261. package/dist/handlers/search-posts.d.ts +10 -0
  262. package/dist/handlers/search-posts.d.ts.map +1 -0
  263. package/dist/handlers/search-posts.js +56 -0
  264. package/dist/handlers/search-posts.js.map +1 -0
  265. package/dist/handlers/search-posts.test.d.ts +2 -0
  266. package/dist/handlers/search-posts.test.d.ts.map +1 -0
  267. package/dist/handlers/search-posts.test.js +112 -0
  268. package/dist/handlers/search-posts.test.js.map +1 -0
  269. package/dist/handlers/send-inmail.d.ts +15 -0
  270. package/dist/handlers/send-inmail.d.ts.map +1 -0
  271. package/dist/handlers/send-inmail.js +65 -0
  272. package/dist/handlers/send-inmail.js.map +1 -0
  273. package/dist/handlers/send-inmail.test.d.ts +2 -0
  274. package/dist/handlers/send-inmail.test.d.ts.map +1 -0
  275. package/dist/handlers/send-inmail.test.js +77 -0
  276. package/dist/handlers/send-inmail.test.js.map +1 -0
  277. package/dist/handlers/send-invite.d.ts +13 -0
  278. package/dist/handlers/send-invite.d.ts.map +1 -0
  279. package/dist/handlers/send-invite.js +54 -0
  280. package/dist/handlers/send-invite.js.map +1 -0
  281. package/dist/handlers/send-invite.test.d.ts +2 -0
  282. package/dist/handlers/send-invite.test.d.ts.map +1 -0
  283. package/dist/handlers/send-invite.test.js +71 -0
  284. package/dist/handlers/send-invite.test.js.map +1 -0
  285. package/dist/handlers/start-instance.d.ts.map +1 -1
  286. package/dist/handlers/start-instance.js +11 -2
  287. package/dist/handlers/start-instance.js.map +1 -1
  288. package/dist/handlers/start-instance.test.js +3 -1
  289. package/dist/handlers/start-instance.test.js.map +1 -1
  290. package/dist/handlers/stop-instance.d.ts.map +1 -1
  291. package/dist/handlers/stop-instance.js +11 -2
  292. package/dist/handlers/stop-instance.js.map +1 -1
  293. package/dist/handlers/stop-instance.test.js +3 -1
  294. package/dist/handlers/stop-instance.test.js.map +1 -1
  295. package/dist/handlers/visit-profile.d.ts +11 -0
  296. package/dist/handlers/visit-profile.d.ts.map +1 -0
  297. package/dist/handlers/visit-profile.js +93 -0
  298. package/dist/handlers/visit-profile.js.map +1 -0
  299. package/dist/handlers/visit-profile.test.d.ts +2 -0
  300. package/dist/handlers/visit-profile.test.d.ts.map +1 -0
  301. package/dist/handlers/visit-profile.test.js +169 -0
  302. package/dist/handlers/visit-profile.test.js.map +1 -0
  303. package/dist/program.d.ts.map +1 -1
  304. package/dist/program.js +281 -37
  305. package/dist/program.js.map +1 -1
  306. package/dist/program.test.js +21 -1
  307. package/dist/program.test.js.map +1 -1
  308. package/package.json +2 -2
@@ -1 +1 @@
1
- {"version":3,"file":"scrape-messaging-history.d.ts","sourceRoot":"","sources":["../../src/handlers/scrape-messaging-history.ts"],"names":[],"mappings":"AAYA,+HAA+H;AAC/H,wBAAsB,4BAA4B,CAAC,OAAO,EAAE;IAC1D,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,GAAG,OAAO,CAAC,IAAI,CAAC,CAmChB"}
1
+ {"version":3,"file":"scrape-messaging-history.d.ts","sourceRoot":"","sources":["../../src/handlers/scrape-messaging-history.ts"],"names":[],"mappings":"AAWA,+HAA+H;AAC/H,wBAAsB,4BAA4B,CAAC,OAAO,EAAE;IAC1D,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,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,CAoChB"}
@@ -1,6 +1,6 @@
1
1
  // SPDX-License-Identifier: AGPL-3.0-only
2
2
  // Copyright (C) 2026 Oleksii PELYKH
3
- import { DEFAULT_CDP_PORT, errorMessage, InstanceNotRunningError, scrapeMessagingHistory, } from "@lhremote/core";
3
+ import { errorMessage, InstanceNotRunningError, scrapeMessagingHistory, } from "@lhremote/core";
4
4
  /** Handle the {@link https://github.com/alexey-pelykh/lhremote#profiles--messaging | scrape-messaging-history} CLI command. */
5
5
  export async function handleScrapeMessagingHistory(options) {
6
6
  if (options.personId.length === 0) {
@@ -13,7 +13,8 @@ export async function handleScrapeMessagingHistory(options) {
13
13
  try {
14
14
  result = await scrapeMessagingHistory({
15
15
  personIds: options.personId,
16
- cdpPort: options.cdpPort ?? DEFAULT_CDP_PORT,
16
+ pauseOthers: options.pauseOthers,
17
+ cdpPort: options.cdpPort,
17
18
  cdpHost: options.cdpHost,
18
19
  allowRemote: options.allowRemote,
19
20
  });
@@ -1 +1 @@
1
- {"version":3,"file":"scrape-messaging-history.js","sourceRoot":"","sources":["../../src/handlers/scrape-messaging-history.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAEL,gBAAgB,EAChB,YAAY,EACZ,uBAAuB,EACvB,sBAAsB,GAEvB,MAAM,gBAAgB,CAAC;AAExB,+HAA+H;AAC/H,MAAM,CAAC,KAAK,UAAU,4BAA4B,CAAC,OAMlD;IACC,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAClC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,yCAAyC,CAAC,CAAC;QAChE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,+CAA+C,CAAC,CAAC;IAEtE,IAAI,MAAoC,CAAC;IACzC,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,sBAAsB,CAAC;YACpC,SAAS,EAAE,OAAO,CAAC,QAAQ;YAC3B,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,uBAAuB,EAAE,CAAC;YAC7C,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,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;AACH,CAAC;AAED,SAAS,UAAU,CAAC,KAAmB;IACrC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;IACnD,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,KAAK,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,kBAAkB,CAChD,CAAC;IACF,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,KAAK,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAC9C,CAAC;IAEF,IAAI,KAAK,CAAC,eAAe,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;QACjD,MAAM,QAAQ,GAAG,KAAK,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACpD,MAAM,MAAM,GAAG,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAChD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,iBAAiB,QAAQ,MAAM,MAAM,IAAI,CAAC,CAAC;IAClE,CAAC;IAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,8DAA8D,CAC/D,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"scrape-messaging-history.js","sourceRoot":"","sources":["../../src/handlers/scrape-messaging-history.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAEL,YAAY,EACZ,uBAAuB,EACvB,sBAAsB,GAEvB,MAAM,gBAAgB,CAAC;AAExB,+HAA+H;AAC/H,MAAM,CAAC,KAAK,UAAU,4BAA4B,CAAC,OAOlD;IACC,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAClC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,yCAAyC,CAAC,CAAC;QAChE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,+CAA+C,CAAC,CAAC;IAEtE,IAAI,MAAoC,CAAC;IACzC,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,sBAAsB,CAAC;YACpC,SAAS,EAAE,OAAO,CAAC,QAAQ;YAC3B,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,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,uBAAuB,EAAE,CAAC;YAC7C,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,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;AACH,CAAC;AAED,SAAS,UAAU,CAAC,KAAmB;IACrC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;IACnD,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,KAAK,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,kBAAkB,CAChD,CAAC;IACF,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,KAAK,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAC9C,CAAC;IAEF,IAAI,KAAK,CAAC,eAAe,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;QACjD,MAAM,QAAQ,GAAG,KAAK,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACpD,MAAM,MAAM,GAAG,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAChD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,iBAAiB,QAAQ,MAAM,MAAM,IAAI,CAAC,CAAC;IAClE,CAAC;IAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,8DAA8D,CAC/D,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ /** Handle the {@link https://github.com/alexey-pelykh/lhremote#search-posts | search-posts} CLI command. */
2
+ export declare function handleSearchPosts(query: string, options: {
3
+ cursor?: number;
4
+ count?: number;
5
+ cdpPort?: number;
6
+ cdpHost?: string;
7
+ allowRemote?: boolean;
8
+ json?: boolean;
9
+ }): Promise<void>;
10
+ //# sourceMappingURL=search-posts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search-posts.d.ts","sourceRoot":"","sources":["../../src/handlers/search-posts.ts"],"names":[],"mappings":"AASA,4GAA4G;AAC5G,wBAAsB,iBAAiB,CACrC,KAAK,EAAE,MAAM,EACb,OAAO,EAAE;IACP,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,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,CA0Df"}
@@ -0,0 +1,56 @@
1
+ // SPDX-License-Identifier: AGPL-3.0-only
2
+ // Copyright (C) 2026 Oleksii PELYKH
3
+ import { errorMessage, searchPosts, } from "@lhremote/core";
4
+ /** Handle the {@link https://github.com/alexey-pelykh/lhremote#search-posts | search-posts} CLI command. */
5
+ export async function handleSearchPosts(query, options) {
6
+ let result;
7
+ try {
8
+ result = await searchPosts({
9
+ query,
10
+ cursor: options.cursor,
11
+ count: options.count,
12
+ cdpPort: options.cdpPort,
13
+ cdpHost: options.cdpHost,
14
+ allowRemote: options.allowRemote,
15
+ });
16
+ }
17
+ catch (error) {
18
+ const message = errorMessage(error);
19
+ process.stderr.write(`${message}\n`);
20
+ process.exitCode = 1;
21
+ return;
22
+ }
23
+ if (options.json) {
24
+ process.stdout.write(JSON.stringify(result, null, 2) + "\n");
25
+ }
26
+ else {
27
+ process.stdout.write(`Search: "${result.query}"\n\n`);
28
+ const { posts } = result;
29
+ if (posts.length === 0) {
30
+ process.stdout.write("No posts found.\n");
31
+ return;
32
+ }
33
+ for (const post of posts) {
34
+ const author = post.authorName ?? "Unknown";
35
+ process.stdout.write(` ${author}\n`);
36
+ if (post.url) {
37
+ process.stdout.write(` URL: ${post.url}\n`);
38
+ }
39
+ if (post.authorHeadline) {
40
+ process.stdout.write(` Headline: ${post.authorHeadline}\n`);
41
+ }
42
+ if (post.text) {
43
+ const preview = post.text.length > 120
44
+ ? post.text.substring(0, 120) + "..."
45
+ : post.text;
46
+ process.stdout.write(` Text: ${preview}\n`);
47
+ }
48
+ process.stdout.write(` Reactions: ${String(post.reactionCount)} Comments: ${String(post.commentCount)} Reposts: ${String(post.shareCount)}\n`);
49
+ process.stdout.write("\n");
50
+ }
51
+ if (result.nextCursor) {
52
+ process.stdout.write(`More results available. Use --cursor ${String(result.nextCursor)} for next page.\n`);
53
+ }
54
+ }
55
+ }
56
+ //# sourceMappingURL=search-posts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search-posts.js","sourceRoot":"","sources":["../../src/handlers/search-posts.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=search-posts.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search-posts.test.d.ts","sourceRoot":"","sources":["../../src/handlers/search-posts.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,112 @@
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
+ searchPosts: vi.fn(),
9
+ };
10
+ });
11
+ import { searchPosts } from "@lhremote/core";
12
+ import { handleSearchPosts } from "./search-posts.js";
13
+ import { getStderr, getStdout } from "./testing/mock-helpers.js";
14
+ const MOCK_RESULTS = {
15
+ query: "AI agents",
16
+ posts: [
17
+ {
18
+ url: "https://www.linkedin.com/feed/update/urn:li:activity:7123456789012345678/",
19
+ authorName: "Jane Smith",
20
+ authorHeadline: "CEO at Acme Corp",
21
+ authorProfileUrl: "https://www.linkedin.com/in/janesmith",
22
+ authorPublicId: null,
23
+ text: "Excited about AI agents!",
24
+ mediaType: null,
25
+ reactionCount: 42,
26
+ commentCount: 7,
27
+ shareCount: 3,
28
+ timestamp: null,
29
+ hashtags: [],
30
+ },
31
+ {
32
+ url: "https://www.linkedin.com/feed/update/urn:li:activity:7234567890123456789/",
33
+ authorName: "Bob",
34
+ authorHeadline: null,
35
+ authorProfileUrl: null,
36
+ authorPublicId: null,
37
+ text: null,
38
+ mediaType: null,
39
+ reactionCount: 0,
40
+ commentCount: 0,
41
+ shareCount: 0,
42
+ timestamp: null,
43
+ hashtags: [],
44
+ },
45
+ ],
46
+ nextCursor: null,
47
+ };
48
+ describe("handleSearchPosts", () => {
49
+ const originalExitCode = process.exitCode;
50
+ let stdoutSpy;
51
+ let stderrSpy;
52
+ beforeEach(() => {
53
+ process.exitCode = undefined;
54
+ vi.clearAllMocks();
55
+ stdoutSpy = vi.spyOn(process.stdout, "write").mockReturnValue(true);
56
+ stderrSpy = vi.spyOn(process.stderr, "write").mockReturnValue(true);
57
+ });
58
+ afterEach(() => {
59
+ process.exitCode = originalExitCode;
60
+ vi.restoreAllMocks();
61
+ });
62
+ it("prints JSON with --json", async () => {
63
+ vi.mocked(searchPosts).mockResolvedValue(MOCK_RESULTS);
64
+ await handleSearchPosts("AI agents", { json: true });
65
+ expect(process.exitCode).toBeUndefined();
66
+ const output = JSON.parse(getStdout(stdoutSpy));
67
+ expect(output.query).toBe("AI agents");
68
+ expect(output.posts).toHaveLength(2);
69
+ expect(output.nextCursor).toBeNull();
70
+ });
71
+ it("prints human-readable output by default", async () => {
72
+ vi.mocked(searchPosts).mockResolvedValue(MOCK_RESULTS);
73
+ await handleSearchPosts("AI agents", {});
74
+ expect(process.exitCode).toBeUndefined();
75
+ const output = getStdout(stdoutSpy);
76
+ expect(output).toContain('"AI agents"');
77
+ expect(output).toContain("Jane Smith");
78
+ expect(output).toContain("CEO at Acme Corp");
79
+ expect(output).toContain("Excited about AI agents!");
80
+ expect(output).toContain("Reactions: 42");
81
+ expect(output).toContain("Comments: 7");
82
+ expect(output).toContain("Reposts: 3");
83
+ });
84
+ it("does not show pagination hint when nextCursor is null", async () => {
85
+ vi.mocked(searchPosts).mockResolvedValue(MOCK_RESULTS);
86
+ await handleSearchPosts("AI agents", {});
87
+ const output = getStdout(stdoutSpy);
88
+ expect(output).not.toContain("--cursor");
89
+ });
90
+ it("handles empty results", async () => {
91
+ vi.mocked(searchPosts).mockResolvedValue({
92
+ query: "nonexistent",
93
+ posts: [],
94
+ nextCursor: null,
95
+ });
96
+ await handleSearchPosts("nonexistent", {});
97
+ const output = getStdout(stdoutSpy);
98
+ expect(output).toContain("No posts found");
99
+ });
100
+ it("passes pagination options to operation", async () => {
101
+ vi.mocked(searchPosts).mockResolvedValue(MOCK_RESULTS);
102
+ await handleSearchPosts("AI agents", { cursor: 10, count: 5 });
103
+ expect(searchPosts).toHaveBeenCalledWith(expect.objectContaining({ query: "AI agents", cursor: 10, count: 5 }));
104
+ });
105
+ it("sets exitCode on error", async () => {
106
+ vi.mocked(searchPosts).mockRejectedValue(new Error("connection refused"));
107
+ await handleSearchPosts("AI agents", {});
108
+ expect(process.exitCode).toBe(1);
109
+ expect(getStderr(stderrSpy)).toContain("connection refused");
110
+ });
111
+ });
112
+ //# sourceMappingURL=search-posts.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search-posts.test.js","sourceRoot":"","sources":["../../src/handlers/search-posts.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ /** Handle the {@link https://github.com/alexey-pelykh/lhremote#send-inmail | send-inmail} CLI command. */
2
+ export declare function handleSendInmail(options: {
3
+ personId?: number;
4
+ url?: string;
5
+ messageTemplate: string;
6
+ subjectTemplate?: string;
7
+ rejectIfReplied?: boolean;
8
+ proceedOnOutOfCredits?: boolean;
9
+ keepCampaign?: boolean;
10
+ cdpPort?: number;
11
+ cdpHost?: string;
12
+ allowRemote?: boolean;
13
+ json?: boolean;
14
+ }): Promise<void>;
15
+ //# sourceMappingURL=send-inmail.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"send-inmail.d.ts","sourceRoot":"","sources":["../../src/handlers/send-inmail.ts"],"names":[],"mappings":"AAWA,0GAA0G;AAC1G,wBAAsB,gBAAgB,CAAC,OAAO,EAAE;IAC9C,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,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,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 { errorMessage, sendInmail, CampaignExecutionError, CampaignTimeoutError, } from "@lhremote/core";
4
+ /** Handle the {@link https://github.com/alexey-pelykh/lhremote#send-inmail | send-inmail} CLI command. */
5
+ export async function handleSendInmail(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 InMail...\n");
32
+ let result;
33
+ try {
34
+ result = await sendInmail({
35
+ personId: options.personId,
36
+ url: options.url,
37
+ messageTemplate: parsedMessageTemplate,
38
+ subjectTemplate: parsedSubjectTemplate,
39
+ rejectIfReplied: options.rejectIfReplied,
40
+ proceedOnOutOfCredits: options.proceedOnOutOfCredits,
41
+ keepCampaign: options.keepCampaign,
42
+ cdpPort: options.cdpPort,
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(`InMail ${result.success ? "sent" : "failed"} (person #${String(result.personId)})\n`);
63
+ }
64
+ }
65
+ //# sourceMappingURL=send-inmail.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"send-inmail.js","sourceRoot":"","sources":["../../src/handlers/send-inmail.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=send-inmail.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"send-inmail.test.d.ts","sourceRoot":"","sources":["../../src/handlers/send-inmail.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
+ sendInmail: vi.fn(),
9
+ };
10
+ });
11
+ import { CampaignExecutionError, CampaignTimeoutError, sendInmail, } from "@lhremote/core";
12
+ import { handleSendInmail } from "./send-inmail.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("handleSendInmail", () => {
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(sendInmail).mockResolvedValue(MOCK_RESULT);
33
+ await handleSendInmail({ 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(sendInmail).mockResolvedValue(MOCK_RESULT);
42
+ await handleSendInmail({ 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 handleSendInmail({ 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(sendInmail).not.toHaveBeenCalled();
51
+ });
52
+ it("returns error for invalid JSON in messageTemplate", async () => {
53
+ await handleSendInmail({ personId: 100, messageTemplate: "not json" });
54
+ expect(process.exitCode).toBe(1);
55
+ expect(getStderr(stderrSpy)).toContain("Invalid JSON in --message-template");
56
+ expect(sendInmail).not.toHaveBeenCalled();
57
+ });
58
+ it("returns error for invalid JSON in subjectTemplate", async () => {
59
+ await handleSendInmail({ 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(sendInmail).not.toHaveBeenCalled();
63
+ });
64
+ it("handles CampaignExecutionError", async () => {
65
+ vi.mocked(sendInmail).mockRejectedValue(new CampaignExecutionError("Person 100 not found"));
66
+ await handleSendInmail({ 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(sendInmail).mockRejectedValue(new CampaignTimeoutError("Timed out", 42));
72
+ await handleSendInmail({ personId: 100, messageTemplate: '{"type":"text","value":"Hello"}' });
73
+ expect(process.exitCode).toBe(1);
74
+ expect(getStderr(stderrSpy)).toContain("Timed out");
75
+ });
76
+ });
77
+ //# sourceMappingURL=send-inmail.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"send-inmail.test.js","sourceRoot":"","sources":["../../src/handlers/send-inmail.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ /** Handle the {@link https://github.com/alexey-pelykh/lhremote#send-invite | send-invite} CLI command. */
2
+ export declare function handleSendInvite(options: {
3
+ personId?: number;
4
+ url?: string;
5
+ messageTemplate?: string;
6
+ saveAsLeadSn?: boolean;
7
+ keepCampaign?: boolean;
8
+ cdpPort?: number;
9
+ cdpHost?: string;
10
+ allowRemote?: boolean;
11
+ json?: boolean;
12
+ }): Promise<void>;
13
+ //# sourceMappingURL=send-invite.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"send-invite.d.ts","sourceRoot":"","sources":["../../src/handlers/send-invite.ts"],"names":[],"mappings":"AAWA,0GAA0G;AAC1G,wBAAsB,gBAAgB,CAAC,OAAO,EAAE;IAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,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,CAiDhB"}
@@ -0,0 +1,54 @@
1
+ // SPDX-License-Identifier: AGPL-3.0-only
2
+ // Copyright (C) 2026 Oleksii PELYKH
3
+ import { errorMessage, sendInvite, CampaignExecutionError, CampaignTimeoutError, } from "@lhremote/core";
4
+ /** Handle the {@link https://github.com/alexey-pelykh/lhremote#send-invite | send-invite} CLI command. */
5
+ export async function handleSendInvite(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("Sending invite...\n");
23
+ let result;
24
+ try {
25
+ result = await sendInvite({
26
+ personId: options.personId,
27
+ url: options.url,
28
+ messageTemplate: parsedMessageTemplate,
29
+ saveAsLeadSN: options.saveAsLeadSn,
30
+ keepCampaign: options.keepCampaign,
31
+ cdpPort: options.cdpPort,
32
+ cdpHost: options.cdpHost,
33
+ allowRemote: options.allowRemote,
34
+ });
35
+ }
36
+ catch (error) {
37
+ if (error instanceof CampaignExecutionError || error instanceof CampaignTimeoutError) {
38
+ process.stderr.write(`${error.message}\n`);
39
+ }
40
+ else {
41
+ process.stderr.write(`${errorMessage(error)}\n`);
42
+ }
43
+ process.exitCode = 1;
44
+ return;
45
+ }
46
+ process.stderr.write("Done.\n");
47
+ if (options.json) {
48
+ process.stdout.write(JSON.stringify(result, null, 2) + "\n");
49
+ }
50
+ else {
51
+ process.stdout.write(`Invite ${result.success ? "sent" : "failed"} (person #${String(result.personId)})\n`);
52
+ }
53
+ }
54
+ //# sourceMappingURL=send-invite.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"send-invite.js","sourceRoot":"","sources":["../../src/handlers/send-invite.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,YAAY,EACZ,UAAU,EAEV,sBAAsB,EACtB,oBAAoB,GACrB,MAAM,gBAAgB,CAAC;AAExB,0GAA0G;AAC1G,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,OAUtC;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,qBAAqB,CAAC,CAAC;IAE5C,IAAI,MAA6B,CAAC;IAClC,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,UAAU,CAAC;YACxB,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,eAAe,EAAE,qBAAqB;YACtC,YAAY,EAAE,OAAO,CAAC,YAAY;YAClC,YAAY,EAAE,OAAO,CAAC,YAAY;YAClC,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,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,UAAU,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,aAAa,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9G,CAAC;AACH,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=send-invite.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"send-invite.test.d.ts","sourceRoot":"","sources":["../../src/handlers/send-invite.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
+ sendInvite: vi.fn(),
9
+ };
10
+ });
11
+ import { CampaignExecutionError, CampaignTimeoutError, sendInvite, } from "@lhremote/core";
12
+ import { handleSendInvite } from "./send-invite.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("handleSendInvite", () => {
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(sendInvite).mockResolvedValue(MOCK_RESULT);
33
+ await handleSendInvite({ personId: 100, 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(sendInvite).mockResolvedValue(MOCK_RESULT);
42
+ await handleSendInvite({ personId: 100 });
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 handleSendInvite({});
48
+ expect(process.exitCode).toBe(1);
49
+ expect(getStderr(stderrSpy)).toContain("Exactly one of --person-id or --url");
50
+ expect(sendInvite).not.toHaveBeenCalled();
51
+ });
52
+ it("returns error for invalid JSON in messageTemplate", async () => {
53
+ await handleSendInvite({ personId: 100, messageTemplate: "not json" });
54
+ expect(process.exitCode).toBe(1);
55
+ expect(getStderr(stderrSpy)).toContain("Invalid JSON in --message-template");
56
+ expect(sendInvite).not.toHaveBeenCalled();
57
+ });
58
+ it("handles CampaignExecutionError", async () => {
59
+ vi.mocked(sendInvite).mockRejectedValue(new CampaignExecutionError("Person 100 not found"));
60
+ await handleSendInvite({ 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(sendInvite).mockRejectedValue(new CampaignTimeoutError("Timed out", 42));
66
+ await handleSendInvite({ personId: 100 });
67
+ expect(process.exitCode).toBe(1);
68
+ expect(getStderr(stderrSpy)).toContain("Timed out");
69
+ });
70
+ });
71
+ //# sourceMappingURL=send-invite.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"send-invite.test.js","sourceRoot":"","sources":["../../src/handlers/send-invite.test.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"start-instance.d.ts","sourceRoot":"","sources":["../../src/handlers/start-instance.ts"],"names":[],"mappings":"AAUA,mHAAmH;AACnH,wBAAsB,mBAAmB,CACvC,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE;IAAE,OAAO,CAAC,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAAC,WAAW,CAAC,EAAE,OAAO,CAAA;CAAE,GACrE,OAAO,CAAC,IAAI,CAAC,CA+Cf"}
1
+ {"version":3,"file":"start-instance.d.ts","sourceRoot":"","sources":["../../src/handlers/start-instance.ts"],"names":[],"mappings":"AAUA,mHAAmH;AACnH,wBAAsB,mBAAmB,CACvC,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE;IAAE,OAAO,CAAC,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAAC,WAAW,CAAC,EAAE,OAAO,CAAA;CAAE,GACrE,OAAO,CAAC,IAAI,CAAC,CAyDf"}
@@ -1,10 +1,19 @@
1
1
  // SPDX-License-Identifier: AGPL-3.0-only
2
2
  // Copyright (C) 2026 Oleksii PELYKH
3
- import { DEFAULT_CDP_PORT, errorMessage, LauncherService, startInstanceWithRecovery, } from "@lhremote/core";
3
+ import { errorMessage, LauncherService, resolveAppPort, startInstanceWithRecovery, } from "@lhremote/core";
4
4
  /** Handle the {@link https://github.com/alexey-pelykh/lhremote#account--instance | start-instance} CLI command. */
5
5
  export async function handleStartInstance(accountIdArg, options) {
6
6
  const accountId = Number(accountIdArg);
7
- const cdpPort = options.cdpPort ?? DEFAULT_CDP_PORT;
7
+ let cdpPort;
8
+ try {
9
+ cdpPort = options.cdpPort ?? await resolveAppPort("launcher");
10
+ }
11
+ catch (error) {
12
+ const message = errorMessage(error);
13
+ process.stderr.write(`${message}\n`);
14
+ process.exitCode = 1;
15
+ return;
16
+ }
8
17
  const launcher = new LauncherService(cdpPort, {
9
18
  ...(options.cdpHost !== undefined && { host: options.cdpHost }),
10
19
  ...(options.allowRemote !== undefined && { allowRemote: options.allowRemote }),