@lhremote/core 0.8.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 (438) hide show
  1. package/dist/cdp/app-discovery.d.ts +57 -0
  2. package/dist/cdp/app-discovery.d.ts.map +1 -1
  3. package/dist/cdp/app-discovery.js +90 -7
  4. package/dist/cdp/app-discovery.js.map +1 -1
  5. package/dist/cdp/app-discovery.test.js +180 -9
  6. package/dist/cdp/app-discovery.test.js.map +1 -1
  7. package/dist/cdp/client.d.ts +8 -1
  8. package/dist/cdp/client.d.ts.map +1 -1
  9. package/dist/cdp/client.js +8 -1
  10. package/dist/cdp/client.js.map +1 -1
  11. package/dist/cdp/discovery.d.ts.map +1 -1
  12. package/dist/cdp/discovery.js +5 -1
  13. package/dist/cdp/discovery.js.map +1 -1
  14. package/dist/cdp/discovery.test.js +7 -0
  15. package/dist/cdp/discovery.test.js.map +1 -1
  16. package/dist/cdp/index.d.ts +1 -1
  17. package/dist/cdp/index.d.ts.map +1 -1
  18. package/dist/cdp/index.js +1 -1
  19. package/dist/cdp/index.js.map +1 -1
  20. package/dist/cdp/instance-discovery.d.ts.map +1 -1
  21. package/dist/cdp/instance-discovery.js +25 -10
  22. package/dist/cdp/instance-discovery.js.map +1 -1
  23. package/dist/cdp/instance-discovery.test.js +17 -0
  24. package/dist/cdp/instance-discovery.test.js.map +1 -1
  25. package/dist/cdp/testing/launch-chromium.d.ts +1 -1
  26. package/dist/cdp/testing/launch-chromium.js +2 -2
  27. package/dist/db/client.d.ts.map +1 -1
  28. package/dist/db/client.js +3 -0
  29. package/dist/db/client.js.map +1 -1
  30. package/dist/db/repositories/collection-list.integration.test.js +6 -4
  31. package/dist/db/repositories/collection-list.integration.test.js.map +1 -1
  32. package/dist/index.d.ts +6 -6
  33. package/dist/index.d.ts.map +1 -1
  34. package/dist/index.js +6 -6
  35. package/dist/index.js.map +1 -1
  36. package/dist/linkedin/dom-automation-retry.test.d.ts +2 -0
  37. package/dist/linkedin/dom-automation-retry.test.d.ts.map +1 -0
  38. package/dist/linkedin/dom-automation-retry.test.js +51 -0
  39. package/dist/linkedin/dom-automation-retry.test.js.map +1 -0
  40. package/dist/linkedin/dom-automation.d.ts +160 -3
  41. package/dist/linkedin/dom-automation.d.ts.map +1 -1
  42. package/dist/linkedin/dom-automation.js +489 -14
  43. package/dist/linkedin/dom-automation.js.map +1 -1
  44. package/dist/linkedin/humanized-mouse.d.ts +69 -0
  45. package/dist/linkedin/humanized-mouse.d.ts.map +1 -0
  46. package/dist/linkedin/humanized-mouse.js +109 -0
  47. package/dist/linkedin/humanized-mouse.js.map +1 -0
  48. package/dist/linkedin/index.d.ts +2 -1
  49. package/dist/linkedin/index.d.ts.map +1 -1
  50. package/dist/linkedin/index.js +2 -1
  51. package/dist/linkedin/index.js.map +1 -1
  52. package/dist/operations/add-people-to-collection.d.ts +1 -1
  53. package/dist/operations/add-people-to-collection.d.ts.map +1 -1
  54. package/dist/operations/add-people-to-collection.js +3 -6
  55. package/dist/operations/add-people-to-collection.js.map +1 -1
  56. package/dist/operations/build-linkedin-url.test.d.ts +2 -0
  57. package/dist/operations/build-linkedin-url.test.d.ts.map +1 -0
  58. package/dist/operations/build-linkedin-url.test.js +158 -0
  59. package/dist/operations/build-linkedin-url.test.js.map +1 -0
  60. package/dist/operations/campaign-add-action.d.ts +1 -1
  61. package/dist/operations/campaign-add-action.d.ts.map +1 -1
  62. package/dist/operations/campaign-add-action.js +3 -6
  63. package/dist/operations/campaign-add-action.js.map +1 -1
  64. package/dist/operations/campaign-create.d.ts +1 -1
  65. package/dist/operations/campaign-create.d.ts.map +1 -1
  66. package/dist/operations/campaign-create.js +3 -6
  67. package/dist/operations/campaign-create.js.map +1 -1
  68. package/dist/operations/campaign-delete.d.ts +1 -1
  69. package/dist/operations/campaign-delete.d.ts.map +1 -1
  70. package/dist/operations/campaign-delete.js +3 -6
  71. package/dist/operations/campaign-delete.js.map +1 -1
  72. package/dist/operations/campaign-erase.d.ts +1 -1
  73. package/dist/operations/campaign-erase.d.ts.map +1 -1
  74. package/dist/operations/campaign-erase.js +3 -6
  75. package/dist/operations/campaign-erase.js.map +1 -1
  76. package/dist/operations/campaign-exclude-add.d.ts +1 -1
  77. package/dist/operations/campaign-exclude-add.d.ts.map +1 -1
  78. package/dist/operations/campaign-exclude-add.js +3 -6
  79. package/dist/operations/campaign-exclude-add.js.map +1 -1
  80. package/dist/operations/campaign-exclude-list.d.ts +1 -1
  81. package/dist/operations/campaign-exclude-list.d.ts.map +1 -1
  82. package/dist/operations/campaign-exclude-list.js +3 -6
  83. package/dist/operations/campaign-exclude-list.js.map +1 -1
  84. package/dist/operations/campaign-exclude-remove.d.ts +1 -1
  85. package/dist/operations/campaign-exclude-remove.d.ts.map +1 -1
  86. package/dist/operations/campaign-exclude-remove.js +3 -6
  87. package/dist/operations/campaign-exclude-remove.js.map +1 -1
  88. package/dist/operations/campaign-export.d.ts +1 -1
  89. package/dist/operations/campaign-export.d.ts.map +1 -1
  90. package/dist/operations/campaign-export.js +3 -6
  91. package/dist/operations/campaign-export.js.map +1 -1
  92. package/dist/operations/campaign-get.d.ts +1 -1
  93. package/dist/operations/campaign-get.d.ts.map +1 -1
  94. package/dist/operations/campaign-get.js +3 -6
  95. package/dist/operations/campaign-get.js.map +1 -1
  96. package/dist/operations/campaign-list-people.d.ts +1 -1
  97. package/dist/operations/campaign-list-people.d.ts.map +1 -1
  98. package/dist/operations/campaign-list-people.js +3 -6
  99. package/dist/operations/campaign-list-people.js.map +1 -1
  100. package/dist/operations/campaign-list.d.ts +1 -1
  101. package/dist/operations/campaign-list.d.ts.map +1 -1
  102. package/dist/operations/campaign-list.js +3 -6
  103. package/dist/operations/campaign-list.js.map +1 -1
  104. package/dist/operations/campaign-move-next.d.ts +1 -1
  105. package/dist/operations/campaign-move-next.d.ts.map +1 -1
  106. package/dist/operations/campaign-move-next.js +3 -6
  107. package/dist/operations/campaign-move-next.js.map +1 -1
  108. package/dist/operations/campaign-remove-action.d.ts +1 -1
  109. package/dist/operations/campaign-remove-action.d.ts.map +1 -1
  110. package/dist/operations/campaign-remove-action.js +3 -6
  111. package/dist/operations/campaign-remove-action.js.map +1 -1
  112. package/dist/operations/campaign-remove-people.d.ts +1 -1
  113. package/dist/operations/campaign-remove-people.d.ts.map +1 -1
  114. package/dist/operations/campaign-remove-people.js +3 -6
  115. package/dist/operations/campaign-remove-people.js.map +1 -1
  116. package/dist/operations/campaign-reorder-actions.d.ts +1 -1
  117. package/dist/operations/campaign-reorder-actions.d.ts.map +1 -1
  118. package/dist/operations/campaign-reorder-actions.js +3 -6
  119. package/dist/operations/campaign-reorder-actions.js.map +1 -1
  120. package/dist/operations/campaign-retry.d.ts +1 -1
  121. package/dist/operations/campaign-retry.d.ts.map +1 -1
  122. package/dist/operations/campaign-retry.js +3 -6
  123. package/dist/operations/campaign-retry.js.map +1 -1
  124. package/dist/operations/campaign-start.d.ts +1 -1
  125. package/dist/operations/campaign-start.d.ts.map +1 -1
  126. package/dist/operations/campaign-start.js +3 -6
  127. package/dist/operations/campaign-start.js.map +1 -1
  128. package/dist/operations/campaign-statistics.d.ts +1 -1
  129. package/dist/operations/campaign-statistics.d.ts.map +1 -1
  130. package/dist/operations/campaign-statistics.js +3 -6
  131. package/dist/operations/campaign-statistics.js.map +1 -1
  132. package/dist/operations/campaign-status.d.ts +1 -1
  133. package/dist/operations/campaign-status.d.ts.map +1 -1
  134. package/dist/operations/campaign-status.js +3 -6
  135. package/dist/operations/campaign-status.js.map +1 -1
  136. package/dist/operations/campaign-stop.d.ts +1 -1
  137. package/dist/operations/campaign-stop.d.ts.map +1 -1
  138. package/dist/operations/campaign-stop.js +3 -6
  139. package/dist/operations/campaign-stop.js.map +1 -1
  140. package/dist/operations/campaign-update-action.d.ts +1 -1
  141. package/dist/operations/campaign-update-action.d.ts.map +1 -1
  142. package/dist/operations/campaign-update-action.js +3 -6
  143. package/dist/operations/campaign-update-action.js.map +1 -1
  144. package/dist/operations/campaign-update.d.ts +1 -1
  145. package/dist/operations/campaign-update.d.ts.map +1 -1
  146. package/dist/operations/campaign-update.js +3 -6
  147. package/dist/operations/campaign-update.js.map +1 -1
  148. package/dist/operations/check-replies.d.ts +3 -1
  149. package/dist/operations/check-replies.d.ts.map +1 -1
  150. package/dist/operations/check-replies.js +132 -17
  151. package/dist/operations/check-replies.js.map +1 -1
  152. package/dist/operations/check-replies.test.js +177 -17
  153. package/dist/operations/check-replies.test.js.map +1 -1
  154. package/dist/operations/collect-people.d.ts +1 -1
  155. package/dist/operations/collect-people.d.ts.map +1 -1
  156. package/dist/operations/collect-people.js +3 -6
  157. package/dist/operations/collect-people.js.map +1 -1
  158. package/dist/operations/comment-on-post.d.ts +4 -1
  159. package/dist/operations/comment-on-post.d.ts.map +1 -1
  160. package/dist/operations/comment-on-post.js +15 -19
  161. package/dist/operations/comment-on-post.js.map +1 -1
  162. package/dist/operations/comment-on-post.test.js +8 -6
  163. package/dist/operations/comment-on-post.test.js.map +1 -1
  164. package/dist/operations/create-collection.d.ts +1 -1
  165. package/dist/operations/create-collection.d.ts.map +1 -1
  166. package/dist/operations/create-collection.js +3 -6
  167. package/dist/operations/create-collection.js.map +1 -1
  168. package/dist/operations/delete-collection.d.ts +1 -1
  169. package/dist/operations/delete-collection.d.ts.map +1 -1
  170. package/dist/operations/delete-collection.js +3 -6
  171. package/dist/operations/delete-collection.js.map +1 -1
  172. package/dist/operations/dismiss-errors.d.ts +7 -4
  173. package/dist/operations/dismiss-errors.d.ts.map +1 -1
  174. package/dist/operations/dismiss-errors.js +52 -33
  175. package/dist/operations/dismiss-errors.js.map +1 -1
  176. package/dist/operations/dismiss-errors.test.js +53 -6
  177. package/dist/operations/dismiss-errors.test.js.map +1 -1
  178. package/dist/operations/endorse-skills.test.d.ts +2 -0
  179. package/dist/operations/endorse-skills.test.d.ts.map +1 -0
  180. package/dist/operations/endorse-skills.test.js +70 -0
  181. package/dist/operations/endorse-skills.test.js.map +1 -0
  182. package/dist/operations/enrich-profile.test.d.ts +2 -0
  183. package/dist/operations/enrich-profile.test.d.ts.map +1 -0
  184. package/dist/operations/enrich-profile.test.js +73 -0
  185. package/dist/operations/enrich-profile.test.js.map +1 -0
  186. package/dist/operations/ephemeral-action.d.ts +1 -1
  187. package/dist/operations/ephemeral-action.d.ts.map +1 -1
  188. package/dist/operations/ephemeral-action.js +3 -6
  189. package/dist/operations/ephemeral-action.js.map +1 -1
  190. package/dist/operations/ephemeral-action.test.d.ts +2 -0
  191. package/dist/operations/ephemeral-action.test.d.ts.map +1 -0
  192. package/dist/operations/ephemeral-action.test.js +140 -0
  193. package/dist/operations/ephemeral-action.test.js.map +1 -0
  194. package/dist/operations/follow-person.test.d.ts +2 -0
  195. package/dist/operations/follow-person.test.d.ts.map +1 -0
  196. package/dist/operations/follow-person.test.js +57 -0
  197. package/dist/operations/follow-person.test.js.map +1 -0
  198. package/dist/operations/get-action-budget.d.ts +1 -1
  199. package/dist/operations/get-action-budget.d.ts.map +1 -1
  200. package/dist/operations/get-action-budget.js +3 -6
  201. package/dist/operations/get-action-budget.js.map +1 -1
  202. package/dist/operations/get-errors.d.ts +5 -1
  203. package/dist/operations/get-errors.d.ts.map +1 -1
  204. package/dist/operations/get-errors.js +55 -33
  205. package/dist/operations/get-errors.js.map +1 -1
  206. package/dist/operations/get-errors.test.js +54 -55
  207. package/dist/operations/get-errors.test.js.map +1 -1
  208. package/dist/operations/get-feed.d.ts +83 -4
  209. package/dist/operations/get-feed.d.ts.map +1 -1
  210. package/dist/operations/get-feed.js +400 -153
  211. package/dist/operations/get-feed.js.map +1 -1
  212. package/dist/operations/get-feed.test.js +416 -190
  213. package/dist/operations/get-feed.test.js.map +1 -1
  214. package/dist/operations/get-post-engagers.d.ts +6 -3
  215. package/dist/operations/get-post-engagers.d.ts.map +1 -1
  216. package/dist/operations/get-post-engagers.js +278 -78
  217. package/dist/operations/get-post-engagers.js.map +1 -1
  218. package/dist/operations/get-post-engagers.test.js +292 -14
  219. package/dist/operations/get-post-engagers.test.js.map +1 -1
  220. package/dist/operations/get-post-stats.d.ts +8 -3
  221. package/dist/operations/get-post-stats.d.ts.map +1 -1
  222. package/dist/operations/get-post-stats.js +101 -37
  223. package/dist/operations/get-post-stats.js.map +1 -1
  224. package/dist/operations/get-post-stats.test.js +137 -2
  225. package/dist/operations/get-post-stats.test.js.map +1 -1
  226. package/dist/operations/get-post.d.ts +9 -150
  227. package/dist/operations/get-post.d.ts.map +1 -1
  228. package/dist/operations/get-post.js +356 -210
  229. package/dist/operations/get-post.js.map +1 -1
  230. package/dist/operations/get-post.test.js +210 -387
  231. package/dist/operations/get-post.test.js.map +1 -1
  232. package/dist/operations/get-profile-activity.d.ts +13 -92
  233. package/dist/operations/get-profile-activity.d.ts.map +1 -1
  234. package/dist/operations/get-profile-activity.js +305 -105
  235. package/dist/operations/get-profile-activity.js.map +1 -1
  236. package/dist/operations/get-profile-activity.test.js +277 -158
  237. package/dist/operations/get-profile-activity.test.js.map +1 -1
  238. package/dist/operations/get-throttle-status.d.ts +1 -1
  239. package/dist/operations/get-throttle-status.d.ts.map +1 -1
  240. package/dist/operations/get-throttle-status.js +4 -10
  241. package/dist/operations/get-throttle-status.js.map +1 -1
  242. package/dist/operations/import-people-from-collection.d.ts +1 -1
  243. package/dist/operations/import-people-from-collection.d.ts.map +1 -1
  244. package/dist/operations/import-people-from-collection.js +3 -6
  245. package/dist/operations/import-people-from-collection.js.map +1 -1
  246. package/dist/operations/import-people-from-urls.d.ts +1 -1
  247. package/dist/operations/import-people-from-urls.d.ts.map +1 -1
  248. package/dist/operations/import-people-from-urls.js +3 -6
  249. package/dist/operations/import-people-from-urls.js.map +1 -1
  250. package/dist/operations/index.d.ts +2 -2
  251. package/dist/operations/index.d.ts.map +1 -1
  252. package/dist/operations/index.js +2 -1
  253. package/dist/operations/index.js.map +1 -1
  254. package/dist/operations/like-person-posts.test.d.ts +2 -0
  255. package/dist/operations/like-person-posts.test.d.ts.map +1 -0
  256. package/dist/operations/like-person-posts.test.js +103 -0
  257. package/dist/operations/like-person-posts.test.js.map +1 -0
  258. package/dist/operations/list-collections.d.ts +1 -1
  259. package/dist/operations/list-collections.d.ts.map +1 -1
  260. package/dist/operations/list-collections.js +3 -6
  261. package/dist/operations/list-collections.js.map +1 -1
  262. package/dist/operations/message-person.test.d.ts +2 -0
  263. package/dist/operations/message-person.test.d.ts.map +1 -0
  264. package/dist/operations/message-person.test.js +108 -0
  265. package/dist/operations/message-person.test.js.map +1 -0
  266. package/dist/operations/navigate-away.d.ts +14 -0
  267. package/dist/operations/navigate-away.d.ts.map +1 -0
  268. package/dist/operations/navigate-away.js +24 -0
  269. package/dist/operations/navigate-away.js.map +1 -0
  270. package/dist/operations/navigate-away.test.d.ts +2 -0
  271. package/dist/operations/navigate-away.test.d.ts.map +1 -0
  272. package/dist/operations/navigate-away.test.js +51 -0
  273. package/dist/operations/navigate-away.test.js.map +1 -0
  274. package/dist/operations/query-messages.d.ts +1 -1
  275. package/dist/operations/query-messages.d.ts.map +1 -1
  276. package/dist/operations/query-messages.js +3 -6
  277. package/dist/operations/query-messages.js.map +1 -1
  278. package/dist/operations/react-to-post.d.ts +3 -0
  279. package/dist/operations/react-to-post.d.ts.map +1 -1
  280. package/dist/operations/react-to-post.js +13 -15
  281. package/dist/operations/react-to-post.js.map +1 -1
  282. package/dist/operations/react-to-post.test.js +8 -5
  283. package/dist/operations/react-to-post.test.js.map +1 -1
  284. package/dist/operations/remove-connection.test.d.ts +2 -0
  285. package/dist/operations/remove-connection.test.d.ts.map +1 -0
  286. package/dist/operations/remove-connection.test.js +45 -0
  287. package/dist/operations/remove-connection.test.js.map +1 -0
  288. package/dist/operations/remove-people-from-collection.d.ts +1 -1
  289. package/dist/operations/remove-people-from-collection.d.ts.map +1 -1
  290. package/dist/operations/remove-people-from-collection.js +3 -6
  291. package/dist/operations/remove-people-from-collection.js.map +1 -1
  292. package/dist/operations/resolve-linkedin-entity.d.ts.map +1 -1
  293. package/dist/operations/resolve-linkedin-entity.js +2 -2
  294. package/dist/operations/resolve-linkedin-entity.js.map +1 -1
  295. package/dist/operations/resolve-linkedin-entity.test.d.ts +2 -0
  296. package/dist/operations/resolve-linkedin-entity.test.d.ts.map +1 -0
  297. package/dist/operations/resolve-linkedin-entity.test.js +343 -0
  298. package/dist/operations/resolve-linkedin-entity.test.js.map +1 -0
  299. package/dist/operations/scrape-messaging-history.d.ts +2 -1
  300. package/dist/operations/scrape-messaging-history.d.ts.map +1 -1
  301. package/dist/operations/scrape-messaging-history.js +121 -18
  302. package/dist/operations/scrape-messaging-history.js.map +1 -1
  303. package/dist/operations/scrape-messaging-history.test.js +134 -12
  304. package/dist/operations/scrape-messaging-history.test.js.map +1 -1
  305. package/dist/operations/search-posts.d.ts +20 -112
  306. package/dist/operations/search-posts.d.ts.map +1 -1
  307. package/dist/operations/search-posts.js +369 -170
  308. package/dist/operations/search-posts.js.map +1 -1
  309. package/dist/operations/search-posts.test.js +273 -234
  310. package/dist/operations/search-posts.test.js.map +1 -1
  311. package/dist/operations/send-inmail.test.d.ts +2 -0
  312. package/dist/operations/send-inmail.test.d.ts.map +1 -0
  313. package/dist/operations/send-inmail.test.js +108 -0
  314. package/dist/operations/send-inmail.test.js.map +1 -0
  315. package/dist/operations/send-invite.test.d.ts +2 -0
  316. package/dist/operations/send-invite.test.d.ts.map +1 -0
  317. package/dist/operations/send-invite.test.js +59 -0
  318. package/dist/operations/send-invite.test.js.map +1 -0
  319. package/dist/operations/types.d.ts +24 -1
  320. package/dist/operations/types.d.ts.map +1 -1
  321. package/dist/operations/types.js +13 -1
  322. package/dist/operations/types.js.map +1 -1
  323. package/dist/operations/visit-profile.d.ts +1 -1
  324. package/dist/operations/visit-profile.d.ts.map +1 -1
  325. package/dist/operations/visit-profile.js +3 -6
  326. package/dist/operations/visit-profile.js.map +1 -1
  327. package/dist/services/account-resolution.d.ts +9 -4
  328. package/dist/services/account-resolution.d.ts.map +1 -1
  329. package/dist/services/account-resolution.js +60 -5
  330. package/dist/services/account-resolution.js.map +1 -1
  331. package/dist/services/app.d.ts +6 -2
  332. package/dist/services/app.d.ts.map +1 -1
  333. package/dist/services/app.js +18 -6
  334. package/dist/services/app.js.map +1 -1
  335. package/dist/services/app.test.js +41 -7
  336. package/dist/services/app.test.js.map +1 -1
  337. package/dist/services/campaign.d.ts +34 -2
  338. package/dist/services/campaign.d.ts.map +1 -1
  339. package/dist/services/campaign.js +108 -1
  340. package/dist/services/campaign.js.map +1 -1
  341. package/dist/services/errors.d.ts +2 -1
  342. package/dist/services/errors.d.ts.map +1 -1
  343. package/dist/services/errors.js +6 -3
  344. package/dist/services/errors.js.map +1 -1
  345. package/dist/services/index.d.ts +0 -1
  346. package/dist/services/index.d.ts.map +1 -1
  347. package/dist/services/index.js +0 -1
  348. package/dist/services/index.js.map +1 -1
  349. package/dist/services/instance-context.d.ts +5 -1
  350. package/dist/services/instance-context.d.ts.map +1 -1
  351. package/dist/services/instance-context.js +87 -28
  352. package/dist/services/instance-context.js.map +1 -1
  353. package/dist/services/instance-context.test.js +5 -1
  354. package/dist/services/instance-context.test.js.map +1 -1
  355. package/dist/services/instance-lifecycle.d.ts.map +1 -1
  356. package/dist/services/instance-lifecycle.js +32 -1
  357. package/dist/services/instance-lifecycle.js.map +1 -1
  358. package/dist/services/instance-lifecycle.test.js +52 -1
  359. package/dist/services/instance-lifecycle.test.js.map +1 -1
  360. package/dist/services/instance.d.ts +19 -7
  361. package/dist/services/instance.d.ts.map +1 -1
  362. package/dist/services/instance.js +56 -17
  363. package/dist/services/instance.js.map +1 -1
  364. package/dist/services/instance.test.js +65 -0
  365. package/dist/services/instance.test.js.map +1 -1
  366. package/dist/services/launcher.d.ts +47 -3
  367. package/dist/services/launcher.d.ts.map +1 -1
  368. package/dist/services/launcher.js +205 -33
  369. package/dist/services/launcher.js.map +1 -1
  370. package/dist/services/launcher.test.js +133 -6
  371. package/dist/services/launcher.test.js.map +1 -1
  372. package/dist/services/status.d.ts +6 -2
  373. package/dist/services/status.d.ts.map +1 -1
  374. package/dist/services/status.js +67 -34
  375. package/dist/services/status.js.map +1 -1
  376. package/dist/services/status.test.js +9 -2
  377. package/dist/services/status.test.js.map +1 -1
  378. package/dist/testing/e2e-helpers.d.ts +23 -1
  379. package/dist/testing/e2e-helpers.d.ts.map +1 -1
  380. package/dist/testing/e2e-helpers.js +110 -5
  381. package/dist/testing/e2e-helpers.js.map +1 -1
  382. package/dist/testing/index.d.ts +1 -1
  383. package/dist/testing/index.d.ts.map +1 -1
  384. package/dist/testing/index.js +1 -1
  385. package/dist/testing/index.js.map +1 -1
  386. package/dist/types/account.d.ts +1 -1
  387. package/dist/types/feed.d.ts +1 -3
  388. package/dist/types/feed.d.ts.map +1 -1
  389. package/dist/types/index.d.ts +0 -1
  390. package/dist/types/index.d.ts.map +1 -1
  391. package/dist/utils/cdp-port.d.ts.map +1 -1
  392. package/dist/utils/cdp-port.js +3 -1
  393. package/dist/utils/cdp-port.js.map +1 -1
  394. package/dist/utils/cdp-port.test.js +1 -1
  395. package/dist/utils/cdp-port.test.js.map +1 -1
  396. package/dist/utils/delay.d.ts +79 -0
  397. package/dist/utils/delay.d.ts.map +1 -1
  398. package/dist/utils/delay.js +118 -0
  399. package/dist/utils/delay.js.map +1 -1
  400. package/dist/utils/delay.test.js +111 -1
  401. package/dist/utils/delay.test.js.map +1 -1
  402. package/dist/utils/index.d.ts +2 -1
  403. package/dist/utils/index.d.ts.map +1 -1
  404. package/dist/utils/index.js +2 -1
  405. package/dist/utils/index.js.map +1 -1
  406. package/dist/utils/session-pacer.d.ts +27 -0
  407. package/dist/utils/session-pacer.d.ts.map +1 -0
  408. package/dist/utils/session-pacer.js +55 -0
  409. package/dist/utils/session-pacer.js.map +1 -0
  410. package/dist/utils/session-pacer.test.d.ts +2 -0
  411. package/dist/utils/session-pacer.test.d.ts.map +1 -0
  412. package/dist/utils/session-pacer.test.js +111 -0
  413. package/dist/utils/session-pacer.test.js.map +1 -0
  414. package/package.json +1 -1
  415. package/dist/linkedin/__tests__/selectors.integration.test.d.ts +0 -2
  416. package/dist/linkedin/__tests__/selectors.integration.test.d.ts.map +0 -1
  417. package/dist/linkedin/__tests__/selectors.integration.test.js +0 -258
  418. package/dist/linkedin/__tests__/selectors.integration.test.js.map +0 -1
  419. package/dist/types/search-posts.d.ts +0 -22
  420. package/dist/types/search-posts.d.ts.map +0 -1
  421. package/dist/types/search-posts.js +0 -4
  422. package/dist/types/search-posts.js.map +0 -1
  423. package/dist/voyager/index.d.ts +0 -2
  424. package/dist/voyager/index.d.ts.map +0 -1
  425. package/dist/voyager/index.js +0 -4
  426. package/dist/voyager/index.js.map +0 -1
  427. package/dist/voyager/interceptor.d.ts +0 -100
  428. package/dist/voyager/interceptor.d.ts.map +0 -1
  429. package/dist/voyager/interceptor.integration.test.d.ts +0 -2
  430. package/dist/voyager/interceptor.integration.test.d.ts.map +0 -1
  431. package/dist/voyager/interceptor.integration.test.js +0 -89
  432. package/dist/voyager/interceptor.integration.test.js.map +0 -1
  433. package/dist/voyager/interceptor.js +0 -235
  434. package/dist/voyager/interceptor.js.map +0 -1
  435. package/dist/voyager/interceptor.test.d.ts +0 -2
  436. package/dist/voyager/interceptor.test.d.ts.map +0 -1
  437. package/dist/voyager/interceptor.test.js +0 -372
  438. package/dist/voyager/interceptor.test.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"campaign-status.js","sourceRoot":"","sources":["../../src/operations/campaign-status.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAGpC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAoBnD;;;;;;GAMG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAA0B;IAE1B,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,gBAAgB,CAAC;IAClD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,EAAE,CAAC;IAEhC,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE;QAC9C,GAAG,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;QAC3D,GAAG,CAAC,KAAK,CAAC,WAAW,KAAK,SAAS,IAAI,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC;KAC3E,CAAC,CAAC;IAEH,OAAO,oBAAoB,CAAC,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,EAAE;QACzE,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAC1D,MAAM,MAAM,GAAG,MAAM,eAAe,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAEjE,MAAM,MAAM,GAAyB,EAAE,UAAU,EAAE,KAAK,CAAC,UAAU,EAAE,GAAG,MAAM,EAAE,CAAC;QAEjF,IAAI,KAAK,CAAC,cAAc,EAAE,CAAC;YACzB,MAAM,SAAS,GAAG,MAAM,eAAe,CAAC,UAAU,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YACrE,OAAO,EAAE,GAAG,MAAM,EAAE,OAAO,EAAE,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,CAAC;QACnE,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC;AACL,CAAC"}
1
+ {"version":3,"file":"campaign-status.js","sourceRoot":"","sources":["../../src/operations/campaign-status.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAGpC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAA0B,MAAM,YAAY,CAAC;AAmBrE;;;;;;GAMG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAA0B;IAE1B,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;IAC9B,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,EAAE,CAAC;IAEhC,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;IAExE,OAAO,oBAAoB,CAAC,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,EAAE;QACzE,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAC1D,MAAM,MAAM,GAAG,MAAM,eAAe,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAEjE,MAAM,MAAM,GAAyB,EAAE,UAAU,EAAE,KAAK,CAAC,UAAU,EAAE,GAAG,MAAM,EAAE,CAAC;QAEjF,IAAI,KAAK,CAAC,cAAc,EAAE,CAAC;YACzB,MAAM,SAAS,GAAG,MAAM,eAAe,CAAC,UAAU,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YACrE,OAAO,EAAE,GAAG,MAAM,EAAE,OAAO,EAAE,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,CAAC;QACnE,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -1,4 +1,4 @@
1
- import type { ConnectionOptions } from "./types.js";
1
+ import { type ConnectionOptions } from "./types.js";
2
2
  export interface CampaignStopInput extends ConnectionOptions {
3
3
  readonly campaignId: number;
4
4
  }
@@ -1 +1 @@
1
- {"version":3,"file":"campaign-stop.d.ts","sourceRoot":"","sources":["../../src/operations/campaign-stop.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAEpD,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;CAC7B;AAED,MAAM,WAAW,kBAAkB;IACjC,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC;IACvB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;CAC1B;AAED,wBAAsB,YAAY,CAChC,KAAK,EAAE,iBAAiB,GACvB,OAAO,CAAC,kBAAkB,CAAC,CAkB7B"}
1
+ {"version":3,"file":"campaign-stop.d.ts","sourceRoot":"","sources":["../../src/operations/campaign-stop.ts"],"names":[],"mappings":"AAMA,OAAO,EAAmB,KAAK,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAErE,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;CAC7B;AAED,MAAM,WAAW,kBAAkB;IACjC,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC;IACvB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;CAC1B;AAED,wBAAsB,YAAY,CAChC,KAAK,EAAE,iBAAiB,GACvB,OAAO,CAAC,kBAAkB,CAAC,CAe7B"}
@@ -3,13 +3,10 @@
3
3
  import { resolveAccount } from "../services/account-resolution.js";
4
4
  import { withInstanceDatabase } from "../services/instance-context.js";
5
5
  import { CampaignService } from "../services/campaign.js";
6
- import { DEFAULT_CDP_PORT } from "../constants.js";
6
+ import { buildCdpOptions } from "./types.js";
7
7
  export async function campaignStop(input) {
8
- const cdpPort = input.cdpPort ?? DEFAULT_CDP_PORT;
9
- const accountId = await resolveAccount(cdpPort, {
10
- ...(input.cdpHost !== undefined && { host: input.cdpHost }),
11
- ...(input.allowRemote !== undefined && { allowRemote: input.allowRemote }),
12
- });
8
+ const cdpPort = input.cdpPort;
9
+ const accountId = await resolveAccount(cdpPort, buildCdpOptions(input));
13
10
  return withInstanceDatabase(cdpPort, accountId, async ({ instance, db }) => {
14
11
  const campaignService = new CampaignService(instance, db);
15
12
  await campaignService.stop(input.campaignId);
@@ -1 +1 @@
1
- {"version":3,"file":"campaign-stop.js","sourceRoot":"","sources":["../../src/operations/campaign-stop.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAanD,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,KAAwB;IAExB,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,gBAAgB,CAAC;IAElD,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE;QAC9C,GAAG,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;QAC3D,GAAG,CAAC,KAAK,CAAC,WAAW,KAAK,SAAS,IAAI,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC;KAC3E,CAAC,CAAC;IAEH,OAAO,oBAAoB,CAAC,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,EAAE;QACzE,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAC1D,MAAM,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAE7C,OAAO;YACL,OAAO,EAAE,IAAa;YACtB,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,OAAO,EAAE,iBAAiB;SAC3B,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC"}
1
+ {"version":3,"file":"campaign-stop.js","sourceRoot":"","sources":["../../src/operations/campaign-stop.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAA0B,MAAM,YAAY,CAAC;AAYrE,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,KAAwB;IAExB,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;IAE9B,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;IAExE,OAAO,oBAAoB,CAAC,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,EAAE;QACzE,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAC1D,MAAM,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAE7C,OAAO;YACL,OAAO,EAAE,IAAa;YACtB,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,OAAO,EAAE,iBAAiB;SAC3B,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import type { CampaignAction } from "../types/index.js";
2
- import type { ConnectionOptions } from "./types.js";
2
+ import { type ConnectionOptions } from "./types.js";
3
3
  export interface CampaignUpdateActionInput extends ConnectionOptions {
4
4
  readonly campaignId: number;
5
5
  readonly actionId: number;
@@ -1 +1 @@
1
- {"version":3,"file":"campaign-update-action.d.ts","sourceRoot":"","sources":["../../src/operations/campaign-update-action.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAA8B,MAAM,mBAAmB,CAAC;AAKpF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAEpD,MAAM,WAAW,yBAA0B,SAAQ,iBAAiB;IAClE,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACnC,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACjD,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACvC,QAAQ,CAAC,4BAA4B,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3D,QAAQ,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,CAAC;CAC/D;AAED,MAAM,MAAM,0BAA0B,GAAG,cAAc,CAAC;AAExD,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,yBAAyB,GAC/B,OAAO,CAAC,0BAA0B,CAAC,CA8BrC"}
1
+ {"version":3,"file":"campaign-update-action.d.ts","sourceRoot":"","sources":["../../src/operations/campaign-update-action.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAA8B,MAAM,mBAAmB,CAAC;AAIpF,OAAO,EAAmB,KAAK,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAErE,MAAM,WAAW,yBAA0B,SAAQ,iBAAiB;IAClE,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACnC,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACjD,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACvC,QAAQ,CAAC,4BAA4B,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3D,QAAQ,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,CAAC;CAC/D;AAED,MAAM,MAAM,0BAA0B,GAAG,cAAc,CAAC;AAExD,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,yBAAyB,GAC/B,OAAO,CAAC,0BAA0B,CAAC,CA2BrC"}
@@ -3,13 +3,10 @@
3
3
  import { resolveAccount } from "../services/account-resolution.js";
4
4
  import { withDatabase } from "../services/instance-context.js";
5
5
  import { CampaignRepository } from "../db/index.js";
6
- import { DEFAULT_CDP_PORT } from "../constants.js";
6
+ import { buildCdpOptions } from "./types.js";
7
7
  export async function campaignUpdateAction(input) {
8
- const cdpPort = input.cdpPort ?? DEFAULT_CDP_PORT;
9
- const accountId = await resolveAccount(cdpPort, {
10
- ...(input.cdpHost !== undefined && { host: input.cdpHost }),
11
- ...(input.allowRemote !== undefined && { allowRemote: input.allowRemote }),
12
- });
8
+ const cdpPort = input.cdpPort;
9
+ const accountId = await resolveAccount(cdpPort, buildCdpOptions(input));
13
10
  return withDatabase(accountId, ({ db }) => {
14
11
  const campaignRepo = new CampaignRepository(db);
15
12
  const updates = {};
@@ -1 +1 @@
1
- {"version":3,"file":"campaign-update-action.js","sourceRoot":"","sources":["../../src/operations/campaign-update-action.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAGpC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAenD,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,KAAgC;IAEhC,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,gBAAgB,CAAC;IAElD,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE;QAC9C,GAAG,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;QAC3D,GAAG,CAAC,KAAK,CAAC,WAAW,KAAK,SAAS,IAAI,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC;KAC3E,CAAC,CAAC;IAEH,OAAO,YAAY,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;QACxC,MAAM,YAAY,GAAG,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAEhD,MAAM,OAAO,GAA+B,EAAE,CAAC;QAC/C,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC7B,OAAO,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QAC5B,CAAC;QACD,IAAI,KAAK,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;YACpC,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QAC1C,CAAC;QACD,IAAI,KAAK,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;YACjC,OAAO,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QACpC,CAAC;QACD,IAAI,KAAK,CAAC,4BAA4B,KAAK,SAAS,EAAE,CAAC;YACrD,OAAO,CAAC,4BAA4B,GAAG,KAAK,CAAC,4BAA4B,CAAC;QAC5E,CAAC;QACD,IAAI,KAAK,CAAC,cAAc,KAAK,SAAS,EAAE,CAAC;YACvC,OAAO,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;QAChD,CAAC;QAED,OAAO,YAAY,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC9E,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;AAC1B,CAAC"}
1
+ {"version":3,"file":"campaign-update-action.js","sourceRoot":"","sources":["../../src/operations/campaign-update-action.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAGpC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,eAAe,EAA0B,MAAM,YAAY,CAAC;AAcrE,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,KAAgC;IAEhC,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;IAE9B,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;IAExE,OAAO,YAAY,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;QACxC,MAAM,YAAY,GAAG,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAEhD,MAAM,OAAO,GAA+B,EAAE,CAAC;QAC/C,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC7B,OAAO,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QAC5B,CAAC;QACD,IAAI,KAAK,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;YACpC,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QAC1C,CAAC;QACD,IAAI,KAAK,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;YACjC,OAAO,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QACpC,CAAC;QACD,IAAI,KAAK,CAAC,4BAA4B,KAAK,SAAS,EAAE,CAAC;YACrD,OAAO,CAAC,4BAA4B,GAAG,KAAK,CAAC,4BAA4B,CAAC;QAC5E,CAAC;QACD,IAAI,KAAK,CAAC,cAAc,KAAK,SAAS,EAAE,CAAC;YACvC,OAAO,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;QAChD,CAAC;QAED,OAAO,YAAY,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC9E,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;AAC1B,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import type { Campaign, CampaignUpdateConfig } from "../types/index.js";
2
- import type { ConnectionOptions } from "./types.js";
2
+ import { type ConnectionOptions } from "./types.js";
3
3
  /**
4
4
  * Input for the campaign-update operation.
5
5
  */
@@ -1 +1 @@
1
- {"version":3,"file":"campaign-update.d.ts","sourceRoot":"","sources":["../../src/operations/campaign-update.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,QAAQ,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAKxE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAEpD;;GAEG;AACH,MAAM,WAAW,mBAAoB,SAAQ,iBAAiB;IAC5D,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,OAAO,EAAE,oBAAoB,CAAC;CACxC;AAED;;GAEG;AACH,MAAM,MAAM,oBAAoB,GAAG,QAAQ,CAAC;AAE5C;;GAEG;AACH,wBAAsB,cAAc,CAClC,KAAK,EAAE,mBAAmB,GACzB,OAAO,CAAC,oBAAoB,CAAC,CAY/B"}
1
+ {"version":3,"file":"campaign-update.d.ts","sourceRoot":"","sources":["../../src/operations/campaign-update.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,QAAQ,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAIxE,OAAO,EAAmB,KAAK,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAErE;;GAEG;AACH,MAAM,WAAW,mBAAoB,SAAQ,iBAAiB;IAC5D,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,OAAO,EAAE,oBAAoB,CAAC;CACxC;AAED;;GAEG;AACH,MAAM,MAAM,oBAAoB,GAAG,QAAQ,CAAC;AAE5C;;GAEG;AACH,wBAAsB,cAAc,CAClC,KAAK,EAAE,mBAAmB,GACzB,OAAO,CAAC,oBAAoB,CAAC,CAS/B"}
@@ -3,16 +3,13 @@
3
3
  import { resolveAccount } from "../services/account-resolution.js";
4
4
  import { withDatabase } from "../services/instance-context.js";
5
5
  import { CampaignRepository } from "../db/index.js";
6
- import { DEFAULT_CDP_PORT } from "../constants.js";
6
+ import { buildCdpOptions } from "./types.js";
7
7
  /**
8
8
  * Update a campaign's name and/or description.
9
9
  */
10
10
  export async function campaignUpdate(input) {
11
- const cdpPort = input.cdpPort ?? DEFAULT_CDP_PORT;
12
- const accountId = await resolveAccount(cdpPort, {
13
- ...(input.cdpHost !== undefined && { host: input.cdpHost }),
14
- ...(input.allowRemote !== undefined && { allowRemote: input.allowRemote }),
15
- });
11
+ const cdpPort = input.cdpPort;
12
+ const accountId = await resolveAccount(cdpPort, buildCdpOptions(input));
16
13
  return withDatabase(accountId, ({ db }) => {
17
14
  const campaignRepo = new CampaignRepository(db);
18
15
  return campaignRepo.updateCampaign(input.campaignId, input.updates);
@@ -1 +1 @@
1
- {"version":3,"file":"campaign-update.js","sourceRoot":"","sources":["../../src/operations/campaign-update.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAGpC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAgBnD;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAA0B;IAE1B,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,gBAAgB,CAAC;IAElD,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE;QAC9C,GAAG,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;QAC3D,GAAG,CAAC,KAAK,CAAC,WAAW,KAAK,SAAS,IAAI,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC;KAC3E,CAAC,CAAC;IAEH,OAAO,YAAY,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;QACxC,MAAM,YAAY,GAAG,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAChD,OAAO,YAAY,CAAC,cAAc,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;IACtE,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;AAC1B,CAAC"}
1
+ {"version":3,"file":"campaign-update.js","sourceRoot":"","sources":["../../src/operations/campaign-update.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAGpC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,eAAe,EAA0B,MAAM,YAAY,CAAC;AAerE;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAA0B;IAE1B,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;IAE9B,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;IAExE,OAAO,YAAY,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;QACxC,MAAM,YAAY,GAAG,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAChD,OAAO,YAAY,CAAC,cAAc,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;IACtE,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;AAC1B,CAAC"}
@@ -1,7 +1,9 @@
1
1
  import type { ConversationMessages } from "../types/index.js";
2
- import type { ConnectionOptions } from "./types.js";
2
+ import { type ConnectionOptions } from "./types.js";
3
3
  export interface CheckRepliesInput extends ConnectionOptions {
4
+ readonly personIds: number[];
4
5
  readonly since?: string | undefined;
6
+ readonly pauseOthers?: boolean | undefined;
5
7
  }
6
8
  export interface CheckRepliesOutput {
7
9
  readonly newMessages: ConversationMessages[];
@@ -1 +1 @@
1
- {"version":3,"file":"check-replies.d.ts","sourceRoot":"","sources":["../../src/operations/check-replies.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAK9D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAEpD,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CACrC;AAED,MAAM,WAAW,kBAAkB;IACjC,QAAQ,CAAC,WAAW,EAAE,oBAAoB,EAAE,CAAC;IAC7C,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;CAC5B;AAED,wBAAsB,YAAY,CAChC,KAAK,EAAE,iBAAiB,GACvB,OAAO,CAAC,kBAAkB,CAAC,CA0B7B"}
1
+ {"version":3,"file":"check-replies.d.ts","sourceRoot":"","sources":["../../src/operations/check-replies.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAQ9D,OAAO,EAAmB,KAAK,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAQrE,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,CAAC;IAC7B,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACpC,QAAQ,CAAC,WAAW,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;CAC5C;AAED,MAAM,WAAW,kBAAkB;IACjC,QAAQ,CAAC,WAAW,EAAE,oBAAoB,EAAE,CAAC;IAC7C,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;CAC5B;AAED,wBAAsB,YAAY,CAChC,KAAK,EAAE,iBAAiB,GACvB,OAAO,CAAC,kBAAkB,CAAC,CAuH7B"}
@@ -2,25 +2,140 @@
2
2
  // Copyright (C) 2026 Oleksii PELYKH
3
3
  import { resolveAccount } from "../services/account-resolution.js";
4
4
  import { withInstanceDatabase } from "../services/instance-context.js";
5
- import { MessageRepository } from "../db/index.js";
6
- import { DEFAULT_CDP_PORT } from "../constants.js";
5
+ import { CampaignService } from "../services/campaign.js";
6
+ import { CampaignTimeoutError } from "../services/errors.js";
7
+ import { MessageRepository, ProfileRepository } from "../db/index.js";
8
+ import { delay } from "../utils/delay.js";
9
+ import { errorMessage } from "../utils/error-message.js";
10
+ import { buildCdpOptions } from "./types.js";
11
+ /** Timeout for ephemeral campaign completion (5 minutes). */
12
+ const CAMPAIGN_TIMEOUT = 300_000;
13
+ /** Interval between campaign status polls (2 seconds). */
14
+ const POLL_INTERVAL = 2_000;
7
15
  export async function checkReplies(input) {
8
- const cdpPort = input.cdpPort ?? DEFAULT_CDP_PORT;
16
+ if (input.personIds.length === 0) {
17
+ throw new Error("At least one personId is required");
18
+ }
19
+ const cdpPort = input.cdpPort;
9
20
  const cutoff = input.since ?? new Date(Date.now() - 24 * 60 * 60 * 1000).toISOString();
10
- const accountId = await resolveAccount(cdpPort, {
11
- ...(input.cdpHost !== undefined && { host: input.cdpHost }),
12
- ...(input.allowRemote !== undefined && { allowRemote: input.allowRemote }),
13
- });
21
+ const accountId = await resolveAccount(cdpPort, buildCdpOptions(input));
14
22
  return withInstanceDatabase(cdpPort, accountId, async ({ instance, db }) => {
15
- await instance.executeAction("CheckForReplies");
16
- const repo = new MessageRepository(db);
17
- const conversations = repo.getMessagesSince(cutoff);
18
- const totalNew = conversations.reduce((sum, c) => sum + c.messages.length, 0);
19
- return {
20
- newMessages: conversations,
21
- totalNew,
22
- checkedAt: new Date().toISOString(),
23
- };
24
- }, { instanceTimeout: 120_000 });
23
+ const campaignService = new CampaignService(instance, db);
24
+ const profileRepo = new ProfileRepository(db);
25
+ // Resolve person IDs to LinkedIn profile URLs
26
+ const profiles = profileRepo.findByIds(input.personIds);
27
+ const linkedInUrls = [];
28
+ for (let i = 0; i < input.personIds.length; i++) {
29
+ const personId = input.personIds[i];
30
+ const profile = profiles[i];
31
+ if (!profile) {
32
+ throw new Error(`Person ${String(personId)} not found in database`);
33
+ }
34
+ const publicId = profile.externalIds.find((e) => e.typeGroup === "public");
35
+ if (!publicId) {
36
+ throw new Error(`Person ${String(personId)} has no LinkedIn public ID`);
37
+ }
38
+ linkedInUrls.push(`https://www.linkedin.com/in/${publicId.externalId}`);
39
+ }
40
+ let runnerWasActive = false;
41
+ let campaign;
42
+ let pausedCampaignIds = [];
43
+ try {
44
+ // Capture runner state and stop if active to avoid SQLite lock contention
45
+ runnerWasActive = (await campaignService.getRunnerState()) !== "idle";
46
+ await campaignService.stopRunnerAndWaitForIdle();
47
+ // Create ephemeral campaign with CheckForReplies action
48
+ campaign = await campaignService.create({
49
+ name: `[ephemeral] CheckForReplies ${new Date().toISOString()}`,
50
+ actions: [{
51
+ name: "CheckForReplies",
52
+ actionType: "CheckForReplies",
53
+ coolDown: 0,
54
+ maxActionResultsPerIteration: input.personIds.length,
55
+ actionSettings: {
56
+ moveToSuccessfulAfterMs: 1_000,
57
+ treatMessageAcceptedAsReply: false,
58
+ keepInQueueIfRequestIsNotAccepted: false,
59
+ },
60
+ }],
61
+ });
62
+ // Pause other campaigns if requested (restore in finally)
63
+ if (input.pauseOthers) {
64
+ pausedCampaignIds = await campaignService.pauseAllExcept(campaign.id);
65
+ }
66
+ // Import target persons into campaign
67
+ await campaignService.importPeopleFromUrls(campaign.id, linkedInUrls);
68
+ // Start the campaign: wait for idle, unpause, start runner
69
+ await campaignService.start(campaign.id, []);
70
+ // Poll for completion (runner idle + no queued persons)
71
+ const deadline = Date.now() + CAMPAIGN_TIMEOUT;
72
+ let completed = false;
73
+ while (Date.now() < deadline) {
74
+ const status = await campaignService.getStatus(campaign.id);
75
+ const counts = status.actionCounts[0];
76
+ if (status.runnerState === "idle" && counts && counts.queued === 0) {
77
+ completed = true;
78
+ break;
79
+ }
80
+ const remaining = deadline - Date.now();
81
+ if (remaining <= 0)
82
+ break;
83
+ await delay(Math.min(POLL_INTERVAL, remaining));
84
+ }
85
+ if (!completed) {
86
+ throw new CampaignTimeoutError(`CheckForReplies did not complete within ${String(CAMPAIGN_TIMEOUT)}ms`, campaign.id);
87
+ }
88
+ // Read new messages from database, filtered to requested persons
89
+ const repo = new MessageRepository(db);
90
+ const conversations = repo.getMessagesSince(cutoff);
91
+ const personIdSet = new Set(input.personIds);
92
+ const filtered = conversations.filter((c) => personIdSet.has(c.personId));
93
+ const totalNew = filtered.reduce((sum, c) => sum + c.messages.length, 0);
94
+ return {
95
+ newMessages: filtered,
96
+ totalNew,
97
+ checkedAt: new Date().toISOString(),
98
+ };
99
+ }
100
+ finally {
101
+ // Stop runner first so DB writes don't contend with it
102
+ try {
103
+ await campaignService.stopRunnerAndWaitForIdle();
104
+ }
105
+ catch (e) {
106
+ console.warn("Best-effort stopRunner failed:", errorMessage(e));
107
+ }
108
+ if (campaign) {
109
+ try {
110
+ await campaignService.stop(campaign.id);
111
+ }
112
+ catch (e) {
113
+ console.warn("Best-effort campaign stop failed:", errorMessage(e));
114
+ }
115
+ try {
116
+ campaignService.hardDelete(campaign.id);
117
+ }
118
+ catch (e) {
119
+ console.warn("Best-effort campaign hardDelete failed:", errorMessage(e));
120
+ }
121
+ }
122
+ if (pausedCampaignIds.length > 0) {
123
+ try {
124
+ await campaignService.unpauseCampaigns(pausedCampaignIds);
125
+ }
126
+ catch (e) {
127
+ console.warn("Best-effort unpauseCampaigns failed:", errorMessage(e));
128
+ }
129
+ }
130
+ if (runnerWasActive) {
131
+ try {
132
+ await campaignService.startRunner();
133
+ }
134
+ catch (e) {
135
+ console.warn("Best-effort startRunner failed:", errorMessage(e));
136
+ }
137
+ }
138
+ }
139
+ }, { instanceTimeout: CAMPAIGN_TIMEOUT, db: { readOnly: false } });
25
140
  }
26
141
  //# sourceMappingURL=check-replies.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"check-replies.js","sourceRoot":"","sources":["../../src/operations/check-replies.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAGpC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAanD,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,KAAwB;IAExB,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,gBAAgB,CAAC;IAClD,MAAM,MAAM,GACV,KAAK,CAAC,KAAK,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;IAE1E,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE;QAC9C,GAAG,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;QAC3D,GAAG,CAAC,KAAK,CAAC,WAAW,KAAK,SAAS,IAAI,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC;KAC3E,CAAC,CAAC;IAEH,OAAO,oBAAoB,CAAC,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,EAAE;QACzE,MAAM,QAAQ,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC;QAEhD,MAAM,IAAI,GAAG,IAAI,iBAAiB,CAAC,EAAE,CAAC,CAAC;QACvC,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QACpD,MAAM,QAAQ,GAAG,aAAa,CAAC,MAAM,CACnC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,QAAQ,CAAC,MAAM,EACnC,CAAC,CACF,CAAC;QAEF,OAAO;YACL,WAAW,EAAE,aAAa;YAC1B,QAAQ;YACR,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACpC,CAAC;IACJ,CAAC,EAAE,EAAE,eAAe,EAAE,OAAO,EAAE,CAAC,CAAC;AACnC,CAAC"}
1
+ {"version":3,"file":"check-replies.js","sourceRoot":"","sources":["../../src/operations/check-replies.ts"],"names":[],"mappings":"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"}
@@ -7,12 +7,20 @@ vi.mock("../services/account-resolution.js", () => ({
7
7
  vi.mock("../services/instance-context.js", () => ({
8
8
  withInstanceDatabase: vi.fn(),
9
9
  }));
10
+ vi.mock("../services/campaign.js", () => ({
11
+ CampaignService: vi.fn(),
12
+ }));
10
13
  vi.mock("../db/index.js", () => ({
11
14
  MessageRepository: vi.fn(),
15
+ ProfileRepository: vi.fn(),
16
+ }));
17
+ vi.mock("../utils/delay.js", () => ({
18
+ delay: vi.fn().mockResolvedValue(undefined),
12
19
  }));
13
20
  import { resolveAccount } from "../services/account-resolution.js";
14
21
  import { withInstanceDatabase } from "../services/instance-context.js";
15
- import { MessageRepository } from "../db/index.js";
22
+ import { CampaignService } from "../services/campaign.js";
23
+ import { MessageRepository, ProfileRepository } from "../db/index.js";
16
24
  import { checkReplies } from "./check-replies.js";
17
25
  const MOCK_CONVERSATIONS = [
18
26
  {
@@ -25,14 +33,45 @@ const MOCK_CONVERSATIONS = [
25
33
  ],
26
34
  },
27
35
  ];
28
- const mockInstance = { executeAction: vi.fn().mockResolvedValue(undefined) };
36
+ const MOCK_PROFILES = [
37
+ { id: 100, externalIds: [{ typeGroup: "public", externalId: "alice-wonder" }] },
38
+ { id: 200, externalIds: [{ typeGroup: "public", externalId: "bob-builder" }] },
39
+ ];
40
+ const mockCampaignService = {
41
+ create: vi.fn().mockResolvedValue({ id: 42 }),
42
+ importPeopleFromUrls: vi.fn().mockResolvedValue({
43
+ actionId: 1,
44
+ successful: 2,
45
+ alreadyInQueue: 0,
46
+ alreadyProcessed: 0,
47
+ failed: 0,
48
+ }),
49
+ start: vi.fn().mockResolvedValue(undefined),
50
+ getStatus: vi.fn().mockResolvedValue({
51
+ runnerState: "idle",
52
+ actionCounts: [{ queued: 0, processed: 0, successful: 2, failed: 0 }],
53
+ }),
54
+ getRunnerState: vi.fn().mockResolvedValue("idle"),
55
+ stopRunnerAndWaitForIdle: vi.fn().mockResolvedValue(undefined),
56
+ startRunner: vi.fn().mockResolvedValue(undefined),
57
+ stop: vi.fn().mockResolvedValue(undefined),
58
+ hardDelete: vi.fn(),
59
+ };
29
60
  function setupMocks() {
30
61
  vi.mocked(resolveAccount).mockResolvedValue(1);
31
62
  vi.mocked(withInstanceDatabase).mockImplementation(async (_cdpPort, _accountId, callback) => callback({
32
63
  accountId: 1,
33
- instance: mockInstance,
64
+ instance: {},
34
65
  db: {},
35
66
  }));
67
+ vi.mocked(CampaignService).mockImplementation(function () {
68
+ return mockCampaignService;
69
+ });
70
+ vi.mocked(ProfileRepository).mockImplementation(function () {
71
+ return {
72
+ findByIds: vi.fn().mockReturnValue(MOCK_PROFILES),
73
+ };
74
+ });
36
75
  vi.mocked(MessageRepository).mockImplementation(function () {
37
76
  return {
38
77
  getMessagesSince: vi.fn().mockReturnValue(MOCK_CONVERSATIONS),
@@ -46,33 +85,134 @@ describe("checkReplies", () => {
46
85
  afterEach(() => {
47
86
  vi.restoreAllMocks();
48
87
  });
88
+ it("throws when personIds is empty", async () => {
89
+ await expect(checkReplies({ personIds: [], cdpPort: 9222 })).rejects.toThrow("At least one personId is required");
90
+ });
49
91
  it("returns new messages and totals", async () => {
50
92
  setupMocks();
51
93
  const result = await checkReplies({
94
+ personIds: [100, 200],
52
95
  cdpPort: 9222,
53
96
  since: "2025-12-31T00:00:00Z",
54
97
  });
55
- expect(result.newMessages).toBe(MOCK_CONVERSATIONS);
98
+ expect(result.newMessages).toEqual(MOCK_CONVERSATIONS);
56
99
  expect(result.totalNew).toBe(2);
57
100
  expect(result.checkedAt).toBeDefined();
58
101
  });
59
- it("calls instance.executeAction with CheckForReplies", async () => {
102
+ it("filters messages to only requested personIds", async () => {
103
+ setupMocks();
104
+ vi.mocked(MessageRepository).mockImplementation(function () {
105
+ return {
106
+ getMessagesSince: vi.fn().mockReturnValue([
107
+ ...MOCK_CONVERSATIONS,
108
+ {
109
+ chatId: 10,
110
+ personId: 999,
111
+ personName: "Unrelated",
112
+ messages: [
113
+ { id: 3, type: "text", text: "unrelated", subject: null, sendAt: "2026-01-01T00:02:00Z", attachmentsCount: 0, senderPersonId: 999, senderFirstName: "Unrelated", senderLastName: null },
114
+ ],
115
+ },
116
+ ]),
117
+ };
118
+ });
119
+ const result = await checkReplies({
120
+ personIds: [100],
121
+ cdpPort: 9222,
122
+ });
123
+ expect(result.newMessages).toHaveLength(1);
124
+ expect(result.newMessages[0]?.personId).toBe(100);
125
+ expect(result.totalNew).toBe(2);
126
+ });
127
+ it("creates ephemeral campaign with CheckForReplies action and settings", async () => {
128
+ setupMocks();
129
+ await checkReplies({
130
+ personIds: [100, 200],
131
+ cdpPort: 9222,
132
+ });
133
+ expect(mockCampaignService.create).toHaveBeenCalledWith({
134
+ name: expect.stringContaining("[ephemeral] CheckForReplies"),
135
+ actions: [{
136
+ name: "CheckForReplies",
137
+ actionType: "CheckForReplies",
138
+ coolDown: 0,
139
+ maxActionResultsPerIteration: 2,
140
+ actionSettings: {
141
+ moveToSuccessfulAfterMs: 1_000,
142
+ treatMessageAcceptedAsReply: false,
143
+ keepInQueueIfRequestIsNotAccepted: false,
144
+ },
145
+ }],
146
+ });
147
+ });
148
+ it("resolves personIds to LinkedIn URLs and imports them", async () => {
149
+ setupMocks();
150
+ await checkReplies({
151
+ personIds: [100, 200],
152
+ cdpPort: 9222,
153
+ });
154
+ expect(mockCampaignService.importPeopleFromUrls).toHaveBeenCalledWith(42, [
155
+ "https://www.linkedin.com/in/alice-wonder",
156
+ "https://www.linkedin.com/in/bob-builder",
157
+ ]);
158
+ });
159
+ it("starts campaign and polls for completion", async () => {
160
+ setupMocks();
161
+ await checkReplies({
162
+ personIds: [100, 200],
163
+ cdpPort: 9222,
164
+ });
165
+ expect(mockCampaignService.start).toHaveBeenCalledWith(42, []);
166
+ expect(mockCampaignService.getStatus).toHaveBeenCalledWith(42);
167
+ });
168
+ it("cleans up campaign after success", async () => {
60
169
  setupMocks();
61
170
  await checkReplies({
171
+ personIds: [100, 200],
62
172
  cdpPort: 9222,
63
173
  });
64
- expect(mockInstance.executeAction).toHaveBeenCalledWith("CheckForReplies");
174
+ expect(mockCampaignService.stopRunnerAndWaitForIdle).toHaveBeenCalled();
175
+ expect(mockCampaignService.stop).toHaveBeenCalledWith(42);
176
+ expect(mockCampaignService.hardDelete).toHaveBeenCalledWith(42);
177
+ });
178
+ it("cleans up campaign after failure", async () => {
179
+ setupMocks();
180
+ mockCampaignService.start.mockRejectedValueOnce(new Error("start failed"));
181
+ await expect(checkReplies({ personIds: [100, 200], cdpPort: 9222 })).rejects.toThrow("start failed");
182
+ expect(mockCampaignService.stopRunnerAndWaitForIdle).toHaveBeenCalled();
183
+ expect(mockCampaignService.stop).toHaveBeenCalledWith(42);
184
+ expect(mockCampaignService.hardDelete).toHaveBeenCalledWith(42);
185
+ });
186
+ it("throws when person not found in database", async () => {
187
+ setupMocks();
188
+ vi.mocked(ProfileRepository).mockImplementation(function () {
189
+ return {
190
+ findByIds: vi.fn().mockReturnValue([null]),
191
+ };
192
+ });
193
+ await expect(checkReplies({ personIds: [999], cdpPort: 9222 })).rejects.toThrow("Person 999 not found in database");
194
+ });
195
+ it("throws when person has no LinkedIn public ID", async () => {
196
+ setupMocks();
197
+ vi.mocked(ProfileRepository).mockImplementation(function () {
198
+ return {
199
+ findByIds: vi.fn().mockReturnValue([{ id: 100, externalIds: [] }]),
200
+ };
201
+ });
202
+ await expect(checkReplies({ personIds: [100], cdpPort: 9222 })).rejects.toThrow("Person 100 has no LinkedIn public ID");
65
203
  });
66
- it("passes instanceTimeout to withInstanceDatabase", async () => {
204
+ it("passes instanceTimeout and db readOnly: false to withInstanceDatabase", async () => {
67
205
  setupMocks();
68
206
  await checkReplies({
207
+ personIds: [100],
69
208
  cdpPort: 9222,
70
209
  });
71
- expect(withInstanceDatabase).toHaveBeenCalledWith(9222, 1, expect.any(Function), { instanceTimeout: 120_000 });
210
+ expect(withInstanceDatabase).toHaveBeenCalledWith(9222, 1, expect.any(Function), { instanceTimeout: 300_000, db: { readOnly: false } });
72
211
  });
73
212
  it("passes connection options to resolveAccount", async () => {
74
213
  setupMocks();
75
214
  await checkReplies({
215
+ personIds: [100],
76
216
  cdpPort: 1234,
77
217
  cdpHost: "192.168.1.1",
78
218
  allowRemote: true,
@@ -85,26 +225,46 @@ describe("checkReplies", () => {
85
225
  it("omits undefined connection options", async () => {
86
226
  setupMocks();
87
227
  await checkReplies({
228
+ personIds: [100],
88
229
  cdpPort: 9222,
89
230
  });
90
231
  expect(resolveAccount).toHaveBeenCalledWith(9222, {});
91
232
  });
92
233
  it("propagates resolveAccount errors", async () => {
93
234
  vi.mocked(resolveAccount).mockRejectedValue(new Error("connection refused"));
94
- await expect(checkReplies({ cdpPort: 9222 })).rejects.toThrow("connection refused");
235
+ await expect(checkReplies({ personIds: [100], cdpPort: 9222 })).rejects.toThrow("connection refused");
95
236
  });
96
237
  it("propagates withInstanceDatabase errors", async () => {
97
238
  vi.mocked(resolveAccount).mockResolvedValue(1);
98
239
  vi.mocked(withInstanceDatabase).mockRejectedValue(new Error("instance not running"));
99
- await expect(checkReplies({ cdpPort: 9222 })).rejects.toThrow("instance not running");
240
+ await expect(checkReplies({ personIds: [100], cdpPort: 9222 })).rejects.toThrow("instance not running");
241
+ });
242
+ it("restores runner when it was active before execution", async () => {
243
+ setupMocks();
244
+ mockCampaignService.getRunnerState.mockResolvedValueOnce("campaigns");
245
+ await checkReplies({
246
+ personIds: [100, 200],
247
+ cdpPort: 9222,
248
+ });
249
+ expect(mockCampaignService.startRunner).toHaveBeenCalled();
250
+ });
251
+ it("does not restore runner when it was idle before execution", async () => {
252
+ setupMocks();
253
+ await checkReplies({
254
+ personIds: [100, 200],
255
+ cdpPort: 9222,
256
+ });
257
+ expect(mockCampaignService.startRunner).not.toHaveBeenCalled();
258
+ });
259
+ it("restores runner when stopRunnerAndWaitForIdle fails and runner was active", async () => {
260
+ setupMocks();
261
+ mockCampaignService.getRunnerState.mockResolvedValueOnce("campaigns");
262
+ mockCampaignService.stopRunnerAndWaitForIdle.mockRejectedValueOnce(new Error("timeout"));
263
+ await expect(checkReplies({ personIds: [100, 200], cdpPort: 9222 })).rejects.toThrow("timeout");
264
+ expect(mockCampaignService.startRunner).toHaveBeenCalled();
100
265
  });
101
266
  it("propagates MessageRepository errors", async () => {
102
- vi.mocked(resolveAccount).mockResolvedValue(1);
103
- vi.mocked(withInstanceDatabase).mockImplementation(async (_cdpPort, _accountId, callback) => callback({
104
- accountId: 1,
105
- instance: mockInstance,
106
- db: {},
107
- }));
267
+ setupMocks();
108
268
  vi.mocked(MessageRepository).mockImplementation(function () {
109
269
  return {
110
270
  getMessagesSince: vi.fn().mockImplementation(() => {
@@ -112,7 +272,7 @@ describe("checkReplies", () => {
112
272
  }),
113
273
  };
114
274
  });
115
- await expect(checkReplies({ cdpPort: 9222 })).rejects.toThrow("query failed");
275
+ await expect(checkReplies({ personIds: [100], cdpPort: 9222 })).rejects.toThrow("query failed");
116
276
  });
117
277
  });
118
278
  //# sourceMappingURL=check-replies.test.js.map