@elizaos/plugin-personal-assistant 2.0.3-beta.6 → 2.0.3-beta.7

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 (1317) hide show
  1. package/dist/actions/app-block.d.ts +15 -0
  2. package/dist/actions/app-block.d.ts.map +1 -0
  3. package/dist/actions/app-block.js +349 -0
  4. package/dist/actions/app-block.js.map +1 -0
  5. package/dist/actions/autofill.d.ts +20 -0
  6. package/dist/actions/autofill.d.ts.map +1 -0
  7. package/dist/actions/autofill.js +370 -0
  8. package/dist/actions/autofill.js.map +1 -0
  9. package/dist/actions/block.d.ts +30 -0
  10. package/dist/actions/block.d.ts.map +1 -0
  11. package/dist/actions/block.js +326 -0
  12. package/dist/actions/block.js.map +1 -0
  13. package/dist/actions/book-travel.d.ts +10 -0
  14. package/dist/actions/book-travel.d.ts.map +1 -0
  15. package/dist/actions/book-travel.js +467 -0
  16. package/dist/actions/book-travel.js.map +1 -0
  17. package/dist/actions/brief.d.ts +60 -0
  18. package/dist/actions/brief.d.ts.map +1 -0
  19. package/dist/actions/brief.js +485 -0
  20. package/dist/actions/brief.js.map +1 -0
  21. package/dist/actions/calendar.d.ts +22 -0
  22. package/dist/actions/calendar.d.ts.map +1 -0
  23. package/dist/actions/calendar.js +832 -0
  24. package/dist/actions/calendar.js.map +1 -0
  25. package/dist/actions/conflict-detect.d.ts +67 -0
  26. package/dist/actions/conflict-detect.d.ts.map +1 -0
  27. package/dist/actions/conflict-detect.js +310 -0
  28. package/dist/actions/conflict-detect.js.map +1 -0
  29. package/dist/actions/connector.d.ts +5 -0
  30. package/dist/actions/connector.d.ts.map +1 -0
  31. package/dist/actions/connector.js +1354 -0
  32. package/dist/actions/connector.js.map +1 -0
  33. package/dist/actions/credentials.d.ts +14 -0
  34. package/dist/actions/credentials.d.ts.map +1 -0
  35. package/dist/actions/credentials.js +191 -0
  36. package/dist/actions/credentials.js.map +1 -0
  37. package/dist/actions/document.d.ts +36 -0
  38. package/dist/actions/document.d.ts.map +1 -0
  39. package/dist/actions/document.js +613 -0
  40. package/dist/actions/document.js.map +1 -0
  41. package/dist/actions/entity.d.ts +20 -0
  42. package/dist/actions/entity.d.ts.map +1 -0
  43. package/dist/actions/entity.js +785 -0
  44. package/dist/actions/entity.js.map +1 -0
  45. package/dist/actions/health.d.ts +4 -0
  46. package/dist/actions/health.d.ts.map +1 -0
  47. package/dist/actions/health.js +37 -0
  48. package/dist/actions/health.js.map +1 -0
  49. package/dist/actions/inbox.d.ts +12 -0
  50. package/dist/actions/inbox.d.ts.map +1 -0
  51. package/dist/actions/inbox.js +13 -0
  52. package/dist/actions/inbox.js.map +1 -0
  53. package/dist/actions/lib/calendly-handler.d.ts +3 -0
  54. package/dist/actions/lib/calendly-handler.d.ts.map +1 -0
  55. package/dist/actions/lib/calendly-handler.js +506 -0
  56. package/dist/actions/lib/calendly-handler.js.map +1 -0
  57. package/dist/actions/lib/extract-goal-plan.d.ts +69 -0
  58. package/dist/actions/lib/extract-goal-plan.d.ts.map +1 -0
  59. package/dist/actions/lib/extract-goal-plan.js +488 -0
  60. package/dist/actions/lib/extract-goal-plan.js.map +1 -0
  61. package/dist/actions/lib/extract-life-operation.d.ts +18 -0
  62. package/dist/actions/lib/extract-life-operation.d.ts.map +1 -0
  63. package/dist/actions/lib/extract-life-operation.js +318 -0
  64. package/dist/actions/lib/extract-life-operation.js.map +1 -0
  65. package/dist/actions/lib/extract-task-plan.d.ts +78 -0
  66. package/dist/actions/lib/extract-task-plan.d.ts.map +1 -0
  67. package/dist/actions/lib/extract-task-plan.js +355 -0
  68. package/dist/actions/lib/extract-task-plan.js.map +1 -0
  69. package/dist/actions/lib/extract-update-fields.d.ts +27 -0
  70. package/dist/actions/lib/extract-update-fields.d.ts.map +1 -0
  71. package/dist/actions/lib/extract-update-fields.js +172 -0
  72. package/dist/actions/lib/extract-update-fields.js.map +1 -0
  73. package/dist/actions/lib/lifeops-deferred-draft.d.ts +68 -0
  74. package/dist/actions/lib/lifeops-deferred-draft.d.ts.map +1 -0
  75. package/dist/actions/lib/lifeops-deferred-draft.js +315 -0
  76. package/dist/actions/lib/lifeops-deferred-draft.js.map +1 -0
  77. package/dist/actions/lib/messaging-helpers.d.ts +20 -0
  78. package/dist/actions/lib/messaging-helpers.d.ts.map +1 -0
  79. package/dist/actions/lib/messaging-helpers.js +103 -0
  80. package/dist/actions/lib/messaging-helpers.js.map +1 -0
  81. package/dist/actions/lib/owner-policy-writes.d.ts +49 -0
  82. package/dist/actions/lib/owner-policy-writes.d.ts.map +1 -0
  83. package/dist/actions/lib/owner-policy-writes.js +157 -0
  84. package/dist/actions/lib/owner-policy-writes.js.map +1 -0
  85. package/dist/actions/lib/prompt-format.d.ts +3 -0
  86. package/dist/actions/lib/prompt-format.d.ts.map +1 -0
  87. package/dist/actions/lib/prompt-format.js +42 -0
  88. package/dist/actions/lib/prompt-format.js.map +1 -0
  89. package/dist/actions/lib/scheduling-handler.d.ts +93 -0
  90. package/dist/actions/lib/scheduling-handler.d.ts.map +1 -0
  91. package/dist/actions/lib/scheduling-handler.js +868 -0
  92. package/dist/actions/lib/scheduling-handler.js.map +1 -0
  93. package/dist/actions/life.d.ts +13 -0
  94. package/dist/actions/life.d.ts.map +1 -0
  95. package/dist/actions/life.js +2524 -0
  96. package/dist/actions/life.js.map +1 -0
  97. package/dist/actions/money.d.ts +24 -0
  98. package/dist/actions/money.d.ts.map +1 -0
  99. package/dist/actions/money.js +41 -0
  100. package/dist/actions/money.js.map +1 -0
  101. package/dist/actions/owner-surfaces.d.ts +11 -0
  102. package/dist/actions/owner-surfaces.d.ts.map +1 -0
  103. package/dist/actions/owner-surfaces.js +493 -0
  104. package/dist/actions/owner-surfaces.js.map +1 -0
  105. package/dist/actions/password-manager.d.ts +10 -0
  106. package/dist/actions/password-manager.d.ts.map +1 -0
  107. package/dist/actions/password-manager.js +195 -0
  108. package/dist/actions/password-manager.js.map +1 -0
  109. package/dist/actions/payments.d.ts +10 -0
  110. package/dist/actions/payments.d.ts.map +1 -0
  111. package/dist/actions/payments.js +5 -0
  112. package/dist/actions/payments.js.map +1 -0
  113. package/dist/actions/prioritize.d.ts +49 -0
  114. package/dist/actions/prioritize.d.ts.map +1 -0
  115. package/dist/actions/prioritize.js +313 -0
  116. package/dist/actions/prioritize.js.map +1 -0
  117. package/dist/actions/remote-desktop.d.ts +13 -0
  118. package/dist/actions/remote-desktop.d.ts.map +1 -0
  119. package/dist/actions/remote-desktop.js +11 -0
  120. package/dist/actions/remote-desktop.js.map +1 -0
  121. package/dist/actions/resolve-request.d.ts +12 -0
  122. package/dist/actions/resolve-request.d.ts.map +1 -0
  123. package/dist/actions/resolve-request.js +427 -0
  124. package/dist/actions/resolve-request.js.map +1 -0
  125. package/dist/actions/schedule.d.ts +10 -0
  126. package/dist/actions/schedule.d.ts.map +1 -0
  127. package/dist/actions/schedule.js +113 -0
  128. package/dist/actions/schedule.js.map +1 -0
  129. package/dist/actions/scheduled-task.d.ts +32 -0
  130. package/dist/actions/scheduled-task.d.ts.map +1 -0
  131. package/dist/actions/scheduled-task.js +661 -0
  132. package/dist/actions/scheduled-task.js.map +1 -0
  133. package/dist/actions/screen-time.d.ts +4 -0
  134. package/dist/actions/screen-time.d.ts.map +1 -0
  135. package/dist/actions/screen-time.js +47 -0
  136. package/dist/actions/screen-time.js.map +1 -0
  137. package/dist/actions/subscriptions.d.ts +8 -0
  138. package/dist/actions/subscriptions.d.ts.map +1 -0
  139. package/dist/actions/subscriptions.js +327 -0
  140. package/dist/actions/subscriptions.js.map +1 -0
  141. package/dist/actions/voice-call.d.ts +16 -0
  142. package/dist/actions/voice-call.d.ts.map +1 -0
  143. package/dist/actions/voice-call.js +756 -0
  144. package/dist/actions/voice-call.js.map +1 -0
  145. package/dist/actions/website-block.d.ts +15 -0
  146. package/dist/actions/website-block.d.ts.map +1 -0
  147. package/dist/actions/website-block.js +719 -0
  148. package/dist/actions/website-block.js.map +1 -0
  149. package/dist/actions/work-thread.d.ts +5 -0
  150. package/dist/actions/work-thread.d.ts.map +1 -0
  151. package/dist/actions/work-thread.js +556 -0
  152. package/dist/actions/work-thread.js.map +1 -0
  153. package/dist/activity-profile/activity-tracker-repo.d.ts +28 -0
  154. package/dist/activity-profile/activity-tracker-repo.d.ts.map +1 -0
  155. package/dist/activity-profile/activity-tracker-repo.js +61 -0
  156. package/dist/activity-profile/activity-tracker-repo.js.map +1 -0
  157. package/dist/activity-profile/activity-tracker-reporting.d.ts +52 -0
  158. package/dist/activity-profile/activity-tracker-reporting.d.ts.map +1 -0
  159. package/dist/activity-profile/activity-tracker-reporting.js +119 -0
  160. package/dist/activity-profile/activity-tracker-reporting.js.map +1 -0
  161. package/dist/activity-profile/activity-tracker-service.d.ts +36 -0
  162. package/dist/activity-profile/activity-tracker-service.d.ts.map +1 -0
  163. package/dist/activity-profile/activity-tracker-service.js +187 -0
  164. package/dist/activity-profile/activity-tracker-service.js.map +1 -0
  165. package/dist/activity-profile/analyzer.d.ts +23 -0
  166. package/dist/activity-profile/analyzer.d.ts.map +1 -0
  167. package/dist/activity-profile/analyzer.js +485 -0
  168. package/dist/activity-profile/analyzer.js.map +1 -0
  169. package/dist/activity-profile/presence-signal-bridge-service.d.ts +14 -0
  170. package/dist/activity-profile/presence-signal-bridge-service.d.ts.map +1 -0
  171. package/dist/activity-profile/presence-signal-bridge-service.js +159 -0
  172. package/dist/activity-profile/presence-signal-bridge-service.js.map +1 -0
  173. package/dist/activity-profile/proactive-inbox-digest.d.ts +3 -0
  174. package/dist/activity-profile/proactive-inbox-digest.d.ts.map +1 -0
  175. package/dist/activity-profile/proactive-inbox-digest.js +21 -0
  176. package/dist/activity-profile/proactive-inbox-digest.js.map +1 -0
  177. package/dist/activity-profile/proactive-planner.d.ts +150 -0
  178. package/dist/activity-profile/proactive-planner.d.ts.map +1 -0
  179. package/dist/activity-profile/proactive-planner.js +529 -0
  180. package/dist/activity-profile/proactive-planner.js.map +1 -0
  181. package/dist/activity-profile/proactive-worker.d.ts +33 -0
  182. package/dist/activity-profile/proactive-worker.d.ts.map +1 -0
  183. package/dist/activity-profile/proactive-worker.js +779 -0
  184. package/dist/activity-profile/proactive-worker.js.map +1 -0
  185. package/dist/activity-profile/profile-metadata.d.ts +10 -0
  186. package/dist/activity-profile/profile-metadata.d.ts.map +1 -0
  187. package/dist/activity-profile/profile-metadata.js +16 -0
  188. package/dist/activity-profile/profile-metadata.js.map +1 -0
  189. package/dist/activity-profile/redactor.d.ts +15 -0
  190. package/dist/activity-profile/redactor.d.ts.map +1 -0
  191. package/dist/activity-profile/redactor.js +22 -0
  192. package/dist/activity-profile/redactor.js.map +1 -0
  193. package/dist/activity-profile/service.d.ts +11 -0
  194. package/dist/activity-profile/service.d.ts.map +1 -0
  195. package/dist/activity-profile/service.js +272 -0
  196. package/dist/activity-profile/service.js.map +1 -0
  197. package/dist/activity-profile/types.d.ts +97 -0
  198. package/dist/activity-profile/types.d.ts.map +1 -0
  199. package/dist/activity-profile/types.js +36 -0
  200. package/dist/activity-profile/types.js.map +1 -0
  201. package/dist/agent-lifeops.d.ts +2 -0
  202. package/dist/agent-lifeops.d.ts.map +1 -0
  203. package/dist/agent-lifeops.js +2 -0
  204. package/dist/agent-lifeops.js.map +1 -0
  205. package/dist/api/client-lifeops.d.ts +319 -0
  206. package/dist/api/client-lifeops.d.ts.map +1 -0
  207. package/dist/api/client-lifeops.js +794 -0
  208. package/dist/api/client-lifeops.js.map +1 -0
  209. package/dist/automation-node-contributor.d.ts +2 -0
  210. package/dist/automation-node-contributor.d.ts.map +1 -0
  211. package/dist/automation-node-contributor.js +184 -0
  212. package/dist/automation-node-contributor.js.map +1 -0
  213. package/dist/client.d.ts +16 -0
  214. package/dist/client.d.ts.map +1 -0
  215. package/dist/client.js +18 -0
  216. package/dist/client.js.map +1 -0
  217. package/dist/components/AppBlockerSettingsCard.d.ts +3 -0
  218. package/dist/components/AppBlockerSettingsCard.d.ts.map +1 -0
  219. package/dist/components/AppBlockerSettingsCard.js +538 -0
  220. package/dist/components/AppBlockerSettingsCard.js.map +1 -0
  221. package/dist/components/WebsiteBlockerSettingsCard.d.ts +3 -0
  222. package/dist/components/WebsiteBlockerSettingsCard.d.ts.map +1 -0
  223. package/dist/components/WebsiteBlockerSettingsCard.js +148 -0
  224. package/dist/components/WebsiteBlockerSettingsCard.js.map +1 -0
  225. package/dist/contracts/index.d.ts +2 -0
  226. package/dist/contracts/index.d.ts.map +1 -0
  227. package/dist/contracts/index.js +2 -0
  228. package/dist/contracts/index.js.map +1 -0
  229. package/dist/contracts/lifeops.d.ts +2 -0
  230. package/dist/contracts/lifeops.d.ts.map +1 -0
  231. package/dist/contracts/lifeops.js +2 -0
  232. package/dist/contracts/lifeops.js.map +1 -0
  233. package/dist/default-packs/autofill-whitelist-pack.d.ts +17 -0
  234. package/dist/default-packs/autofill-whitelist-pack.d.ts.map +1 -0
  235. package/dist/default-packs/autofill-whitelist-pack.js +56 -0
  236. package/dist/default-packs/autofill-whitelist-pack.js.map +1 -0
  237. package/dist/default-packs/consolidation-policies.d.ts +14 -0
  238. package/dist/default-packs/consolidation-policies.d.ts.map +1 -0
  239. package/dist/default-packs/consolidation-policies.js +17 -0
  240. package/dist/default-packs/consolidation-policies.js.map +1 -0
  241. package/dist/default-packs/contract-types.d.ts +200 -0
  242. package/dist/default-packs/contract-types.d.ts.map +1 -0
  243. package/dist/default-packs/contract-types.js +1 -0
  244. package/dist/default-packs/contract-types.js.map +1 -0
  245. package/dist/default-packs/daily-rhythm.d.ts +28 -0
  246. package/dist/default-packs/daily-rhythm.d.ts.map +1 -0
  247. package/dist/default-packs/daily-rhythm.js +136 -0
  248. package/dist/default-packs/daily-rhythm.js.map +1 -0
  249. package/dist/default-packs/escalation-ladders.d.ts +18 -0
  250. package/dist/default-packs/escalation-ladders.d.ts.map +1 -0
  251. package/dist/default-packs/escalation-ladders.js +17 -0
  252. package/dist/default-packs/escalation-ladders.js.map +1 -0
  253. package/dist/default-packs/executive-assistant.d.ts +50 -0
  254. package/dist/default-packs/executive-assistant.d.ts.map +1 -0
  255. package/dist/default-packs/executive-assistant.js +745 -0
  256. package/dist/default-packs/executive-assistant.js.map +1 -0
  257. package/dist/default-packs/followup-starter.d.ts +49 -0
  258. package/dist/default-packs/followup-starter.d.ts.map +1 -0
  259. package/dist/default-packs/followup-starter.js +104 -0
  260. package/dist/default-packs/followup-starter.js.map +1 -0
  261. package/dist/default-packs/habit-starters.d.ts +37 -0
  262. package/dist/default-packs/habit-starters.d.ts.map +1 -0
  263. package/dist/default-packs/habit-starters.js +255 -0
  264. package/dist/default-packs/habit-starters.js.map +1 -0
  265. package/dist/default-packs/inbox-triage-starter.d.ts +23 -0
  266. package/dist/default-packs/inbox-triage-starter.d.ts.map +1 -0
  267. package/dist/default-packs/inbox-triage-starter.js +61 -0
  268. package/dist/default-packs/inbox-triage-starter.js.map +1 -0
  269. package/dist/default-packs/index.d.ts +54 -0
  270. package/dist/default-packs/index.d.ts.map +1 -0
  271. package/dist/default-packs/index.js +150 -0
  272. package/dist/default-packs/index.js.map +1 -0
  273. package/dist/default-packs/lint.d.ts +62 -0
  274. package/dist/default-packs/lint.d.ts.map +1 -0
  275. package/dist/default-packs/lint.js +161 -0
  276. package/dist/default-packs/lint.js.map +1 -0
  277. package/dist/default-packs/morning-brief.d.ts +44 -0
  278. package/dist/default-packs/morning-brief.d.ts.map +1 -0
  279. package/dist/default-packs/morning-brief.js +69 -0
  280. package/dist/default-packs/morning-brief.js.map +1 -0
  281. package/dist/default-packs/quiet-user-watcher.d.ts +49 -0
  282. package/dist/default-packs/quiet-user-watcher.d.ts.map +1 -0
  283. package/dist/default-packs/quiet-user-watcher.js +92 -0
  284. package/dist/default-packs/quiet-user-watcher.js.map +1 -0
  285. package/dist/default-packs/registry-types.d.ts +51 -0
  286. package/dist/default-packs/registry-types.d.ts.map +1 -0
  287. package/dist/default-packs/registry-types.js +1 -0
  288. package/dist/default-packs/registry-types.js.map +1 -0
  289. package/dist/default-packs/task-definitions.d.ts +88 -0
  290. package/dist/default-packs/task-definitions.d.ts.map +1 -0
  291. package/dist/default-packs/task-definitions.js +87 -0
  292. package/dist/default-packs/task-definitions.js.map +1 -0
  293. package/dist/events/index.d.ts +34 -0
  294. package/dist/events/index.d.ts.map +1 -0
  295. package/dist/events/index.js +30 -0
  296. package/dist/events/index.js.map +1 -0
  297. package/dist/followup/actions/listOverdueFollowups.d.ts +3 -0
  298. package/dist/followup/actions/listOverdueFollowups.d.ts.map +1 -0
  299. package/dist/followup/actions/listOverdueFollowups.js +90 -0
  300. package/dist/followup/actions/listOverdueFollowups.js.map +1 -0
  301. package/dist/followup/actions/markFollowupDone.d.ts +3 -0
  302. package/dist/followup/actions/markFollowupDone.d.ts.map +1 -0
  303. package/dist/followup/actions/markFollowupDone.js +171 -0
  304. package/dist/followup/actions/markFollowupDone.js.map +1 -0
  305. package/dist/followup/actions/setFollowupThreshold.d.ts +3 -0
  306. package/dist/followup/actions/setFollowupThreshold.d.ts.map +1 -0
  307. package/dist/followup/actions/setFollowupThreshold.js +171 -0
  308. package/dist/followup/actions/setFollowupThreshold.js.map +1 -0
  309. package/dist/followup/followup-tracker.d.ts +83 -0
  310. package/dist/followup/followup-tracker.d.ts.map +1 -0
  311. package/dist/followup/followup-tracker.js +311 -0
  312. package/dist/followup/followup-tracker.js.map +1 -0
  313. package/dist/followup/index.d.ts +5 -0
  314. package/dist/followup/index.d.ts.map +1 -0
  315. package/dist/followup/index.js +39 -0
  316. package/dist/followup/index.js.map +1 -0
  317. package/dist/hooks/connector-error.d.ts +2 -0
  318. package/dist/hooks/connector-error.d.ts.map +1 -0
  319. package/dist/hooks/connector-error.js +13 -0
  320. package/dist/hooks/connector-error.js.map +1 -0
  321. package/dist/hooks/useDiscordConnector.d.ts +11 -0
  322. package/dist/hooks/useDiscordConnector.d.ts.map +1 -0
  323. package/dist/hooks/useDiscordConnector.js +95 -0
  324. package/dist/hooks/useDiscordConnector.js.map +1 -0
  325. package/dist/hooks/useGoogleLifeOpsConnector.d.ts +23 -0
  326. package/dist/hooks/useGoogleLifeOpsConnector.d.ts.map +1 -0
  327. package/dist/hooks/useGoogleLifeOpsConnector.js +630 -0
  328. package/dist/hooks/useGoogleLifeOpsConnector.js.map +1 -0
  329. package/dist/hooks/useIMessageConnector.d.ts +10 -0
  330. package/dist/hooks/useIMessageConnector.d.ts.map +1 -0
  331. package/dist/hooks/useIMessageConnector.js +57 -0
  332. package/dist/hooks/useIMessageConnector.js.map +1 -0
  333. package/dist/hooks/useInbox.d.ts +36 -0
  334. package/dist/hooks/useInbox.d.ts.map +1 -0
  335. package/dist/hooks/useInbox.js +96 -0
  336. package/dist/hooks/useInbox.js.map +1 -0
  337. package/dist/hooks/useLifeOpsActivitySignals.d.ts +2 -0
  338. package/dist/hooks/useLifeOpsActivitySignals.d.ts.map +1 -0
  339. package/dist/hooks/useLifeOpsActivitySignals.js +358 -0
  340. package/dist/hooks/useLifeOpsActivitySignals.js.map +1 -0
  341. package/dist/hooks/useLifeOpsAppState.d.ts +9 -0
  342. package/dist/hooks/useLifeOpsAppState.d.ts.map +1 -0
  343. package/dist/hooks/useLifeOpsAppState.js +79 -0
  344. package/dist/hooks/useLifeOpsAppState.js.map +1 -0
  345. package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts +8 -0
  346. package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts.map +1 -0
  347. package/dist/hooks/useLifeOpsCapabilitiesStatus.js +60 -0
  348. package/dist/hooks/useLifeOpsCapabilitiesStatus.js.map +1 -0
  349. package/dist/hooks/useLifeOpsXConnector.d.ts +11 -0
  350. package/dist/hooks/useLifeOpsXConnector.d.ts.map +1 -0
  351. package/dist/hooks/useLifeOpsXConnector.js +92 -0
  352. package/dist/hooks/useLifeOpsXConnector.js.map +1 -0
  353. package/dist/hooks/useSignalConnector.d.ts +14 -0
  354. package/dist/hooks/useSignalConnector.d.ts.map +1 -0
  355. package/dist/hooks/useSignalConnector.js +89 -0
  356. package/dist/hooks/useSignalConnector.js.map +1 -0
  357. package/dist/hooks/useTelegramConnector.d.ts +14 -0
  358. package/dist/hooks/useTelegramConnector.d.ts.map +1 -0
  359. package/dist/hooks/useTelegramConnector.js +97 -0
  360. package/dist/hooks/useTelegramConnector.js.map +1 -0
  361. package/dist/hooks/useWhatsAppConnector.d.ts +8 -0
  362. package/dist/hooks/useWhatsAppConnector.d.ts.map +1 -0
  363. package/dist/hooks/useWhatsAppConnector.js +62 -0
  364. package/dist/hooks/useWhatsAppConnector.js.map +1 -0
  365. package/dist/inbox/message-fetcher.d.ts +11 -0
  366. package/dist/inbox/message-fetcher.d.ts.map +1 -0
  367. package/dist/inbox/message-fetcher.js +13 -0
  368. package/dist/inbox/message-fetcher.js.map +1 -0
  369. package/dist/inbox/repository.d.ts +11 -0
  370. package/dist/inbox/repository.d.ts.map +1 -0
  371. package/dist/inbox/repository.js +5 -0
  372. package/dist/inbox/repository.js.map +1 -0
  373. package/dist/inbox/types.d.ts +10 -0
  374. package/dist/inbox/types.d.ts.map +1 -0
  375. package/dist/inbox/types.js +2 -0
  376. package/dist/inbox/types.js.map +1 -0
  377. package/dist/index.d.ts +36 -0
  378. package/dist/index.d.ts.map +1 -0
  379. package/dist/index.js +188 -0
  380. package/dist/index.js.map +1 -0
  381. package/dist/lifeops/access.d.ts +29 -0
  382. package/dist/lifeops/access.d.ts.map +1 -0
  383. package/dist/lifeops/access.js +56 -0
  384. package/dist/lifeops/access.js.map +1 -0
  385. package/dist/lifeops/app-state.d.ts +22 -0
  386. package/dist/lifeops/app-state.d.ts.map +1 -0
  387. package/dist/lifeops/app-state.js +67 -0
  388. package/dist/lifeops/app-state.js.map +1 -0
  389. package/dist/lifeops/apple-reminders.d.ts +67 -0
  390. package/dist/lifeops/apple-reminders.d.ts.map +1 -0
  391. package/dist/lifeops/apple-reminders.js +396 -0
  392. package/dist/lifeops/apple-reminders.js.map +1 -0
  393. package/dist/lifeops/approval-queue.d.ts +38 -0
  394. package/dist/lifeops/approval-queue.d.ts.map +1 -0
  395. package/dist/lifeops/approval-queue.js +575 -0
  396. package/dist/lifeops/approval-queue.js.map +1 -0
  397. package/dist/lifeops/approval-queue.types.d.ts +172 -0
  398. package/dist/lifeops/approval-queue.types.d.ts.map +1 -0
  399. package/dist/lifeops/approval-queue.types.js +27 -0
  400. package/dist/lifeops/approval-queue.types.js.map +1 -0
  401. package/dist/lifeops/autofill-whitelist.d.ts +20 -0
  402. package/dist/lifeops/autofill-whitelist.d.ts.map +1 -0
  403. package/dist/lifeops/autofill-whitelist.js +59 -0
  404. package/dist/lifeops/autofill-whitelist.js.map +1 -0
  405. package/dist/lifeops/background-planner-dispatch.d.ts +60 -0
  406. package/dist/lifeops/background-planner-dispatch.d.ts.map +1 -0
  407. package/dist/lifeops/background-planner-dispatch.js +113 -0
  408. package/dist/lifeops/background-planner-dispatch.js.map +1 -0
  409. package/dist/lifeops/background-planner.d.ts +140 -0
  410. package/dist/lifeops/background-planner.d.ts.map +1 -0
  411. package/dist/lifeops/background-planner.js +359 -0
  412. package/dist/lifeops/background-planner.js.map +1 -0
  413. package/dist/lifeops/bill-extraction.d.ts +46 -0
  414. package/dist/lifeops/bill-extraction.d.ts.map +1 -0
  415. package/dist/lifeops/bill-extraction.js +325 -0
  416. package/dist/lifeops/bill-extraction.js.map +1 -0
  417. package/dist/lifeops/browser-constants.d.ts +4 -0
  418. package/dist/lifeops/browser-constants.d.ts.map +1 -0
  419. package/dist/lifeops/browser-constants.js +27 -0
  420. package/dist/lifeops/browser-constants.js.map +1 -0
  421. package/dist/lifeops/browser-extension-store.d.ts +61 -0
  422. package/dist/lifeops/browser-extension-store.d.ts.map +1 -0
  423. package/dist/lifeops/browser-extension-store.js +176 -0
  424. package/dist/lifeops/browser-extension-store.js.map +1 -0
  425. package/dist/lifeops/browser-session-lifecycle.d.ts +57 -0
  426. package/dist/lifeops/browser-session-lifecycle.d.ts.map +1 -0
  427. package/dist/lifeops/browser-session-lifecycle.js +308 -0
  428. package/dist/lifeops/browser-session-lifecycle.js.map +1 -0
  429. package/dist/lifeops/bulk-review.d.ts +333 -0
  430. package/dist/lifeops/bulk-review.d.ts.map +1 -0
  431. package/dist/lifeops/bulk-review.js +1120 -0
  432. package/dist/lifeops/bulk-review.js.map +1 -0
  433. package/dist/lifeops/calendar-gate.d.ts +20 -0
  434. package/dist/lifeops/calendar-gate.d.ts.map +1 -0
  435. package/dist/lifeops/calendar-gate.js +30 -0
  436. package/dist/lifeops/calendar-gate.js.map +1 -0
  437. package/dist/lifeops/channels/contract.d.ts +47 -0
  438. package/dist/lifeops/channels/contract.d.ts.map +1 -0
  439. package/dist/lifeops/channels/contract.js +1 -0
  440. package/dist/lifeops/channels/contract.js.map +1 -0
  441. package/dist/lifeops/channels/default-pack.d.ts +26 -0
  442. package/dist/lifeops/channels/default-pack.d.ts.map +1 -0
  443. package/dist/lifeops/channels/default-pack.js +243 -0
  444. package/dist/lifeops/channels/default-pack.js.map +1 -0
  445. package/dist/lifeops/channels/index.d.ts +5 -0
  446. package/dist/lifeops/channels/index.d.ts.map +1 -0
  447. package/dist/lifeops/channels/index.js +23 -0
  448. package/dist/lifeops/channels/index.js.map +1 -0
  449. package/dist/lifeops/channels/priority-posture.d.ts +36 -0
  450. package/dist/lifeops/channels/priority-posture.d.ts.map +1 -0
  451. package/dist/lifeops/channels/priority-posture.js +27 -0
  452. package/dist/lifeops/channels/priority-posture.js.map +1 -0
  453. package/dist/lifeops/channels/registry.d.ts +7 -0
  454. package/dist/lifeops/channels/registry.d.ts.map +1 -0
  455. package/dist/lifeops/channels/registry.js +49 -0
  456. package/dist/lifeops/channels/registry.js.map +1 -0
  457. package/dist/lifeops/checkin/checkin-service.d.ts +66 -0
  458. package/dist/lifeops/checkin/checkin-service.d.ts.map +1 -0
  459. package/dist/lifeops/checkin/checkin-service.js +1084 -0
  460. package/dist/lifeops/checkin/checkin-service.js.map +1 -0
  461. package/dist/lifeops/checkin/schedule-resolver.d.ts +17 -0
  462. package/dist/lifeops/checkin/schedule-resolver.d.ts.map +1 -0
  463. package/dist/lifeops/checkin/schedule-resolver.js +26 -0
  464. package/dist/lifeops/checkin/schedule-resolver.js.map +1 -0
  465. package/dist/lifeops/checkin/types.d.ts +106 -0
  466. package/dist/lifeops/checkin/types.d.ts.map +1 -0
  467. package/dist/lifeops/checkin/types.js +1 -0
  468. package/dist/lifeops/checkin/types.js.map +1 -0
  469. package/dist/lifeops/connectors/_helpers.d.ts +51 -0
  470. package/dist/lifeops/connectors/_helpers.d.ts.map +1 -0
  471. package/dist/lifeops/connectors/_helpers.js +104 -0
  472. package/dist/lifeops/connectors/_helpers.js.map +1 -0
  473. package/dist/lifeops/connectors/calendly.d.ts +11 -0
  474. package/dist/lifeops/connectors/calendly.d.ts.map +1 -0
  475. package/dist/lifeops/connectors/calendly.js +61 -0
  476. package/dist/lifeops/connectors/calendly.js.map +1 -0
  477. package/dist/lifeops/connectors/contract.d.ts +88 -0
  478. package/dist/lifeops/connectors/contract.d.ts.map +1 -0
  479. package/dist/lifeops/connectors/contract.js +1 -0
  480. package/dist/lifeops/connectors/contract.js.map +1 -0
  481. package/dist/lifeops/connectors/default-pack.d.ts +35 -0
  482. package/dist/lifeops/connectors/default-pack.d.ts.map +1 -0
  483. package/dist/lifeops/connectors/default-pack.js +37 -0
  484. package/dist/lifeops/connectors/default-pack.js.map +1 -0
  485. package/dist/lifeops/connectors/discord.d.ts +8 -0
  486. package/dist/lifeops/connectors/discord.d.ts.map +1 -0
  487. package/dist/lifeops/connectors/discord.js +53 -0
  488. package/dist/lifeops/connectors/discord.js.map +1 -0
  489. package/dist/lifeops/connectors/dispatch-policy.d.ts +75 -0
  490. package/dist/lifeops/connectors/dispatch-policy.d.ts.map +1 -0
  491. package/dist/lifeops/connectors/dispatch-policy.js +35 -0
  492. package/dist/lifeops/connectors/dispatch-policy.js.map +1 -0
  493. package/dist/lifeops/connectors/duffel.d.ts +11 -0
  494. package/dist/lifeops/connectors/duffel.d.ts.map +1 -0
  495. package/dist/lifeops/connectors/duffel.js +74 -0
  496. package/dist/lifeops/connectors/duffel.js.map +1 -0
  497. package/dist/lifeops/connectors/google.d.ts +27 -0
  498. package/dist/lifeops/connectors/google.d.ts.map +1 -0
  499. package/dist/lifeops/connectors/google.js +80 -0
  500. package/dist/lifeops/connectors/google.js.map +1 -0
  501. package/dist/lifeops/connectors/imessage.d.ts +11 -0
  502. package/dist/lifeops/connectors/imessage.d.ts.map +1 -0
  503. package/dist/lifeops/connectors/imessage.js +55 -0
  504. package/dist/lifeops/connectors/imessage.js.map +1 -0
  505. package/dist/lifeops/connectors/index.d.ts +5 -0
  506. package/dist/lifeops/connectors/index.d.ts.map +1 -0
  507. package/dist/lifeops/connectors/index.js +23 -0
  508. package/dist/lifeops/connectors/index.js.map +1 -0
  509. package/dist/lifeops/connectors/mockoon-redirect.d.ts +54 -0
  510. package/dist/lifeops/connectors/mockoon-redirect.d.ts.map +1 -0
  511. package/dist/lifeops/connectors/mockoon-redirect.js +71 -0
  512. package/dist/lifeops/connectors/mockoon-redirect.js.map +1 -0
  513. package/dist/lifeops/connectors/registry.d.ts +7 -0
  514. package/dist/lifeops/connectors/registry.d.ts.map +1 -0
  515. package/dist/lifeops/connectors/registry.js +55 -0
  516. package/dist/lifeops/connectors/registry.js.map +1 -0
  517. package/dist/lifeops/connectors/signal.d.ts +8 -0
  518. package/dist/lifeops/connectors/signal.d.ts.map +1 -0
  519. package/dist/lifeops/connectors/signal.js +60 -0
  520. package/dist/lifeops/connectors/signal.js.map +1 -0
  521. package/dist/lifeops/connectors/telegram.d.ts +12 -0
  522. package/dist/lifeops/connectors/telegram.d.ts.map +1 -0
  523. package/dist/lifeops/connectors/telegram.js +65 -0
  524. package/dist/lifeops/connectors/telegram.js.map +1 -0
  525. package/dist/lifeops/connectors/twilio.d.ts +15 -0
  526. package/dist/lifeops/connectors/twilio.d.ts.map +1 -0
  527. package/dist/lifeops/connectors/twilio.js +126 -0
  528. package/dist/lifeops/connectors/twilio.js.map +1 -0
  529. package/dist/lifeops/connectors/whatsapp.d.ts +10 -0
  530. package/dist/lifeops/connectors/whatsapp.d.ts.map +1 -0
  531. package/dist/lifeops/connectors/whatsapp.js +56 -0
  532. package/dist/lifeops/connectors/whatsapp.js.map +1 -0
  533. package/dist/lifeops/connectors/x.d.ts +8 -0
  534. package/dist/lifeops/connectors/x.d.ts.map +1 -0
  535. package/dist/lifeops/connectors/x.js +62 -0
  536. package/dist/lifeops/connectors/x.js.map +1 -0
  537. package/dist/lifeops/contact-route-policy.d.ts +27 -0
  538. package/dist/lifeops/contact-route-policy.d.ts.map +1 -0
  539. package/dist/lifeops/contact-route-policy.js +153 -0
  540. package/dist/lifeops/contact-route-policy.js.map +1 -0
  541. package/dist/lifeops/continuity-probe.d.ts +49 -0
  542. package/dist/lifeops/continuity-probe.d.ts.map +1 -0
  543. package/dist/lifeops/continuity-probe.js +161 -0
  544. package/dist/lifeops/continuity-probe.js.map +1 -0
  545. package/dist/lifeops/cross-channel-search.d.ts +108 -0
  546. package/dist/lifeops/cross-channel-search.d.ts.map +1 -0
  547. package/dist/lifeops/cross-channel-search.js +888 -0
  548. package/dist/lifeops/cross-channel-search.js.map +1 -0
  549. package/dist/lifeops/defaults.d.ts +30 -0
  550. package/dist/lifeops/defaults.d.ts.map +1 -0
  551. package/dist/lifeops/defaults.js +206 -0
  552. package/dist/lifeops/defaults.js.map +1 -0
  553. package/dist/lifeops/device-bus-service.d.ts +16 -0
  554. package/dist/lifeops/device-bus-service.d.ts.map +1 -0
  555. package/dist/lifeops/device-bus-service.js +20 -0
  556. package/dist/lifeops/device-bus-service.js.map +1 -0
  557. package/dist/lifeops/device-identity.d.ts +31 -0
  558. package/dist/lifeops/device-identity.d.ts.map +1 -0
  559. package/dist/lifeops/device-identity.js +94 -0
  560. package/dist/lifeops/device-identity.js.map +1 -0
  561. package/dist/lifeops/document-review.d.ts +264 -0
  562. package/dist/lifeops/document-review.d.ts.map +1 -0
  563. package/dist/lifeops/document-review.js +925 -0
  564. package/dist/lifeops/document-review.js.map +1 -0
  565. package/dist/lifeops/email-classifier.d.ts +9 -0
  566. package/dist/lifeops/email-classifier.d.ts.map +1 -0
  567. package/dist/lifeops/email-classifier.js +15 -0
  568. package/dist/lifeops/email-classifier.js.map +1 -0
  569. package/dist/lifeops/email-curation.d.ts +13 -0
  570. package/dist/lifeops/email-curation.d.ts.map +1 -0
  571. package/dist/lifeops/email-curation.js +2 -0
  572. package/dist/lifeops/email-curation.js.map +1 -0
  573. package/dist/lifeops/email-unsubscribe-types.d.ts +7 -0
  574. package/dist/lifeops/email-unsubscribe-types.d.ts.map +1 -0
  575. package/dist/lifeops/email-unsubscribe-types.js +1 -0
  576. package/dist/lifeops/email-unsubscribe-types.js.map +1 -0
  577. package/dist/lifeops/enforcement-windows.d.ts +34 -0
  578. package/dist/lifeops/enforcement-windows.d.ts.map +1 -0
  579. package/dist/lifeops/enforcement-windows.js +80 -0
  580. package/dist/lifeops/enforcement-windows.js.map +1 -0
  581. package/dist/lifeops/engine.d.ts +8 -0
  582. package/dist/lifeops/engine.d.ts.map +1 -0
  583. package/dist/lifeops/engine.js +540 -0
  584. package/dist/lifeops/engine.js.map +1 -0
  585. package/dist/lifeops/entities/index.d.ts +4 -0
  586. package/dist/lifeops/entities/index.d.ts.map +1 -0
  587. package/dist/lifeops/entities/index.js +29 -0
  588. package/dist/lifeops/entities/index.js.map +1 -0
  589. package/dist/lifeops/entities/merge.d.ts +9 -0
  590. package/dist/lifeops/entities/merge.d.ts.map +1 -0
  591. package/dist/lifeops/entities/merge.js +17 -0
  592. package/dist/lifeops/entities/merge.js.map +1 -0
  593. package/dist/lifeops/entities/store.d.ts +13 -0
  594. package/dist/lifeops/entities/store.d.ts.map +1 -0
  595. package/dist/lifeops/entities/store.js +7 -0
  596. package/dist/lifeops/entities/store.js.map +1 -0
  597. package/dist/lifeops/entities/types.d.ts +9 -0
  598. package/dist/lifeops/entities/types.d.ts.map +1 -0
  599. package/dist/lifeops/entities/types.js +13 -0
  600. package/dist/lifeops/entities/types.js.map +1 -0
  601. package/dist/lifeops/entities/voice-attribution.d.ts +70 -0
  602. package/dist/lifeops/entities/voice-attribution.d.ts.map +1 -0
  603. package/dist/lifeops/entities/voice-attribution.js +121 -0
  604. package/dist/lifeops/entities/voice-attribution.js.map +1 -0
  605. package/dist/lifeops/entities/voice-observer-bridge.d.ts +32 -0
  606. package/dist/lifeops/entities/voice-observer-bridge.d.ts.map +1 -0
  607. package/dist/lifeops/entities/voice-observer-bridge.js +68 -0
  608. package/dist/lifeops/entities/voice-observer-bridge.js.map +1 -0
  609. package/dist/lifeops/entities/voice-observer.d.ts +72 -0
  610. package/dist/lifeops/entities/voice-observer.d.ts.map +1 -0
  611. package/dist/lifeops/entities/voice-observer.js +97 -0
  612. package/dist/lifeops/entities/voice-observer.js.map +1 -0
  613. package/dist/lifeops/escalation-ladders.d.ts +28 -0
  614. package/dist/lifeops/escalation-ladders.d.ts.map +1 -0
  615. package/dist/lifeops/escalation-ladders.js +17 -0
  616. package/dist/lifeops/escalation-ladders.js.map +1 -0
  617. package/dist/lifeops/fda-probe.d.ts +23 -0
  618. package/dist/lifeops/fda-probe.d.ts.map +1 -0
  619. package/dist/lifeops/fda-probe.js +59 -0
  620. package/dist/lifeops/fda-probe.js.map +1 -0
  621. package/dist/lifeops/feature-flags.d.ts +24 -0
  622. package/dist/lifeops/feature-flags.d.ts.map +1 -0
  623. package/dist/lifeops/feature-flags.js +261 -0
  624. package/dist/lifeops/feature-flags.js.map +1 -0
  625. package/dist/lifeops/feature-flags.types.d.ts +156 -0
  626. package/dist/lifeops/feature-flags.types.d.ts.map +1 -0
  627. package/dist/lifeops/feature-flags.types.js +129 -0
  628. package/dist/lifeops/feature-flags.types.js.map +1 -0
  629. package/dist/lifeops/first-run/defaults.d.ts +57 -0
  630. package/dist/lifeops/first-run/defaults.d.ts.map +1 -0
  631. package/dist/lifeops/first-run/defaults.js +159 -0
  632. package/dist/lifeops/first-run/defaults.js.map +1 -0
  633. package/dist/lifeops/first-run/questions.d.ts +74 -0
  634. package/dist/lifeops/first-run/questions.d.ts.map +1 -0
  635. package/dist/lifeops/first-run/questions.js +184 -0
  636. package/dist/lifeops/first-run/questions.js.map +1 -0
  637. package/dist/lifeops/first-run/replay.d.ts +41 -0
  638. package/dist/lifeops/first-run/replay.d.ts.map +1 -0
  639. package/dist/lifeops/first-run/replay.js +34 -0
  640. package/dist/lifeops/first-run/replay.js.map +1 -0
  641. package/dist/lifeops/first-run/service.d.ts +147 -0
  642. package/dist/lifeops/first-run/service.d.ts.map +1 -0
  643. package/dist/lifeops/first-run/service.js +455 -0
  644. package/dist/lifeops/first-run/service.js.map +1 -0
  645. package/dist/lifeops/first-run/state.d.ts +36 -0
  646. package/dist/lifeops/first-run/state.d.ts.map +1 -0
  647. package/dist/lifeops/first-run/state.js +128 -0
  648. package/dist/lifeops/first-run/state.js.map +1 -0
  649. package/dist/lifeops/global-pause/store.d.ts +22 -0
  650. package/dist/lifeops/global-pause/store.d.ts.map +1 -0
  651. package/dist/lifeops/global-pause/store.js +18 -0
  652. package/dist/lifeops/global-pause/store.js.map +1 -0
  653. package/dist/lifeops/goal-grounding.d.ts +9 -0
  654. package/dist/lifeops/goal-grounding.d.ts.map +1 -0
  655. package/dist/lifeops/goal-grounding.js +19 -0
  656. package/dist/lifeops/goal-grounding.js.map +1 -0
  657. package/dist/lifeops/goal-semantic-evaluator.d.ts +8 -0
  658. package/dist/lifeops/goal-semantic-evaluator.d.ts.map +1 -0
  659. package/dist/lifeops/goal-semantic-evaluator.js +7 -0
  660. package/dist/lifeops/goal-semantic-evaluator.js.map +1 -0
  661. package/dist/lifeops/google/format-helpers.d.ts +63 -0
  662. package/dist/lifeops/google/format-helpers.d.ts.map +1 -0
  663. package/dist/lifeops/google/format-helpers.js +597 -0
  664. package/dist/lifeops/google/format-helpers.js.map +1 -0
  665. package/dist/lifeops/google-plugin-delegates.d.ts +59 -0
  666. package/dist/lifeops/google-plugin-delegates.d.ts.map +1 -0
  667. package/dist/lifeops/google-plugin-delegates.js +408 -0
  668. package/dist/lifeops/google-plugin-delegates.js.map +1 -0
  669. package/dist/lifeops/google-scopes.d.ts +15 -0
  670. package/dist/lifeops/google-scopes.d.ts.map +1 -0
  671. package/dist/lifeops/google-scopes.js +118 -0
  672. package/dist/lifeops/google-scopes.js.map +1 -0
  673. package/dist/lifeops/handoff/store.d.ts +23 -0
  674. package/dist/lifeops/handoff/store.d.ts.map +1 -0
  675. package/dist/lifeops/handoff/store.js +20 -0
  676. package/dist/lifeops/handoff/store.js.map +1 -0
  677. package/dist/lifeops/i18n/localized-examples-provider.d.ts +16 -0
  678. package/dist/lifeops/i18n/localized-examples-provider.d.ts.map +1 -0
  679. package/dist/lifeops/i18n/localized-examples-provider.js +33 -0
  680. package/dist/lifeops/i18n/localized-examples-provider.js.map +1 -0
  681. package/dist/lifeops/i18n/localized-examples-resolver.d.ts +32 -0
  682. package/dist/lifeops/i18n/localized-examples-resolver.d.ts.map +1 -0
  683. package/dist/lifeops/i18n/localized-examples-resolver.js +28 -0
  684. package/dist/lifeops/i18n/localized-examples-resolver.js.map +1 -0
  685. package/dist/lifeops/i18n/prompt-registry.d.ts +64 -0
  686. package/dist/lifeops/i18n/prompt-registry.d.ts.map +1 -0
  687. package/dist/lifeops/i18n/prompt-registry.js +283 -0
  688. package/dist/lifeops/i18n/prompt-registry.js.map +1 -0
  689. package/dist/lifeops/imessage-outbound-probe.d.ts +7 -0
  690. package/dist/lifeops/imessage-outbound-probe.d.ts.map +1 -0
  691. package/dist/lifeops/imessage-outbound-probe.js +81 -0
  692. package/dist/lifeops/imessage-outbound-probe.js.map +1 -0
  693. package/dist/lifeops/index.d.ts +24 -0
  694. package/dist/lifeops/index.d.ts.map +1 -0
  695. package/dist/lifeops/index.js +24 -0
  696. package/dist/lifeops/index.js.map +1 -0
  697. package/dist/lifeops/intent-sync.d.ts +64 -0
  698. package/dist/lifeops/intent-sync.d.ts.map +1 -0
  699. package/dist/lifeops/intent-sync.js +321 -0
  700. package/dist/lifeops/intent-sync.js.map +1 -0
  701. package/dist/lifeops/messaging/index.d.ts +2 -0
  702. package/dist/lifeops/messaging/index.d.ts.map +1 -0
  703. package/dist/lifeops/messaging/index.js +5 -0
  704. package/dist/lifeops/messaging/index.js.map +1 -0
  705. package/dist/lifeops/messaging/owner-send-policy.d.ts +3 -0
  706. package/dist/lifeops/messaging/owner-send-policy.d.ts.map +1 -0
  707. package/dist/lifeops/messaging/owner-send-policy.js +83 -0
  708. package/dist/lifeops/messaging/owner-send-policy.js.map +1 -0
  709. package/dist/lifeops/notifications-push.d.ts +37 -0
  710. package/dist/lifeops/notifications-push.d.ts.map +1 -0
  711. package/dist/lifeops/notifications-push.js +95 -0
  712. package/dist/lifeops/notifications-push.js.map +1 -0
  713. package/dist/lifeops/optimized-prompt-instructions.d.ts +5 -0
  714. package/dist/lifeops/optimized-prompt-instructions.d.ts.map +1 -0
  715. package/dist/lifeops/optimized-prompt-instructions.js +48 -0
  716. package/dist/lifeops/optimized-prompt-instructions.js.map +1 -0
  717. package/dist/lifeops/owner/fact-store.d.ts +143 -0
  718. package/dist/lifeops/owner/fact-store.d.ts.map +1 -0
  719. package/dist/lifeops/owner/fact-store.js +446 -0
  720. package/dist/lifeops/owner/fact-store.js.map +1 -0
  721. package/dist/lifeops/owner/profile-extraction-evaluator.d.ts +3 -0
  722. package/dist/lifeops/owner/profile-extraction-evaluator.d.ts.map +1 -0
  723. package/dist/lifeops/owner/profile-extraction-evaluator.js +241 -0
  724. package/dist/lifeops/owner/profile-extraction-evaluator.js.map +1 -0
  725. package/dist/lifeops/owner-profile.d.ts +61 -0
  726. package/dist/lifeops/owner-profile.d.ts.map +1 -0
  727. package/dist/lifeops/owner-profile.js +407 -0
  728. package/dist/lifeops/owner-profile.js.map +1 -0
  729. package/dist/lifeops/pending-prompts/store.d.ts +23 -0
  730. package/dist/lifeops/pending-prompts/store.d.ts.map +1 -0
  731. package/dist/lifeops/pending-prompts/store.js +16 -0
  732. package/dist/lifeops/pending-prompts/store.js.map +1 -0
  733. package/dist/lifeops/policy-memory.d.ts +190 -0
  734. package/dist/lifeops/policy-memory.d.ts.map +1 -0
  735. package/dist/lifeops/policy-memory.js +1026 -0
  736. package/dist/lifeops/policy-memory.js.map +1 -0
  737. package/dist/lifeops/priority-scoring.d.ts +51 -0
  738. package/dist/lifeops/priority-scoring.d.ts.map +1 -0
  739. package/dist/lifeops/priority-scoring.js +305 -0
  740. package/dist/lifeops/priority-scoring.js.map +1 -0
  741. package/dist/lifeops/privacy-egress.d.ts +92 -0
  742. package/dist/lifeops/privacy-egress.d.ts.map +1 -0
  743. package/dist/lifeops/privacy-egress.js +230 -0
  744. package/dist/lifeops/privacy-egress.js.map +1 -0
  745. package/dist/lifeops/privacy.d.ts +49 -0
  746. package/dist/lifeops/privacy.d.ts.map +1 -0
  747. package/dist/lifeops/privacy.js +66 -0
  748. package/dist/lifeops/privacy.js.map +1 -0
  749. package/dist/lifeops/redact-sensitive-data.d.ts +32 -0
  750. package/dist/lifeops/redact-sensitive-data.d.ts.map +1 -0
  751. package/dist/lifeops/redact-sensitive-data.js +98 -0
  752. package/dist/lifeops/redact-sensitive-data.js.map +1 -0
  753. package/dist/lifeops/registries/app-blocker-contribution.d.ts +13 -0
  754. package/dist/lifeops/registries/app-blocker-contribution.d.ts.map +1 -0
  755. package/dist/lifeops/registries/app-blocker-contribution.js +73 -0
  756. package/dist/lifeops/registries/app-blocker-contribution.js.map +1 -0
  757. package/dist/lifeops/registries/blocker-registry.d.ts +76 -0
  758. package/dist/lifeops/registries/blocker-registry.d.ts.map +1 -0
  759. package/dist/lifeops/registries/blocker-registry.js +40 -0
  760. package/dist/lifeops/registries/blocker-registry.js.map +1 -0
  761. package/dist/lifeops/registries/event-kind-registry.d.ts +57 -0
  762. package/dist/lifeops/registries/event-kind-registry.d.ts.map +1 -0
  763. package/dist/lifeops/registries/event-kind-registry.js +82 -0
  764. package/dist/lifeops/registries/event-kind-registry.js.map +1 -0
  765. package/dist/lifeops/registries/family-registry.d.ts +72 -0
  766. package/dist/lifeops/registries/family-registry.d.ts.map +1 -0
  767. package/dist/lifeops/registries/family-registry.js +98 -0
  768. package/dist/lifeops/registries/family-registry.js.map +1 -0
  769. package/dist/lifeops/registries/feature-flag-default-pack.d.ts +32 -0
  770. package/dist/lifeops/registries/feature-flag-default-pack.d.ts.map +1 -0
  771. package/dist/lifeops/registries/feature-flag-default-pack.js +36 -0
  772. package/dist/lifeops/registries/feature-flag-default-pack.js.map +1 -0
  773. package/dist/lifeops/registries/feature-flag-registry.d.ts +76 -0
  774. package/dist/lifeops/registries/feature-flag-registry.d.ts.map +1 -0
  775. package/dist/lifeops/registries/feature-flag-registry.js +68 -0
  776. package/dist/lifeops/registries/feature-flag-registry.js.map +1 -0
  777. package/dist/lifeops/registries/index.d.ts +24 -0
  778. package/dist/lifeops/registries/index.d.ts.map +1 -0
  779. package/dist/lifeops/registries/index.js +115 -0
  780. package/dist/lifeops/registries/index.js.map +1 -0
  781. package/dist/lifeops/registries/website-blocker-contribution.d.ts +21 -0
  782. package/dist/lifeops/registries/website-blocker-contribution.d.ts.map +1 -0
  783. package/dist/lifeops/registries/website-blocker-contribution.js +76 -0
  784. package/dist/lifeops/registries/website-blocker-contribution.js.map +1 -0
  785. package/dist/lifeops/registries/workflow-step-default-pack.d.ts +30 -0
  786. package/dist/lifeops/registries/workflow-step-default-pack.d.ts.map +1 -0
  787. package/dist/lifeops/registries/workflow-step-default-pack.js +315 -0
  788. package/dist/lifeops/registries/workflow-step-default-pack.js.map +1 -0
  789. package/dist/lifeops/registries/workflow-step-registry.d.ts +101 -0
  790. package/dist/lifeops/registries/workflow-step-registry.d.ts.map +1 -0
  791. package/dist/lifeops/registries/workflow-step-registry.js +56 -0
  792. package/dist/lifeops/registries/workflow-step-registry.js.map +1 -0
  793. package/dist/lifeops/relationships/extraction.d.ts +77 -0
  794. package/dist/lifeops/relationships/extraction.d.ts.map +1 -0
  795. package/dist/lifeops/relationships/extraction.js +146 -0
  796. package/dist/lifeops/relationships/extraction.js.map +1 -0
  797. package/dist/lifeops/relationships/index.d.ts +4 -0
  798. package/dist/lifeops/relationships/index.d.ts.map +1 -0
  799. package/dist/lifeops/relationships/index.js +19 -0
  800. package/dist/lifeops/relationships/index.js.map +1 -0
  801. package/dist/lifeops/relationships/mapping.d.ts +34 -0
  802. package/dist/lifeops/relationships/mapping.d.ts.map +1 -0
  803. package/dist/lifeops/relationships/mapping.js +87 -0
  804. package/dist/lifeops/relationships/mapping.js.map +1 -0
  805. package/dist/lifeops/relationships/store.d.ts +12 -0
  806. package/dist/lifeops/relationships/store.d.ts.map +1 -0
  807. package/dist/lifeops/relationships/store.js +5 -0
  808. package/dist/lifeops/relationships/store.js.map +1 -0
  809. package/dist/lifeops/relationships/types.d.ts +9 -0
  810. package/dist/lifeops/relationships/types.d.ts.map +1 -0
  811. package/dist/lifeops/relationships/types.js +11 -0
  812. package/dist/lifeops/relationships/types.js.map +1 -0
  813. package/dist/lifeops/relative-schedule-resolver.d.ts +13 -0
  814. package/dist/lifeops/relative-schedule-resolver.d.ts.map +1 -0
  815. package/dist/lifeops/relative-schedule-resolver.js +107 -0
  816. package/dist/lifeops/relative-schedule-resolver.js.map +1 -0
  817. package/dist/lifeops/relative-time.d.ts +15 -0
  818. package/dist/lifeops/relative-time.d.ts.map +1 -0
  819. package/dist/lifeops/relative-time.js +191 -0
  820. package/dist/lifeops/relative-time.js.map +1 -0
  821. package/dist/lifeops/repository.d.ts +638 -0
  822. package/dist/lifeops/repository.d.ts.map +1 -0
  823. package/dist/lifeops/repository.js +6289 -0
  824. package/dist/lifeops/repository.js.map +1 -0
  825. package/dist/lifeops/runtime-cache.d.ts +4 -0
  826. package/dist/lifeops/runtime-cache.d.ts.map +1 -0
  827. package/dist/lifeops/runtime-cache.js +7 -0
  828. package/dist/lifeops/runtime-cache.js.map +1 -0
  829. package/dist/lifeops/runtime-service-delegates.d.ts +236 -0
  830. package/dist/lifeops/runtime-service-delegates.d.ts.map +1 -0
  831. package/dist/lifeops/runtime-service-delegates.js +839 -0
  832. package/dist/lifeops/runtime-service-delegates.js.map +1 -0
  833. package/dist/lifeops/runtime.d.ts +13 -0
  834. package/dist/lifeops/runtime.d.ts.map +1 -0
  835. package/dist/lifeops/runtime.js +104 -0
  836. package/dist/lifeops/runtime.js.map +1 -0
  837. package/dist/lifeops/schedule-insight.d.ts +133 -0
  838. package/dist/lifeops/schedule-insight.d.ts.map +1 -0
  839. package/dist/lifeops/schedule-insight.js +726 -0
  840. package/dist/lifeops/schedule-insight.js.map +1 -0
  841. package/dist/lifeops/schedule-state.d.ts +39 -0
  842. package/dist/lifeops/schedule-state.d.ts.map +1 -0
  843. package/dist/lifeops/schedule-state.js +671 -0
  844. package/dist/lifeops/schedule-state.js.map +1 -0
  845. package/dist/lifeops/schedule-sync-config.d.ts +3 -0
  846. package/dist/lifeops/schedule-sync-config.d.ts.map +1 -0
  847. package/dist/lifeops/schedule-sync-config.js +23 -0
  848. package/dist/lifeops/schedule-sync-config.js.map +1 -0
  849. package/dist/lifeops/schedule-sync-contracts.d.ts +2 -0
  850. package/dist/lifeops/schedule-sync-contracts.d.ts.map +1 -0
  851. package/dist/lifeops/schedule-sync-contracts.js +2 -0
  852. package/dist/lifeops/schedule-sync-contracts.js.map +1 -0
  853. package/dist/lifeops/scheduled-task/index.d.ts +13 -0
  854. package/dist/lifeops/scheduled-task/index.d.ts.map +1 -0
  855. package/dist/lifeops/scheduled-task/index.js +14 -0
  856. package/dist/lifeops/scheduled-task/index.js.map +1 -0
  857. package/dist/lifeops/scheduled-task/runtime-wiring.d.ts +33 -0
  858. package/dist/lifeops/scheduled-task/runtime-wiring.d.ts.map +1 -0
  859. package/dist/lifeops/scheduled-task/runtime-wiring.js +334 -0
  860. package/dist/lifeops/scheduled-task/runtime-wiring.js.map +1 -0
  861. package/dist/lifeops/scheduled-task/scheduler.d.ts +28 -0
  862. package/dist/lifeops/scheduled-task/scheduler.d.ts.map +1 -0
  863. package/dist/lifeops/scheduled-task/scheduler.js +202 -0
  864. package/dist/lifeops/scheduled-task/scheduler.js.map +1 -0
  865. package/dist/lifeops/scheduled-task/service.d.ts +61 -0
  866. package/dist/lifeops/scheduled-task/service.d.ts.map +1 -0
  867. package/dist/lifeops/scheduled-task/service.js +64 -0
  868. package/dist/lifeops/scheduled-task/service.js.map +1 -0
  869. package/dist/lifeops/scheduler-task.d.ts +19 -0
  870. package/dist/lifeops/scheduler-task.d.ts.map +1 -0
  871. package/dist/lifeops/scheduler-task.js +201 -0
  872. package/dist/lifeops/scheduler-task.js.map +1 -0
  873. package/dist/lifeops/schema.d.ts +28068 -0
  874. package/dist/lifeops/schema.d.ts.map +1 -0
  875. package/dist/lifeops/schema.js +1689 -0
  876. package/dist/lifeops/schema.js.map +1 -0
  877. package/dist/lifeops/screen-context.d.ts +66 -0
  878. package/dist/lifeops/screen-context.d.ts.map +1 -0
  879. package/dist/lifeops/screen-context.js +347 -0
  880. package/dist/lifeops/screen-context.js.map +1 -0
  881. package/dist/lifeops/seed-routine-migration/migrator.d.ts +113 -0
  882. package/dist/lifeops/seed-routine-migration/migrator.d.ts.map +1 -0
  883. package/dist/lifeops/seed-routine-migration/migrator.js +142 -0
  884. package/dist/lifeops/seed-routine-migration/migrator.js.map +1 -0
  885. package/dist/lifeops/seed-routines.d.ts +24 -0
  886. package/dist/lifeops/seed-routines.d.ts.map +1 -0
  887. package/dist/lifeops/seed-routines.js +140 -0
  888. package/dist/lifeops/seed-routines.js.map +1 -0
  889. package/dist/lifeops/send-policy/contract.d.ts +81 -0
  890. package/dist/lifeops/send-policy/contract.d.ts.map +1 -0
  891. package/dist/lifeops/send-policy/contract.js +1 -0
  892. package/dist/lifeops/send-policy/contract.js.map +1 -0
  893. package/dist/lifeops/send-policy/index.d.ts +3 -0
  894. package/dist/lifeops/send-policy/index.d.ts.map +1 -0
  895. package/dist/lifeops/send-policy/index.js +13 -0
  896. package/dist/lifeops/send-policy/index.js.map +1 -0
  897. package/dist/lifeops/send-policy/registry.d.ts +7 -0
  898. package/dist/lifeops/send-policy/registry.d.ts.map +1 -0
  899. package/dist/lifeops/send-policy/registry.js +62 -0
  900. package/dist/lifeops/send-policy/registry.js.map +1 -0
  901. package/dist/lifeops/sensitive-request-delivery.d.ts +46 -0
  902. package/dist/lifeops/sensitive-request-delivery.d.ts.map +1 -0
  903. package/dist/lifeops/sensitive-request-delivery.js +103 -0
  904. package/dist/lifeops/sensitive-request-delivery.js.map +1 -0
  905. package/dist/lifeops/service-constants.d.ts +10 -0
  906. package/dist/lifeops/service-constants.d.ts.map +1 -0
  907. package/dist/lifeops/service-constants.js +129 -0
  908. package/dist/lifeops/service-constants.js.map +1 -0
  909. package/dist/lifeops/service-helpers-browser.d.ts +41 -0
  910. package/dist/lifeops/service-helpers-browser.d.ts.map +1 -0
  911. package/dist/lifeops/service-helpers-browser.js +290 -0
  912. package/dist/lifeops/service-helpers-browser.js.map +1 -0
  913. package/dist/lifeops/service-helpers-misc.d.ts +68 -0
  914. package/dist/lifeops/service-helpers-misc.d.ts.map +1 -0
  915. package/dist/lifeops/service-helpers-misc.js +531 -0
  916. package/dist/lifeops/service-helpers-misc.js.map +1 -0
  917. package/dist/lifeops/service-helpers-occurrence.d.ts +23 -0
  918. package/dist/lifeops/service-helpers-occurrence.d.ts.map +1 -0
  919. package/dist/lifeops/service-helpers-occurrence.js +257 -0
  920. package/dist/lifeops/service-helpers-occurrence.js.map +1 -0
  921. package/dist/lifeops/service-helpers-reminder.d.ts +260 -0
  922. package/dist/lifeops/service-helpers-reminder.d.ts.map +1 -0
  923. package/dist/lifeops/service-helpers-reminder.js +1186 -0
  924. package/dist/lifeops/service-helpers-reminder.js.map +1 -0
  925. package/dist/lifeops/service-mixin-browser.d.ts +31 -0
  926. package/dist/lifeops/service-mixin-browser.d.ts.map +1 -0
  927. package/dist/lifeops/service-mixin-browser.js +975 -0
  928. package/dist/lifeops/service-mixin-browser.js.map +1 -0
  929. package/dist/lifeops/service-mixin-calendar.d.ts +53 -0
  930. package/dist/lifeops/service-mixin-calendar.d.ts.map +1 -0
  931. package/dist/lifeops/service-mixin-calendar.js +68 -0
  932. package/dist/lifeops/service-mixin-calendar.js.map +1 -0
  933. package/dist/lifeops/service-mixin-core.d.ts +51 -0
  934. package/dist/lifeops/service-mixin-core.d.ts.map +1 -0
  935. package/dist/lifeops/service-mixin-core.js +500 -0
  936. package/dist/lifeops/service-mixin-core.js.map +1 -0
  937. package/dist/lifeops/service-mixin-definitions.d.ts +14 -0
  938. package/dist/lifeops/service-mixin-definitions.d.ts.map +1 -0
  939. package/dist/lifeops/service-mixin-definitions.js +470 -0
  940. package/dist/lifeops/service-mixin-definitions.js.map +1 -0
  941. package/dist/lifeops/service-mixin-discord.d.ts +49 -0
  942. package/dist/lifeops/service-mixin-discord.d.ts.map +1 -0
  943. package/dist/lifeops/service-mixin-discord.js +1253 -0
  944. package/dist/lifeops/service-mixin-discord.js.map +1 -0
  945. package/dist/lifeops/service-mixin-drive.d.ts +96 -0
  946. package/dist/lifeops/service-mixin-drive.d.ts.map +1 -0
  947. package/dist/lifeops/service-mixin-drive.js +213 -0
  948. package/dist/lifeops/service-mixin-drive.js.map +1 -0
  949. package/dist/lifeops/service-mixin-email-unsubscribe.d.ts +23 -0
  950. package/dist/lifeops/service-mixin-email-unsubscribe.d.ts.map +1 -0
  951. package/dist/lifeops/service-mixin-email-unsubscribe.js +27 -0
  952. package/dist/lifeops/service-mixin-email-unsubscribe.js.map +1 -0
  953. package/dist/lifeops/service-mixin-gmail.d.ts +43 -0
  954. package/dist/lifeops/service-mixin-gmail.d.ts.map +1 -0
  955. package/dist/lifeops/service-mixin-gmail.js +727 -0
  956. package/dist/lifeops/service-mixin-gmail.js.map +1 -0
  957. package/dist/lifeops/service-mixin-goals.d.ts +22 -0
  958. package/dist/lifeops/service-mixin-goals.d.ts.map +1 -0
  959. package/dist/lifeops/service-mixin-goals.js +884 -0
  960. package/dist/lifeops/service-mixin-goals.js.map +1 -0
  961. package/dist/lifeops/service-mixin-google.d.ts +13 -0
  962. package/dist/lifeops/service-mixin-google.d.ts.map +1 -0
  963. package/dist/lifeops/service-mixin-google.js +398 -0
  964. package/dist/lifeops/service-mixin-google.js.map +1 -0
  965. package/dist/lifeops/service-mixin-health.d.ts +27 -0
  966. package/dist/lifeops/service-mixin-health.d.ts.map +1 -0
  967. package/dist/lifeops/service-mixin-health.js +670 -0
  968. package/dist/lifeops/service-mixin-health.js.map +1 -0
  969. package/dist/lifeops/service-mixin-imessage.d.ts +106 -0
  970. package/dist/lifeops/service-mixin-imessage.d.ts.map +1 -0
  971. package/dist/lifeops/service-mixin-imessage.js +303 -0
  972. package/dist/lifeops/service-mixin-imessage.js.map +1 -0
  973. package/dist/lifeops/service-mixin-inbox.d.ts +55 -0
  974. package/dist/lifeops/service-mixin-inbox.d.ts.map +1 -0
  975. package/dist/lifeops/service-mixin-inbox.js +597 -0
  976. package/dist/lifeops/service-mixin-inbox.js.map +1 -0
  977. package/dist/lifeops/service-mixin-relationships.d.ts +65 -0
  978. package/dist/lifeops/service-mixin-relationships.d.ts.map +1 -0
  979. package/dist/lifeops/service-mixin-relationships.js +150 -0
  980. package/dist/lifeops/service-mixin-relationships.js.map +1 -0
  981. package/dist/lifeops/service-mixin-reminders.d.ts +62 -0
  982. package/dist/lifeops/service-mixin-reminders.d.ts.map +1 -0
  983. package/dist/lifeops/service-mixin-reminders.js +4003 -0
  984. package/dist/lifeops/service-mixin-reminders.js.map +1 -0
  985. package/dist/lifeops/service-mixin-scheduling.d.ts +53 -0
  986. package/dist/lifeops/service-mixin-scheduling.d.ts.map +1 -0
  987. package/dist/lifeops/service-mixin-scheduling.js +405 -0
  988. package/dist/lifeops/service-mixin-scheduling.js.map +1 -0
  989. package/dist/lifeops/service-mixin-screentime.d.ts +71 -0
  990. package/dist/lifeops/service-mixin-screentime.d.ts.map +1 -0
  991. package/dist/lifeops/service-mixin-screentime.js +530 -0
  992. package/dist/lifeops/service-mixin-screentime.js.map +1 -0
  993. package/dist/lifeops/service-mixin-signal.d.ts +74 -0
  994. package/dist/lifeops/service-mixin-signal.d.ts.map +1 -0
  995. package/dist/lifeops/service-mixin-signal.js +214 -0
  996. package/dist/lifeops/service-mixin-signal.js.map +1 -0
  997. package/dist/lifeops/service-mixin-sleep.d.ts +68 -0
  998. package/dist/lifeops/service-mixin-sleep.d.ts.map +1 -0
  999. package/dist/lifeops/service-mixin-sleep.js +43 -0
  1000. package/dist/lifeops/service-mixin-sleep.js.map +1 -0
  1001. package/dist/lifeops/service-mixin-status.d.ts +31 -0
  1002. package/dist/lifeops/service-mixin-status.d.ts.map +1 -0
  1003. package/dist/lifeops/service-mixin-status.js +373 -0
  1004. package/dist/lifeops/service-mixin-status.js.map +1 -0
  1005. package/dist/lifeops/service-mixin-subscriptions.d.ts +101 -0
  1006. package/dist/lifeops/service-mixin-subscriptions.d.ts.map +1 -0
  1007. package/dist/lifeops/service-mixin-subscriptions.js +50 -0
  1008. package/dist/lifeops/service-mixin-subscriptions.js.map +1 -0
  1009. package/dist/lifeops/service-mixin-telegram.d.ts +104 -0
  1010. package/dist/lifeops/service-mixin-telegram.d.ts.map +1 -0
  1011. package/dist/lifeops/service-mixin-telegram.js +280 -0
  1012. package/dist/lifeops/service-mixin-telegram.js.map +1 -0
  1013. package/dist/lifeops/service-mixin-travel.d.ts +66 -0
  1014. package/dist/lifeops/service-mixin-travel.d.ts.map +1 -0
  1015. package/dist/lifeops/service-mixin-travel.js +275 -0
  1016. package/dist/lifeops/service-mixin-travel.js.map +1 -0
  1017. package/dist/lifeops/service-mixin-whatsapp.d.ts +96 -0
  1018. package/dist/lifeops/service-mixin-whatsapp.d.ts.map +1 -0
  1019. package/dist/lifeops/service-mixin-whatsapp.js +186 -0
  1020. package/dist/lifeops/service-mixin-whatsapp.js.map +1 -0
  1021. package/dist/lifeops/service-mixin-workflows.d.ts +15 -0
  1022. package/dist/lifeops/service-mixin-workflows.d.ts.map +1 -0
  1023. package/dist/lifeops/service-mixin-workflows.js +710 -0
  1024. package/dist/lifeops/service-mixin-workflows.js.map +1 -0
  1025. package/dist/lifeops/service-mixin-x-read.d.ts +31 -0
  1026. package/dist/lifeops/service-mixin-x-read.d.ts.map +1 -0
  1027. package/dist/lifeops/service-mixin-x-read.js +267 -0
  1028. package/dist/lifeops/service-mixin-x-read.js.map +1 -0
  1029. package/dist/lifeops/service-mixin-x.d.ts +66 -0
  1030. package/dist/lifeops/service-mixin-x.d.ts.map +1 -0
  1031. package/dist/lifeops/service-mixin-x.js +501 -0
  1032. package/dist/lifeops/service-mixin-x.js.map +1 -0
  1033. package/dist/lifeops/service-normalize-connector.d.ts +19 -0
  1034. package/dist/lifeops/service-normalize-connector.d.ts.map +1 -0
  1035. package/dist/lifeops/service-normalize-connector.js +816 -0
  1036. package/dist/lifeops/service-normalize-connector.js.map +1 -0
  1037. package/dist/lifeops/service-normalize-gmail.d.ts +11 -0
  1038. package/dist/lifeops/service-normalize-gmail.d.ts.map +1 -0
  1039. package/dist/lifeops/service-normalize-gmail.js +85 -0
  1040. package/dist/lifeops/service-normalize-gmail.js.map +1 -0
  1041. package/dist/lifeops/service-normalize-task.d.ts +9 -0
  1042. package/dist/lifeops/service-normalize-task.d.ts.map +1 -0
  1043. package/dist/lifeops/service-normalize-task.js +567 -0
  1044. package/dist/lifeops/service-normalize-task.js.map +1 -0
  1045. package/dist/lifeops/service-normalize.d.ts +9 -0
  1046. package/dist/lifeops/service-normalize.d.ts.map +1 -0
  1047. package/dist/lifeops/service-normalize.js +53 -0
  1048. package/dist/lifeops/service-normalize.js.map +1 -0
  1049. package/dist/lifeops/service-types.d.ts +75 -0
  1050. package/dist/lifeops/service-types.d.ts.map +1 -0
  1051. package/dist/lifeops/service-types.js +5 -0
  1052. package/dist/lifeops/service-types.js.map +1 -0
  1053. package/dist/lifeops/service.d.ts +482 -0
  1054. package/dist/lifeops/service.d.ts.map +1 -0
  1055. package/dist/lifeops/service.js +62 -0
  1056. package/dist/lifeops/service.js.map +1 -0
  1057. package/dist/lifeops/signal-runtime-config.d.ts +13 -0
  1058. package/dist/lifeops/signal-runtime-config.d.ts.map +1 -0
  1059. package/dist/lifeops/signal-runtime-config.js +44 -0
  1060. package/dist/lifeops/signal-runtime-config.js.map +1 -0
  1061. package/dist/lifeops/signals/bus.d.ts +78 -0
  1062. package/dist/lifeops/signals/bus.d.ts.map +1 -0
  1063. package/dist/lifeops/signals/bus.js +117 -0
  1064. package/dist/lifeops/signals/bus.js.map +1 -0
  1065. package/dist/lifeops/sql.d.ts +65 -0
  1066. package/dist/lifeops/sql.d.ts.map +1 -0
  1067. package/dist/lifeops/sql.js +182 -0
  1068. package/dist/lifeops/sql.js.map +1 -0
  1069. package/dist/lifeops/stretch-decider.d.ts +73 -0
  1070. package/dist/lifeops/stretch-decider.d.ts.map +1 -0
  1071. package/dist/lifeops/stretch-decider.js +49 -0
  1072. package/dist/lifeops/stretch-decider.js.map +1 -0
  1073. package/dist/lifeops/telemetry-mapping.d.ts +14 -0
  1074. package/dist/lifeops/telemetry-mapping.d.ts.map +1 -0
  1075. package/dist/lifeops/telemetry-mapping.js +115 -0
  1076. package/dist/lifeops/telemetry-mapping.js.map +1 -0
  1077. package/dist/lifeops/telemetry-retention.d.ts +21 -0
  1078. package/dist/lifeops/telemetry-retention.d.ts.map +1 -0
  1079. package/dist/lifeops/telemetry-retention.js +13 -0
  1080. package/dist/lifeops/telemetry-retention.js.map +1 -0
  1081. package/dist/lifeops/time/timezone.d.ts +4 -0
  1082. package/dist/lifeops/time/timezone.d.ts.map +1 -0
  1083. package/dist/lifeops/time/timezone.js +154 -0
  1084. package/dist/lifeops/time/timezone.js.map +1 -0
  1085. package/dist/lifeops/time-util.d.ts +10 -0
  1086. package/dist/lifeops/time-util.d.ts.map +1 -0
  1087. package/dist/lifeops/time-util.js +14 -0
  1088. package/dist/lifeops/time-util.js.map +1 -0
  1089. package/dist/lifeops/time.d.ts +17 -0
  1090. package/dist/lifeops/time.d.ts.map +1 -0
  1091. package/dist/lifeops/time.js +152 -0
  1092. package/dist/lifeops/time.js.map +1 -0
  1093. package/dist/lifeops/travel-booking.types.d.ts +46 -0
  1094. package/dist/lifeops/travel-booking.types.d.ts.map +1 -0
  1095. package/dist/lifeops/travel-booking.types.js +1 -0
  1096. package/dist/lifeops/travel-booking.types.js.map +1 -0
  1097. package/dist/lifeops/triggers/schedule-once.d.ts +19 -0
  1098. package/dist/lifeops/triggers/schedule-once.d.ts.map +1 -0
  1099. package/dist/lifeops/triggers/schedule-once.js +99 -0
  1100. package/dist/lifeops/triggers/schedule-once.js.map +1 -0
  1101. package/dist/lifeops/validate/coding-task-request.d.ts +18 -0
  1102. package/dist/lifeops/validate/coding-task-request.d.ts.map +1 -0
  1103. package/dist/lifeops/validate/coding-task-request.js +16 -0
  1104. package/dist/lifeops/validate/coding-task-request.js.map +1 -0
  1105. package/dist/lifeops/voice/grounded-reply.d.ts +41 -0
  1106. package/dist/lifeops/voice/grounded-reply.d.ts.map +1 -0
  1107. package/dist/lifeops/voice/grounded-reply.js +24 -0
  1108. package/dist/lifeops/voice/grounded-reply.js.map +1 -0
  1109. package/dist/lifeops/voice-affect.d.ts +79 -0
  1110. package/dist/lifeops/voice-affect.d.ts.map +1 -0
  1111. package/dist/lifeops/voice-affect.js +253 -0
  1112. package/dist/lifeops/voice-affect.js.map +1 -0
  1113. package/dist/lifeops/wave1-types.d.ts +125 -0
  1114. package/dist/lifeops/wave1-types.d.ts.map +1 -0
  1115. package/dist/lifeops/wave1-types.js +1 -0
  1116. package/dist/lifeops/wave1-types.js.map +1 -0
  1117. package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts +33 -0
  1118. package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts.map +1 -0
  1119. package/dist/lifeops/work-threads/field-evaluator-thread-ops.js +226 -0
  1120. package/dist/lifeops/work-threads/field-evaluator-thread-ops.js.map +1 -0
  1121. package/dist/lifeops/work-threads/index.d.ts +3 -0
  1122. package/dist/lifeops/work-threads/index.d.ts.map +1 -0
  1123. package/dist/lifeops/work-threads/index.js +7 -0
  1124. package/dist/lifeops/work-threads/index.js.map +1 -0
  1125. package/dist/lifeops/work-threads/store.d.ts +91 -0
  1126. package/dist/lifeops/work-threads/store.d.ts.map +1 -0
  1127. package/dist/lifeops/work-threads/store.js +245 -0
  1128. package/dist/lifeops/work-threads/store.js.map +1 -0
  1129. package/dist/lifeops/work-threads/types.d.ts +58 -0
  1130. package/dist/lifeops/work-threads/types.d.ts.map +1 -0
  1131. package/dist/lifeops/work-threads/types.js +1 -0
  1132. package/dist/lifeops/work-threads/types.js.map +1 -0
  1133. package/dist/platform/host.d.ts +16 -0
  1134. package/dist/platform/host.d.ts.map +1 -0
  1135. package/dist/platform/host.js +22 -0
  1136. package/dist/platform/host.js.map +1 -0
  1137. package/dist/platform/index.d.ts +3 -0
  1138. package/dist/platform/index.d.ts.map +1 -0
  1139. package/dist/platform/index.js +3 -0
  1140. package/dist/platform/index.js.map +1 -0
  1141. package/dist/platform/lifeops-github.d.ts +15 -0
  1142. package/dist/platform/lifeops-github.d.ts.map +1 -0
  1143. package/dist/platform/lifeops-github.js +146 -0
  1144. package/dist/platform/lifeops-github.js.map +1 -0
  1145. package/dist/plugin.d.ts +106 -0
  1146. package/dist/plugin.d.ts.map +1 -0
  1147. package/dist/plugin.js +989 -0
  1148. package/dist/plugin.js.map +1 -0
  1149. package/dist/provider.d.ts +4 -0
  1150. package/dist/provider.d.ts.map +1 -0
  1151. package/dist/provider.js +108 -0
  1152. package/dist/provider.js.map +1 -0
  1153. package/dist/providers/activity-profile.d.ts +3 -0
  1154. package/dist/providers/activity-profile.d.ts.map +1 -0
  1155. package/dist/providers/activity-profile.js +140 -0
  1156. package/dist/providers/activity-profile.js.map +1 -0
  1157. package/dist/providers/cross-channel-context.d.ts +29 -0
  1158. package/dist/providers/cross-channel-context.d.ts.map +1 -0
  1159. package/dist/providers/cross-channel-context.js +206 -0
  1160. package/dist/providers/cross-channel-context.js.map +1 -0
  1161. package/dist/providers/first-run.d.ts +22 -0
  1162. package/dist/providers/first-run.d.ts.map +1 -0
  1163. package/dist/providers/first-run.js +93 -0
  1164. package/dist/providers/first-run.js.map +1 -0
  1165. package/dist/providers/health.d.ts +2 -0
  1166. package/dist/providers/health.d.ts.map +1 -0
  1167. package/dist/providers/health.js +14 -0
  1168. package/dist/providers/health.js.map +1 -0
  1169. package/dist/providers/inbox-triage.d.ts +3 -0
  1170. package/dist/providers/inbox-triage.d.ts.map +1 -0
  1171. package/dist/providers/inbox-triage.js +134 -0
  1172. package/dist/providers/inbox-triage.js.map +1 -0
  1173. package/dist/providers/lifeops.d.ts +3 -0
  1174. package/dist/providers/lifeops.d.ts.map +1 -0
  1175. package/dist/providers/lifeops.js +548 -0
  1176. package/dist/providers/lifeops.js.map +1 -0
  1177. package/dist/providers/pending-prompts.d.ts +38 -0
  1178. package/dist/providers/pending-prompts.d.ts.map +1 -0
  1179. package/dist/providers/pending-prompts.js +81 -0
  1180. package/dist/providers/pending-prompts.js.map +1 -0
  1181. package/dist/providers/recent-task-states.d.ts +52 -0
  1182. package/dist/providers/recent-task-states.d.ts.map +1 -0
  1183. package/dist/providers/recent-task-states.js +166 -0
  1184. package/dist/providers/recent-task-states.js.map +1 -0
  1185. package/dist/providers/room-policy.d.ts +16 -0
  1186. package/dist/providers/room-policy.d.ts.map +1 -0
  1187. package/dist/providers/room-policy.js +71 -0
  1188. package/dist/providers/room-policy.js.map +1 -0
  1189. package/dist/providers/work-threads.d.ts +3 -0
  1190. package/dist/providers/work-threads.d.ts.map +1 -0
  1191. package/dist/providers/work-threads.js +97 -0
  1192. package/dist/providers/work-threads.js.map +1 -0
  1193. package/dist/public.d.ts +3 -0
  1194. package/dist/public.d.ts.map +1 -0
  1195. package/dist/public.js +17 -0
  1196. package/dist/public.js.map +1 -0
  1197. package/dist/routes/cloud-features-routes.d.ts +9 -0
  1198. package/dist/routes/cloud-features-routes.d.ts.map +1 -0
  1199. package/dist/routes/cloud-features-routes.js +164 -0
  1200. package/dist/routes/cloud-features-routes.js.map +1 -0
  1201. package/dist/routes/entities.d.ts +14 -0
  1202. package/dist/routes/entities.d.ts.map +1 -0
  1203. package/dist/routes/entities.js +203 -0
  1204. package/dist/routes/entities.js.map +1 -0
  1205. package/dist/routes/lifeops-routes.d.ts +20 -0
  1206. package/dist/routes/lifeops-routes.d.ts.map +1 -0
  1207. package/dist/routes/lifeops-routes.js +2337 -0
  1208. package/dist/routes/lifeops-routes.js.map +1 -0
  1209. package/dist/routes/plugin.d.ts +9 -0
  1210. package/dist/routes/plugin.d.ts.map +1 -0
  1211. package/dist/routes/plugin.js +568 -0
  1212. package/dist/routes/plugin.js.map +1 -0
  1213. package/dist/routes/relationships.d.ts +13 -0
  1214. package/dist/routes/relationships.d.ts.map +1 -0
  1215. package/dist/routes/relationships.js +195 -0
  1216. package/dist/routes/relationships.js.map +1 -0
  1217. package/dist/routes/scheduled-tasks.d.ts +102 -0
  1218. package/dist/routes/scheduled-tasks.d.ts.map +1 -0
  1219. package/dist/routes/scheduled-tasks.js +322 -0
  1220. package/dist/routes/scheduled-tasks.js.map +1 -0
  1221. package/dist/routes/sleep-routes.d.ts +3 -0
  1222. package/dist/routes/sleep-routes.d.ts.map +1 -0
  1223. package/dist/routes/sleep-routes.js +33 -0
  1224. package/dist/routes/sleep-routes.js.map +1 -0
  1225. package/dist/routes/travel-provider-relay-routes.d.ts +2 -0
  1226. package/dist/routes/travel-provider-relay-routes.d.ts.map +1 -0
  1227. package/dist/routes/travel-provider-relay-routes.js +7 -0
  1228. package/dist/routes/travel-provider-relay-routes.js.map +1 -0
  1229. package/dist/routes/website-blocker-routes.d.ts +6 -0
  1230. package/dist/routes/website-blocker-routes.d.ts.map +1 -0
  1231. package/dist/routes/website-blocker-routes.js +218 -0
  1232. package/dist/routes/website-blocker-routes.js.map +1 -0
  1233. package/dist/security/action-confirmation.d.ts +12 -0
  1234. package/dist/security/action-confirmation.d.ts.map +1 -0
  1235. package/dist/security/action-confirmation.js +36 -0
  1236. package/dist/security/action-confirmation.js.map +1 -0
  1237. package/dist/service.d.ts +34 -0
  1238. package/dist/service.d.ts.map +1 -0
  1239. package/dist/service.js +111 -0
  1240. package/dist/service.js.map +1 -0
  1241. package/dist/travel-time/calendar-create.d.ts +17 -0
  1242. package/dist/travel-time/calendar-create.d.ts.map +1 -0
  1243. package/dist/travel-time/calendar-create.js +28 -0
  1244. package/dist/travel-time/calendar-create.js.map +1 -0
  1245. package/dist/travel-time/service.d.ts +114 -0
  1246. package/dist/travel-time/service.d.ts.map +1 -0
  1247. package/dist/travel-time/service.js +209 -0
  1248. package/dist/travel-time/service.js.map +1 -0
  1249. package/dist/types/app-blocker-settings-card.d.ts +2 -0
  1250. package/dist/types/app-blocker-settings-card.d.ts.map +1 -0
  1251. package/dist/types/app-blocker-settings-card.js +1 -0
  1252. package/dist/types/app-blocker-settings-card.js.map +1 -0
  1253. package/dist/types/briefing.d.ts +59 -0
  1254. package/dist/types/briefing.d.ts.map +1 -0
  1255. package/dist/types/briefing.js +1 -0
  1256. package/dist/types/briefing.js.map +1 -0
  1257. package/dist/types/document-request.d.ts +41 -0
  1258. package/dist/types/document-request.d.ts.map +1 -0
  1259. package/dist/types/document-request.js +1 -0
  1260. package/dist/types/document-request.js.map +1 -0
  1261. package/dist/types/index.d.ts +5 -0
  1262. package/dist/types/index.d.ts.map +1 -0
  1263. package/dist/types/index.js +1 -0
  1264. package/dist/types/index.js.map +1 -0
  1265. package/dist/types/website-blocker-settings-card.d.ts +2 -0
  1266. package/dist/types/website-blocker-settings-card.d.ts.map +1 -0
  1267. package/dist/types/website-blocker-settings-card.js +1 -0
  1268. package/dist/types/website-blocker-settings-card.js.map +1 -0
  1269. package/dist/ui.d.ts +13 -0
  1270. package/dist/ui.d.ts.map +1 -0
  1271. package/dist/ui.js +25 -0
  1272. package/dist/ui.js.map +1 -0
  1273. package/dist/utils/format-duration.d.ts +2 -0
  1274. package/dist/utils/format-duration.d.ts.map +1 -0
  1275. package/dist/utils/format-duration.js +13 -0
  1276. package/dist/utils/format-duration.js.map +1 -0
  1277. package/dist/utils/index.d.ts +3 -0
  1278. package/dist/utils/index.d.ts.map +1 -0
  1279. package/dist/utils/index.js +3 -0
  1280. package/dist/utils/index.js.map +1 -0
  1281. package/dist/utils/lifeops-url.d.ts +3 -0
  1282. package/dist/utils/lifeops-url.d.ts.map +1 -0
  1283. package/dist/utils/lifeops-url.js +28 -0
  1284. package/dist/utils/lifeops-url.js.map +1 -0
  1285. package/dist/website-blocker/chat-integration/block-activator.d.ts +32 -0
  1286. package/dist/website-blocker/chat-integration/block-activator.d.ts.map +1 -0
  1287. package/dist/website-blocker/chat-integration/block-activator.js +30 -0
  1288. package/dist/website-blocker/chat-integration/block-activator.js.map +1 -0
  1289. package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts +7 -0
  1290. package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts.map +1 -0
  1291. package/dist/website-blocker/chat-integration/block-rule-reconciler.js +115 -0
  1292. package/dist/website-blocker/chat-integration/block-rule-reconciler.js.map +1 -0
  1293. package/dist/website-blocker/chat-integration/block-rule-schema.d.ts +39 -0
  1294. package/dist/website-blocker/chat-integration/block-rule-schema.d.ts.map +1 -0
  1295. package/dist/website-blocker/chat-integration/block-rule-schema.js +133 -0
  1296. package/dist/website-blocker/chat-integration/block-rule-schema.js.map +1 -0
  1297. package/dist/website-blocker/chat-integration/block-rule-service.d.ts +21 -0
  1298. package/dist/website-blocker/chat-integration/block-rule-service.d.ts.map +1 -0
  1299. package/dist/website-blocker/chat-integration/block-rule-service.js +230 -0
  1300. package/dist/website-blocker/chat-integration/block-rule-service.js.map +1 -0
  1301. package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts +13 -0
  1302. package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts.map +1 -0
  1303. package/dist/website-blocker/chat-integration/harsh-mode-check.js +22 -0
  1304. package/dist/website-blocker/chat-integration/harsh-mode-check.js.map +1 -0
  1305. package/dist/website-blocker/chat-integration/index.d.ts +5 -0
  1306. package/dist/website-blocker/chat-integration/index.d.ts.map +1 -0
  1307. package/dist/website-blocker/chat-integration/index.js +26 -0
  1308. package/dist/website-blocker/chat-integration/index.js.map +1 -0
  1309. package/dist/website-blocker/proactive-block-bridge.d.ts +75 -0
  1310. package/dist/website-blocker/proactive-block-bridge.d.ts.map +1 -0
  1311. package/dist/website-blocker/proactive-block-bridge.js +154 -0
  1312. package/dist/website-blocker/proactive-block-bridge.js.map +1 -0
  1313. package/dist/website-blocker/public.d.ts +12 -0
  1314. package/dist/website-blocker/public.d.ts.map +1 -0
  1315. package/dist/website-blocker/public.js +51 -0
  1316. package/dist/website-blocker/public.js.map +1 -0
  1317. package/package.json +28 -28
@@ -0,0 +1,311 @@
1
+ import {
2
+ createUniqueUuid,
3
+ logger,
4
+ MemoryType,
5
+ stringToUuid
6
+ } from "@elizaos/core";
7
+ import { loadLifeOpsAppState } from "../lifeops/app-state.js";
8
+ import {
9
+ BackgroundPlannerError,
10
+ planJob
11
+ } from "../lifeops/background-planner.js";
12
+ import { enqueueIfSensitive } from "../lifeops/background-planner-dispatch.js";
13
+ function isRelationshipsServiceLike(service) {
14
+ if (!service || typeof service !== "object") return false;
15
+ const candidate = service;
16
+ return typeof candidate.searchContacts === "function" && typeof candidate.getContact === "function" && typeof candidate.updateContact === "function";
17
+ }
18
+ const FOLLOWUP_TRACKER_TASK_NAME = "FOLLOWUP_TRACKER_RECONCILE";
19
+ const FOLLOWUP_TRACKER_TASK_TAGS = [
20
+ "queue",
21
+ "repeat",
22
+ "relationships",
23
+ "followup-tracker"
24
+ ];
25
+ const FOLLOWUP_TRACKER_INTERVAL_MS = 60 * 60 * 1e3;
26
+ const FOLLOWUP_DEFAULT_THRESHOLD_DAYS = 30;
27
+ const FOLLOWUP_MEMORY_TABLE = "reminders";
28
+ const DAY_MS = 24 * 60 * 60 * 1e3;
29
+ function isRecord(value) {
30
+ return Boolean(value) && typeof value === "object" && !Array.isArray(value);
31
+ }
32
+ function resolveTrackerNowMs(options = {}) {
33
+ const raw = options.now;
34
+ if (raw instanceof Date) {
35
+ return raw.getTime();
36
+ }
37
+ if (typeof raw === "number" && Number.isFinite(raw)) {
38
+ return raw;
39
+ }
40
+ if (typeof raw === "string" && raw.trim().length > 0) {
41
+ const parsed = new Date(raw).getTime();
42
+ if (Number.isFinite(parsed)) {
43
+ return parsed;
44
+ }
45
+ }
46
+ return Date.now();
47
+ }
48
+ function isFollowupTrackerTask(task) {
49
+ return task.name === FOLLOWUP_TRACKER_TASK_NAME;
50
+ }
51
+ function buildFollowupTrackerMetadata(previous) {
52
+ const metadata = {
53
+ ...isRecord(previous) ? previous : {},
54
+ updateInterval: FOLLOWUP_TRACKER_INTERVAL_MS
55
+ };
56
+ return metadata;
57
+ }
58
+ function getRelationshipsServiceLike(runtime) {
59
+ const service = runtime.getService("relationships");
60
+ if (!service) return null;
61
+ return isRelationshipsServiceLike(service) ? service : null;
62
+ }
63
+ let degradedLogged = false;
64
+ function getNumberField(contact, key) {
65
+ const value = contact.customFields[key];
66
+ if (typeof value === "number" && Number.isFinite(value)) return value;
67
+ if (typeof value === "string" && value.trim().length > 0) {
68
+ const parsed = Number(value);
69
+ if (Number.isFinite(parsed)) return parsed;
70
+ }
71
+ return null;
72
+ }
73
+ function getStringField(contact, key) {
74
+ const value = contact.customFields[key];
75
+ return typeof value === "string" && value.trim().length > 0 ? value : null;
76
+ }
77
+ function resolveLastContactedAtMs(contact) {
78
+ const raw = getStringField(contact, "lastContactedAt") ?? getStringField(contact, "lastInteractionAt");
79
+ if (!raw) return null;
80
+ const ms = new Date(raw).getTime();
81
+ return Number.isFinite(ms) ? ms : null;
82
+ }
83
+ function resolveThresholdDays(contact, defaultDays) {
84
+ const days = getNumberField(contact, "followupThresholdDays");
85
+ if (days !== null && days > 0) return days;
86
+ return defaultDays;
87
+ }
88
+ async function resolveDisplayName(runtime, contact) {
89
+ const explicit = getStringField(contact, "displayName");
90
+ if (explicit) return explicit;
91
+ const entity = await runtime.getEntityById(contact.entityId);
92
+ return entity?.names?.[0] ?? String(contact.entityId);
93
+ }
94
+ async function computeOverdueFollowups(runtime, now = Date.now(), defaultThresholdDays = FOLLOWUP_DEFAULT_THRESHOLD_DAYS) {
95
+ const service = getRelationshipsServiceLike(runtime);
96
+ if (!service) {
97
+ if (!degradedLogged) {
98
+ degradedLogged = true;
99
+ logger.info(
100
+ "[FollowupTracker] RelationshipsService unavailable; follow-up tracking is disabled until contacts exist"
101
+ );
102
+ }
103
+ return {
104
+ generatedAt: new Date(now).toISOString(),
105
+ thresholdDefaultDays: defaultThresholdDays,
106
+ overdue: []
107
+ };
108
+ }
109
+ const contacts = await service.searchContacts({});
110
+ const overdue = [];
111
+ for (const contact of contacts) {
112
+ const lastMs = resolveLastContactedAtMs(contact);
113
+ if (lastMs === null) continue;
114
+ const thresholdDays = resolveThresholdDays(contact, defaultThresholdDays);
115
+ const thresholdMs = thresholdDays * DAY_MS;
116
+ const ageMs = now - lastMs;
117
+ if (ageMs <= thresholdMs) continue;
118
+ const displayName = await resolveDisplayName(runtime, contact);
119
+ overdue.push({
120
+ entityId: contact.entityId,
121
+ displayName,
122
+ lastContactedAt: new Date(lastMs).toISOString(),
123
+ daysOverdue: Math.floor((ageMs - thresholdMs) / DAY_MS),
124
+ thresholdDays
125
+ });
126
+ }
127
+ overdue.sort((a, b) => b.daysOverdue - a.daysOverdue);
128
+ return {
129
+ generatedAt: new Date(now).toISOString(),
130
+ thresholdDefaultDays: defaultThresholdDays,
131
+ overdue
132
+ };
133
+ }
134
+ function followupDigestRoomId(agentId) {
135
+ return stringToUuid(`followup-tracker-${agentId}`);
136
+ }
137
+ function followupDigestWorldId(agentId) {
138
+ return stringToUuid(`followup-tracker-world-${agentId}`);
139
+ }
140
+ async function writeOverdueDigestMemory(runtime, digest) {
141
+ const worldId = followupDigestWorldId(runtime.agentId);
142
+ const roomId = followupDigestRoomId(runtime.agentId);
143
+ if (typeof runtime.ensureWorldExists === "function") {
144
+ await runtime.ensureWorldExists({
145
+ id: worldId,
146
+ name: "Follow-up Tracker",
147
+ agentId: runtime.agentId
148
+ });
149
+ }
150
+ if (typeof runtime.ensureRoomExists === "function") {
151
+ await runtime.ensureRoomExists({
152
+ id: roomId,
153
+ name: "Follow-up Tracker",
154
+ source: "followup-tracker",
155
+ type: "API",
156
+ channelId: `followup-tracker-${runtime.agentId}`,
157
+ worldId
158
+ });
159
+ }
160
+ const memory = {
161
+ id: createUniqueUuid(runtime, `followup-digest-${Date.now()}`),
162
+ entityId: runtime.agentId,
163
+ agentId: runtime.agentId,
164
+ roomId,
165
+ worldId,
166
+ content: {
167
+ text: digest.overdue.length === 0 ? "No overdue follow-ups." : `Overdue follow-ups (${digest.overdue.length}): ${digest.overdue.map((o) => `${o.displayName} (+${o.daysOverdue}d)`).join(", ")}`,
168
+ type: "followup_overdue_digest"
169
+ },
170
+ metadata: {
171
+ type: MemoryType.CUSTOM,
172
+ source: "followup-tracker",
173
+ generatedAt: digest.generatedAt,
174
+ thresholdDefaultDays: digest.thresholdDefaultDays,
175
+ overdue: digest.overdue.map((entry) => ({
176
+ entityId: String(entry.entityId),
177
+ displayName: entry.displayName,
178
+ lastContactedAt: entry.lastContactedAt,
179
+ daysOverdue: entry.daysOverdue,
180
+ thresholdDays: entry.thresholdDays
181
+ }))
182
+ },
183
+ createdAt: Date.now()
184
+ };
185
+ const memoryId = await runtime.createMemory(memory, FOLLOWUP_MEMORY_TABLE);
186
+ logger.info(
187
+ `[FollowupTracker] Wrote overdue digest memory ${memoryId} with ${digest.overdue.length} entries`
188
+ );
189
+ return memoryId;
190
+ }
191
+ async function reconcileFollowupsOnce(runtime, now = Date.now(), defaultThresholdDays = FOLLOWUP_DEFAULT_THRESHOLD_DAYS) {
192
+ const digest = await computeOverdueFollowups(
193
+ runtime,
194
+ now,
195
+ defaultThresholdDays
196
+ );
197
+ await writeOverdueDigestMemory(runtime, digest);
198
+ for (const entry of digest.overdue) {
199
+ const plannerContext = {
200
+ jobKind: "followup_watchdog",
201
+ subjectUserId: String(entry.entityId),
202
+ snapshot: {
203
+ entityId: String(entry.entityId),
204
+ displayName: entry.displayName,
205
+ lastContactedAt: entry.lastContactedAt,
206
+ daysOverdue: entry.daysOverdue,
207
+ thresholdDays: entry.thresholdDays,
208
+ generatedAt: digest.generatedAt
209
+ },
210
+ availableChannels: ["telegram", "imessage", "sms", "email", "internal"],
211
+ trigger: `followup_watchdog:${entry.daysOverdue}d_overdue`
212
+ };
213
+ try {
214
+ const plan = await planJob(runtime, plannerContext);
215
+ await enqueueIfSensitive(runtime, plannerContext, plan);
216
+ } catch (error) {
217
+ if (error instanceof BackgroundPlannerError) {
218
+ logger.warn(
219
+ `[FollowupTracker] background planner unavailable \u2014 ${error.message}`
220
+ );
221
+ break;
222
+ }
223
+ throw error;
224
+ }
225
+ }
226
+ return digest;
227
+ }
228
+ async function executeFollowupTrackerTick(runtime, options = {}) {
229
+ const defaultThresholdDays = typeof options.defaultThresholdDays === "number" && Number.isFinite(options.defaultThresholdDays) && options.defaultThresholdDays > 0 ? options.defaultThresholdDays : FOLLOWUP_DEFAULT_THRESHOLD_DAYS;
230
+ const digest = await reconcileFollowupsOnce(
231
+ runtime,
232
+ resolveTrackerNowMs(options),
233
+ defaultThresholdDays
234
+ );
235
+ return {
236
+ nextInterval: FOLLOWUP_TRACKER_INTERVAL_MS,
237
+ digest
238
+ };
239
+ }
240
+ async function ensureFollowupTrackerTask(runtime) {
241
+ const tasks = await runtime.getTasks({
242
+ agentIds: [runtime.agentId],
243
+ tags: [...FOLLOWUP_TRACKER_TASK_TAGS]
244
+ });
245
+ const existing = tasks.find(isFollowupTrackerTask);
246
+ const metadata = buildFollowupTrackerMetadata(
247
+ isRecord(existing?.metadata) ? existing.metadata : null
248
+ );
249
+ if (existing?.id) {
250
+ await runtime.updateTask(existing.id, {
251
+ description: "Reconcile overdue LifeOps follow-ups",
252
+ metadata
253
+ });
254
+ return existing.id;
255
+ }
256
+ const autonomy = runtime.getService("AUTONOMY");
257
+ const roomId = autonomy?.getAutonomousRoomId?.() ?? stringToUuid(`followup-tracker-room-${runtime.agentId}`);
258
+ return runtime.createTask({
259
+ name: FOLLOWUP_TRACKER_TASK_NAME,
260
+ description: "Reconcile overdue LifeOps follow-ups",
261
+ roomId,
262
+ tags: [...FOLLOWUP_TRACKER_TASK_TAGS],
263
+ metadata,
264
+ dueAt: Date.now()
265
+ });
266
+ }
267
+ function registerFollowupTrackerWorker(runtime) {
268
+ if (runtime.getTaskWorker(FOLLOWUP_TRACKER_TASK_NAME)) {
269
+ return;
270
+ }
271
+ runtime.registerTaskWorker({
272
+ name: FOLLOWUP_TRACKER_TASK_NAME,
273
+ // Skip execution when LifeOps is disabled via the UI. Cycles become
274
+ // cheap no-ops; re-enabling requires no restart.
275
+ shouldRun: async (rt) => {
276
+ try {
277
+ const state = await loadLifeOpsAppState(rt);
278
+ return state.enabled;
279
+ } catch (error) {
280
+ logger.warn(
281
+ `[followup-tracker] loadLifeOpsAppState failed; skipping follow-up tick because LifeOps toggle state is unknown: ${error instanceof Error ? error.message : String(error)}`
282
+ );
283
+ return false;
284
+ }
285
+ },
286
+ execute: (rt, options) => executeFollowupTrackerTick(rt, isRecord(options) ? options : {})
287
+ });
288
+ }
289
+ function getFollowupTrackerRoomId(runtime) {
290
+ return followupDigestRoomId(runtime.agentId);
291
+ }
292
+ function __resetFollowupTrackerForTests() {
293
+ degradedLogged = false;
294
+ }
295
+ export {
296
+ FOLLOWUP_DEFAULT_THRESHOLD_DAYS,
297
+ FOLLOWUP_MEMORY_TABLE,
298
+ FOLLOWUP_TRACKER_INTERVAL_MS,
299
+ FOLLOWUP_TRACKER_TASK_NAME,
300
+ FOLLOWUP_TRACKER_TASK_TAGS,
301
+ __resetFollowupTrackerForTests,
302
+ computeOverdueFollowups,
303
+ ensureFollowupTrackerTask,
304
+ executeFollowupTrackerTick,
305
+ getFollowupTrackerRoomId,
306
+ getRelationshipsServiceLike,
307
+ reconcileFollowupsOnce,
308
+ registerFollowupTrackerWorker,
309
+ writeOverdueDigestMemory
310
+ };
311
+ //# sourceMappingURL=followup-tracker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/followup/followup-tracker.ts"],"sourcesContent":["import type {\n IAgentRuntime,\n JsonValue,\n Memory,\n Task,\n TaskMetadata,\n UUID,\n} from \"@elizaos/core\";\nimport {\n createUniqueUuid,\n logger,\n MemoryType,\n stringToUuid,\n} from \"@elizaos/core\";\nimport { loadLifeOpsAppState } from \"../lifeops/app-state.js\";\nimport {\n type BackgroundJobContext,\n BackgroundPlannerError,\n planJob,\n} from \"../lifeops/background-planner.js\";\nimport { enqueueIfSensitive } from \"../lifeops/background-planner-dispatch.js\";\n\n/**\n * Periodically scans known contacts managed by the RelationshipsService and\n * identifies contacts whose `lastContactedAt` has exceeded the configured\n * threshold. Overdue entries are written as a single consolidated memory per\n * tick (`followup_overdue_digest`) so the morning check-in + the\n * `LIST_OVERDUE_FOLLOWUPS` action can pull from a canonical location.\n *\n * If `RelationshipsService` is not registered on the runtime, the tracker logs\n * once at info level and returns an empty digest.\n */\n\n/**\n * Structural view of the RelationshipsService shape we depend on. Kept local\n * so this module doesn't force a compile-time dependency on the core service\n * type, and so it degrades gracefully when the service isn't registered.\n */\nexport interface ContactInfo {\n entityId: UUID;\n categories: string[];\n tags: string[];\n customFields: Record<string, JsonValue>;\n}\n\nexport interface RelationshipsServiceLike {\n searchContacts(criteria: Record<string, unknown>): Promise<ContactInfo[]>;\n getContact(entityId: UUID): Promise<ContactInfo | null>;\n updateContact(\n entityId: UUID,\n updates: { customFields?: Record<string, JsonValue> },\n ): Promise<ContactInfo | null>;\n}\n\nfunction isRelationshipsServiceLike(\n service: unknown,\n): service is RelationshipsServiceLike {\n if (!service || typeof service !== \"object\") return false;\n const candidate = service as Partial<RelationshipsServiceLike>;\n return (\n typeof candidate.searchContacts === \"function\" &&\n typeof candidate.getContact === \"function\" &&\n typeof candidate.updateContact === \"function\"\n );\n}\n\nexport const FOLLOWUP_TRACKER_TASK_NAME = \"FOLLOWUP_TRACKER_RECONCILE\" as const;\nexport const FOLLOWUP_TRACKER_TASK_TAGS = [\n \"queue\",\n \"repeat\",\n \"relationships\",\n \"followup-tracker\",\n] as const;\nexport const FOLLOWUP_TRACKER_INTERVAL_MS = 60 * 60 * 1000; // 60 minutes\nexport const FOLLOWUP_DEFAULT_THRESHOLD_DAYS = 30;\nexport const FOLLOWUP_MEMORY_TABLE = \"reminders\" as const;\n\nconst DAY_MS = 24 * 60 * 60 * 1000;\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value) && typeof value === \"object\" && !Array.isArray(value);\n}\n\nfunction resolveTrackerNowMs(options: Record<string, unknown> = {}): number {\n const raw = options.now;\n if (raw instanceof Date) {\n return raw.getTime();\n }\n if (typeof raw === \"number\" && Number.isFinite(raw)) {\n return raw;\n }\n if (typeof raw === \"string\" && raw.trim().length > 0) {\n const parsed = new Date(raw).getTime();\n if (Number.isFinite(parsed)) {\n return parsed;\n }\n }\n return Date.now();\n}\n\nfunction isFollowupTrackerTask(task: Task): boolean {\n return task.name === FOLLOWUP_TRACKER_TASK_NAME;\n}\n\nfunction buildFollowupTrackerMetadata(\n previous?: TaskMetadata | null,\n): TaskMetadata {\n const metadata: TaskMetadata = {\n ...(isRecord(previous) ? previous : {}),\n updateInterval: FOLLOWUP_TRACKER_INTERVAL_MS,\n };\n return metadata;\n}\n\nexport interface OverdueFollowup {\n entityId: UUID;\n displayName: string;\n lastContactedAt: string;\n daysOverdue: number;\n thresholdDays: number;\n}\n\nexport interface OverdueDigest {\n generatedAt: string;\n thresholdDefaultDays: number;\n overdue: OverdueFollowup[];\n}\n\nexport function getRelationshipsServiceLike(\n runtime: IAgentRuntime,\n): RelationshipsServiceLike | null {\n const service = runtime.getService(\"relationships\");\n if (!service) return null;\n return isRelationshipsServiceLike(service) ? service : null;\n}\n\nlet degradedLogged = false;\n\nfunction getNumberField(contact: ContactInfo, key: string): number | null {\n const value = contact.customFields[key];\n if (typeof value === \"number\" && Number.isFinite(value)) return value;\n if (typeof value === \"string\" && value.trim().length > 0) {\n const parsed = Number(value);\n if (Number.isFinite(parsed)) return parsed;\n }\n return null;\n}\n\nfunction getStringField(contact: ContactInfo, key: string): string | null {\n const value = contact.customFields[key];\n return typeof value === \"string\" && value.trim().length > 0 ? value : null;\n}\n\nfunction resolveLastContactedAtMs(contact: ContactInfo): number | null {\n const raw =\n getStringField(contact, \"lastContactedAt\") ??\n getStringField(contact, \"lastInteractionAt\");\n if (!raw) return null;\n const ms = new Date(raw).getTime();\n return Number.isFinite(ms) ? ms : null;\n}\n\nfunction resolveThresholdDays(\n contact: ContactInfo,\n defaultDays: number,\n): number {\n const days = getNumberField(contact, \"followupThresholdDays\");\n if (days !== null && days > 0) return days;\n return defaultDays;\n}\n\nasync function resolveDisplayName(\n runtime: IAgentRuntime,\n contact: ContactInfo,\n): Promise<string> {\n const explicit = getStringField(contact, \"displayName\");\n if (explicit) return explicit;\n const entity = await runtime.getEntityById(contact.entityId);\n return entity?.names?.[0] ?? String(contact.entityId);\n}\n\n/**\n * One tick of the tracker. Pure async fn — safe to call from tests.\n */\nexport async function computeOverdueFollowups(\n runtime: IAgentRuntime,\n now: number = Date.now(),\n defaultThresholdDays: number = FOLLOWUP_DEFAULT_THRESHOLD_DAYS,\n): Promise<OverdueDigest> {\n const service = getRelationshipsServiceLike(runtime);\n if (!service) {\n if (!degradedLogged) {\n degradedLogged = true;\n logger.info(\n \"[FollowupTracker] RelationshipsService unavailable; follow-up tracking is disabled until contacts exist\",\n );\n }\n return {\n generatedAt: new Date(now).toISOString(),\n thresholdDefaultDays: defaultThresholdDays,\n overdue: [],\n };\n }\n\n const contacts = await service.searchContacts({});\n const overdue: OverdueFollowup[] = [];\n\n for (const contact of contacts) {\n const lastMs = resolveLastContactedAtMs(contact);\n if (lastMs === null) continue;\n\n const thresholdDays = resolveThresholdDays(contact, defaultThresholdDays);\n const thresholdMs = thresholdDays * DAY_MS;\n const ageMs = now - lastMs;\n if (ageMs <= thresholdMs) continue;\n\n const displayName = await resolveDisplayName(runtime, contact);\n overdue.push({\n entityId: contact.entityId,\n displayName,\n lastContactedAt: new Date(lastMs).toISOString(),\n daysOverdue: Math.floor((ageMs - thresholdMs) / DAY_MS),\n thresholdDays,\n });\n }\n\n overdue.sort((a, b) => b.daysOverdue - a.daysOverdue);\n\n return {\n generatedAt: new Date(now).toISOString(),\n thresholdDefaultDays: defaultThresholdDays,\n overdue,\n };\n}\n\nfunction followupDigestRoomId(agentId: UUID): UUID {\n return stringToUuid(`followup-tracker-${agentId}`);\n}\n\nfunction followupDigestWorldId(agentId: UUID): UUID {\n return stringToUuid(`followup-tracker-world-${agentId}`);\n}\n\n/**\n * Persist the digest as a memory so morning check-in + actions can retrieve\n * it. One memory per tick; callers querying the most recent\n * `followup_overdue_digest` memory in the followup room get the latest view.\n */\nexport async function writeOverdueDigestMemory(\n runtime: IAgentRuntime,\n digest: OverdueDigest,\n): Promise<UUID> {\n const worldId = followupDigestWorldId(runtime.agentId);\n const roomId = followupDigestRoomId(runtime.agentId);\n\n if (typeof runtime.ensureWorldExists === \"function\") {\n await runtime.ensureWorldExists({\n id: worldId,\n name: \"Follow-up Tracker\",\n agentId: runtime.agentId,\n } as Parameters<typeof runtime.ensureWorldExists>[0]);\n }\n if (typeof runtime.ensureRoomExists === \"function\") {\n await runtime.ensureRoomExists({\n id: roomId,\n name: \"Follow-up Tracker\",\n source: \"followup-tracker\",\n type: \"API\",\n channelId: `followup-tracker-${runtime.agentId}`,\n worldId,\n } as Parameters<typeof runtime.ensureRoomExists>[0]);\n }\n\n const memory: Memory = {\n id: createUniqueUuid(runtime, `followup-digest-${Date.now()}`),\n entityId: runtime.agentId,\n agentId: runtime.agentId,\n roomId,\n worldId,\n content: {\n text:\n digest.overdue.length === 0\n ? \"No overdue follow-ups.\"\n : `Overdue follow-ups (${digest.overdue.length}): ${digest.overdue\n .map((o) => `${o.displayName} (+${o.daysOverdue}d)`)\n .join(\", \")}`,\n type: \"followup_overdue_digest\",\n },\n metadata: {\n type: MemoryType.CUSTOM,\n source: \"followup-tracker\",\n generatedAt: digest.generatedAt,\n thresholdDefaultDays: digest.thresholdDefaultDays,\n overdue: digest.overdue.map((entry) => ({\n entityId: String(entry.entityId),\n displayName: entry.displayName,\n lastContactedAt: entry.lastContactedAt,\n daysOverdue: entry.daysOverdue,\n thresholdDays: entry.thresholdDays,\n })),\n },\n createdAt: Date.now(),\n };\n\n const memoryId = await runtime.createMemory(memory, FOLLOWUP_MEMORY_TABLE);\n logger.info(\n `[FollowupTracker] Wrote overdue digest memory ${memoryId} with ${digest.overdue.length} entries`,\n );\n return memoryId;\n}\n\n/**\n * One reconciler tick. Compute + persist. Returns the digest for testability.\n */\nexport async function reconcileFollowupsOnce(\n runtime: IAgentRuntime,\n now: number = Date.now(),\n defaultThresholdDays: number = FOLLOWUP_DEFAULT_THRESHOLD_DAYS,\n): Promise<OverdueDigest> {\n const digest = await computeOverdueFollowups(\n runtime,\n now,\n defaultThresholdDays,\n );\n await writeOverdueDigestMemory(runtime, digest);\n\n // Route each overdue contact through the shared LLM planner. Sensitive\n // actions are enqueued into the approval queue; the tracker never auto-sends.\n for (const entry of digest.overdue) {\n const plannerContext: BackgroundJobContext = {\n jobKind: \"followup_watchdog\",\n subjectUserId: String(entry.entityId),\n snapshot: {\n entityId: String(entry.entityId),\n displayName: entry.displayName,\n lastContactedAt: entry.lastContactedAt,\n daysOverdue: entry.daysOverdue,\n thresholdDays: entry.thresholdDays,\n generatedAt: digest.generatedAt,\n },\n availableChannels: [\"telegram\", \"imessage\", \"sms\", \"email\", \"internal\"],\n trigger: `followup_watchdog:${entry.daysOverdue}d_overdue`,\n };\n try {\n const plan = await planJob(runtime, plannerContext);\n await enqueueIfSensitive(runtime, plannerContext, plan);\n } catch (error) {\n if (error instanceof BackgroundPlannerError) {\n logger.warn(\n `[FollowupTracker] background planner unavailable — ${error.message}`,\n );\n break;\n }\n throw error;\n }\n }\n\n return digest;\n}\n\nexport async function executeFollowupTrackerTick(\n runtime: IAgentRuntime,\n options: Record<string, unknown> = {},\n): Promise<{ nextInterval: number; digest: OverdueDigest }> {\n const defaultThresholdDays =\n typeof options.defaultThresholdDays === \"number\" &&\n Number.isFinite(options.defaultThresholdDays) &&\n options.defaultThresholdDays > 0\n ? options.defaultThresholdDays\n : FOLLOWUP_DEFAULT_THRESHOLD_DAYS;\n const digest = await reconcileFollowupsOnce(\n runtime,\n resolveTrackerNowMs(options),\n defaultThresholdDays,\n );\n return {\n nextInterval: FOLLOWUP_TRACKER_INTERVAL_MS,\n digest,\n };\n}\n\ntype AutonomyServiceLike = {\n getAutonomousRoomId?: () => UUID;\n};\n\nexport async function ensureFollowupTrackerTask(\n runtime: IAgentRuntime,\n): Promise<UUID> {\n const tasks = await runtime.getTasks({\n agentIds: [runtime.agentId],\n tags: [...FOLLOWUP_TRACKER_TASK_TAGS],\n });\n const existing = tasks.find(isFollowupTrackerTask);\n const metadata = buildFollowupTrackerMetadata(\n isRecord(existing?.metadata) ? existing.metadata : null,\n );\n if (existing?.id) {\n await runtime.updateTask(existing.id, {\n description: \"Reconcile overdue LifeOps follow-ups\",\n metadata,\n });\n return existing.id;\n }\n\n const autonomy = runtime.getService(\"AUTONOMY\") as AutonomyServiceLike | null;\n const roomId =\n autonomy?.getAutonomousRoomId?.() ??\n stringToUuid(`followup-tracker-room-${runtime.agentId}`);\n\n return runtime.createTask({\n name: FOLLOWUP_TRACKER_TASK_NAME,\n description: \"Reconcile overdue LifeOps follow-ups\",\n roomId,\n tags: [...FOLLOWUP_TRACKER_TASK_TAGS],\n metadata,\n dueAt: Date.now(),\n });\n}\n\n/**\n * Register the tracker as a periodic task worker. Mirrors the\n * BlockRuleReconciler pattern so it integrates with the agent scheduler.\n */\nexport function registerFollowupTrackerWorker(runtime: IAgentRuntime): void {\n if (runtime.getTaskWorker(FOLLOWUP_TRACKER_TASK_NAME)) {\n return;\n }\n runtime.registerTaskWorker({\n name: FOLLOWUP_TRACKER_TASK_NAME,\n // Skip execution when LifeOps is disabled via the UI. Cycles become\n // cheap no-ops; re-enabling requires no restart.\n shouldRun: async (rt) => {\n try {\n const state = await loadLifeOpsAppState(rt as IAgentRuntime);\n return state.enabled;\n } catch (error) {\n logger.warn(\n `[followup-tracker] loadLifeOpsAppState failed; skipping follow-up tick because LifeOps toggle state is unknown: ${\n error instanceof Error ? error.message : String(error)\n }`,\n );\n return false;\n }\n },\n execute: (rt, options) =>\n executeFollowupTrackerTick(rt, isRecord(options) ? options : {}),\n });\n}\n\n/**\n * Resolve the room used to store follow-up tracker memories. Exposed for\n * callers (e.g. LIST_OVERDUE_FOLLOWUPS action or morning check-in) that need\n * to query the digest.\n */\nexport function getFollowupTrackerRoomId(runtime: IAgentRuntime): UUID {\n return followupDigestRoomId(runtime.agentId);\n}\n\n/**\n * Test-only: reset the one-time degraded-mode log so unit tests can observe\n * the log path repeatedly.\n */\nexport function __resetFollowupTrackerForTests(): void {\n degradedLogged = false;\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,5 @@
1
+ export { listOverdueFollowupsAction } from "./actions/listOverdueFollowups.js";
2
+ export { markFollowupDoneAction } from "./actions/markFollowupDone.js";
3
+ export { setFollowupThresholdAction } from "./actions/setFollowupThreshold.js";
4
+ export { __resetFollowupTrackerForTests, type ContactInfo, computeOverdueFollowups, ensureFollowupTrackerTask, executeFollowupTrackerTick, FOLLOWUP_DEFAULT_THRESHOLD_DAYS, FOLLOWUP_MEMORY_TABLE, FOLLOWUP_TRACKER_INTERVAL_MS, FOLLOWUP_TRACKER_TASK_NAME, FOLLOWUP_TRACKER_TASK_TAGS, getFollowupTrackerRoomId, getRelationshipsServiceLike, type OverdueDigest, type OverdueFollowup, type RelationshipsServiceLike, reconcileFollowupsOnce, registerFollowupTrackerWorker, writeOverdueDigestMemory, } from "./followup-tracker.js";
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/followup/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAC/E,OAAO,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAC;AACvE,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAC/E,OAAO,EACL,8BAA8B,EAC9B,KAAK,WAAW,EAChB,uBAAuB,EACvB,yBAAyB,EACzB,0BAA0B,EAC1B,+BAA+B,EAC/B,qBAAqB,EACrB,4BAA4B,EAC5B,0BAA0B,EAC1B,0BAA0B,EAC1B,wBAAwB,EACxB,2BAA2B,EAC3B,KAAK,aAAa,EAClB,KAAK,eAAe,EACpB,KAAK,wBAAwB,EAC7B,sBAAsB,EACtB,6BAA6B,EAC7B,wBAAwB,GACzB,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,39 @@
1
+ import { listOverdueFollowupsAction } from "./actions/listOverdueFollowups.js";
2
+ import { markFollowupDoneAction } from "./actions/markFollowupDone.js";
3
+ import { setFollowupThresholdAction } from "./actions/setFollowupThreshold.js";
4
+ import {
5
+ __resetFollowupTrackerForTests,
6
+ computeOverdueFollowups,
7
+ ensureFollowupTrackerTask,
8
+ executeFollowupTrackerTick,
9
+ FOLLOWUP_DEFAULT_THRESHOLD_DAYS,
10
+ FOLLOWUP_MEMORY_TABLE,
11
+ FOLLOWUP_TRACKER_INTERVAL_MS,
12
+ FOLLOWUP_TRACKER_TASK_NAME,
13
+ FOLLOWUP_TRACKER_TASK_TAGS,
14
+ getFollowupTrackerRoomId,
15
+ getRelationshipsServiceLike,
16
+ reconcileFollowupsOnce,
17
+ registerFollowupTrackerWorker,
18
+ writeOverdueDigestMemory
19
+ } from "./followup-tracker.js";
20
+ export {
21
+ FOLLOWUP_DEFAULT_THRESHOLD_DAYS,
22
+ FOLLOWUP_MEMORY_TABLE,
23
+ FOLLOWUP_TRACKER_INTERVAL_MS,
24
+ FOLLOWUP_TRACKER_TASK_NAME,
25
+ FOLLOWUP_TRACKER_TASK_TAGS,
26
+ __resetFollowupTrackerForTests,
27
+ computeOverdueFollowups,
28
+ ensureFollowupTrackerTask,
29
+ executeFollowupTrackerTick,
30
+ getFollowupTrackerRoomId,
31
+ getRelationshipsServiceLike,
32
+ listOverdueFollowupsAction,
33
+ markFollowupDoneAction,
34
+ reconcileFollowupsOnce,
35
+ registerFollowupTrackerWorker,
36
+ setFollowupThresholdAction,
37
+ writeOverdueDigestMemory
38
+ };
39
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/followup/index.ts"],"sourcesContent":["export { listOverdueFollowupsAction } from \"./actions/listOverdueFollowups.js\";\nexport { markFollowupDoneAction } from \"./actions/markFollowupDone.js\";\nexport { setFollowupThresholdAction } from \"./actions/setFollowupThreshold.js\";\nexport {\n __resetFollowupTrackerForTests,\n type ContactInfo,\n computeOverdueFollowups,\n ensureFollowupTrackerTask,\n executeFollowupTrackerTick,\n FOLLOWUP_DEFAULT_THRESHOLD_DAYS,\n FOLLOWUP_MEMORY_TABLE,\n FOLLOWUP_TRACKER_INTERVAL_MS,\n FOLLOWUP_TRACKER_TASK_NAME,\n FOLLOWUP_TRACKER_TASK_TAGS,\n getFollowupTrackerRoomId,\n getRelationshipsServiceLike,\n type OverdueDigest,\n type OverdueFollowup,\n type RelationshipsServiceLike,\n reconcileFollowupsOnce,\n registerFollowupTrackerWorker,\n writeOverdueDigestMemory,\n} from \"./followup-tracker.js\";\n"],"mappings":"AAAA,SAAS,kCAAkC;AAC3C,SAAS,8BAA8B;AACvC,SAAS,kCAAkC;AAC3C;AAAA,EACE;AAAA,EAEA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAIA;AAAA,EACA;AAAA,EACA;AAAA,OACK;","names":[]}
@@ -0,0 +1,2 @@
1
+ export declare function formatConnectorError(cause: unknown, fallback: string): string;
2
+ //# sourceMappingURL=connector-error.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connector-error.d.ts","sourceRoot":"","sources":["../../src/hooks/connector-error.ts"],"names":[],"mappings":"AAAA,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,CAQ7E"}
@@ -0,0 +1,13 @@
1
+ function formatConnectorError(cause, fallback) {
2
+ if (cause instanceof Error) {
3
+ const message = cause.message.trim();
4
+ if (message.length > 0) {
5
+ return message;
6
+ }
7
+ }
8
+ return fallback;
9
+ }
10
+ export {
11
+ formatConnectorError
12
+ };
13
+ //# sourceMappingURL=connector-error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/hooks/connector-error.ts"],"sourcesContent":["export function formatConnectorError(cause: unknown, fallback: string): string {\n if (cause instanceof Error) {\n const message = cause.message.trim();\n if (message.length > 0) {\n return message;\n }\n }\n return fallback;\n}\n"],"mappings":"AAAO,SAAS,qBAAqB,OAAgB,UAA0B;AAC7E,MAAI,iBAAiB,OAAO;AAC1B,UAAM,UAAU,MAAM,QAAQ,KAAK;AACnC,QAAI,QAAQ,SAAS,GAAG;AACtB,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;","names":[]}
@@ -0,0 +1,11 @@
1
+ import type { LifeOpsConnectorSide, LifeOpsDiscordConnectorStatus } from "@elizaos/shared";
2
+ export interface UseDiscordConnectorOptions {
3
+ side?: LifeOpsConnectorSide;
4
+ }
5
+ export declare function useDiscordConnector(options?: UseDiscordConnectorOptions): {
6
+ readonly status: LifeOpsDiscordConnectorStatus | null;
7
+ readonly loading: boolean;
8
+ readonly error: string | null;
9
+ readonly refresh: () => Promise<void>;
10
+ };
11
+ //# sourceMappingURL=useDiscordConnector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDiscordConnector.d.ts","sourceRoot":"","sources":["../../src/hooks/useDiscordConnector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,oBAAoB,EACpB,6BAA6B,EAC9B,MAAM,iBAAiB,CAAC;AAKzB,MAAM,WAAW,0BAA0B;IACzC,IAAI,CAAC,EAAE,oBAAoB,CAAC;CAC7B;AAID,wBAAgB,mBAAmB,CAAC,OAAO,GAAE,0BAA+B;;;;;EA6F3E"}
@@ -0,0 +1,95 @@
1
+ import { client } from "@elizaos/ui";
2
+ import { useCallback, useEffect, useRef, useState } from "react";
3
+ import { formatConnectorError } from "./connector-error.js";
4
+ const LOGIN_POLL_INTERVAL_MS = 3e3;
5
+ function useDiscordConnector(options = {}) {
6
+ const side = options.side ?? "owner";
7
+ const [status, setStatus] = useState(
8
+ null
9
+ );
10
+ const [loading, setLoading] = useState(true);
11
+ const [error, setError] = useState(null);
12
+ const pollRef = useRef(null);
13
+ const clearPoll = useCallback(() => {
14
+ if (pollRef.current) {
15
+ clearInterval(pollRef.current);
16
+ pollRef.current = null;
17
+ }
18
+ }, []);
19
+ const refresh = useCallback(async () => {
20
+ setLoading(true);
21
+ try {
22
+ const nextStatus = await client.getDiscordConnectorStatus(side);
23
+ setStatus(nextStatus);
24
+ setError(null);
25
+ } catch (cause) {
26
+ setError(
27
+ formatConnectorError(cause, "Discord connector status failed to load.")
28
+ );
29
+ } finally {
30
+ setLoading(false);
31
+ }
32
+ }, [side]);
33
+ useEffect(() => {
34
+ let cancelled = false;
35
+ void (async () => {
36
+ setLoading(true);
37
+ try {
38
+ const nextStatus = await client.getDiscordConnectorStatus(side);
39
+ if (cancelled) return;
40
+ setStatus(nextStatus);
41
+ setError(null);
42
+ } catch (cause) {
43
+ if (cancelled) return;
44
+ setError(
45
+ formatConnectorError(
46
+ cause,
47
+ "Discord connector status failed to load."
48
+ )
49
+ );
50
+ } finally {
51
+ if (!cancelled) setLoading(false);
52
+ }
53
+ })();
54
+ return () => {
55
+ cancelled = true;
56
+ };
57
+ }, [side]);
58
+ useEffect(() => () => clearPoll(), [clearPoll]);
59
+ useEffect(() => {
60
+ const shouldPoll = status?.reason === "pairing" || status?.reason === "auth_pending";
61
+ if (shouldPoll && !pollRef.current) {
62
+ pollRef.current = setInterval(() => {
63
+ void (async () => {
64
+ try {
65
+ const next = await client.getDiscordConnectorStatus(side);
66
+ setStatus(next);
67
+ if (next.reason !== "pairing" && next.reason !== "auth_pending") {
68
+ clearPoll();
69
+ }
70
+ setError(null);
71
+ } catch (cause) {
72
+ setError(
73
+ formatConnectorError(
74
+ cause,
75
+ "Discord connector status poll failed."
76
+ )
77
+ );
78
+ }
79
+ })();
80
+ }, LOGIN_POLL_INTERVAL_MS);
81
+ } else if (!shouldPoll) {
82
+ clearPoll();
83
+ }
84
+ }, [status?.reason, side, clearPoll]);
85
+ return {
86
+ status,
87
+ loading,
88
+ error,
89
+ refresh
90
+ };
91
+ }
92
+ export {
93
+ useDiscordConnector
94
+ };
95
+ //# sourceMappingURL=useDiscordConnector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/hooks/useDiscordConnector.ts"],"sourcesContent":["import type {\n LifeOpsConnectorSide,\n LifeOpsDiscordConnectorStatus,\n} from \"@elizaos/shared\";\nimport { client } from \"@elizaos/ui\";\nimport { useCallback, useEffect, useRef, useState } from \"react\";\nimport { formatConnectorError } from \"./connector-error.js\";\n\nexport interface UseDiscordConnectorOptions {\n side?: LifeOpsConnectorSide;\n}\n\nconst LOGIN_POLL_INTERVAL_MS = 3_000;\n\nexport function useDiscordConnector(options: UseDiscordConnectorOptions = {}) {\n const side = options.side ?? \"owner\";\n const [status, setStatus] = useState<LifeOpsDiscordConnectorStatus | null>(\n null,\n );\n const [loading, setLoading] = useState(true);\n const [error, setError] = useState<string | null>(null);\n const pollRef = useRef<ReturnType<typeof setInterval> | null>(null);\n\n const clearPoll = useCallback(() => {\n if (pollRef.current) {\n clearInterval(pollRef.current);\n pollRef.current = null;\n }\n }, []);\n\n const refresh = useCallback(async () => {\n setLoading(true);\n try {\n const nextStatus = await client.getDiscordConnectorStatus(side);\n setStatus(nextStatus);\n setError(null);\n } catch (cause) {\n setError(\n formatConnectorError(cause, \"Discord connector status failed to load.\"),\n );\n } finally {\n setLoading(false);\n }\n }, [side]);\n\n useEffect(() => {\n let cancelled = false;\n void (async () => {\n setLoading(true);\n try {\n const nextStatus = await client.getDiscordConnectorStatus(side);\n if (cancelled) return;\n setStatus(nextStatus);\n setError(null);\n } catch (cause) {\n if (cancelled) return;\n setError(\n formatConnectorError(\n cause,\n \"Discord connector status failed to load.\",\n ),\n );\n } finally {\n if (!cancelled) setLoading(false);\n }\n })();\n return () => {\n cancelled = true;\n };\n }, [side]);\n\n useEffect(() => () => clearPoll(), [clearPoll]);\n\n useEffect(() => {\n const shouldPoll =\n status?.reason === \"pairing\" || status?.reason === \"auth_pending\";\n if (shouldPoll && !pollRef.current) {\n pollRef.current = setInterval(() => {\n void (async () => {\n try {\n const next = await client.getDiscordConnectorStatus(side);\n setStatus(next);\n if (next.reason !== \"pairing\" && next.reason !== \"auth_pending\") {\n clearPoll();\n }\n setError(null);\n } catch (cause) {\n setError(\n formatConnectorError(\n cause,\n \"Discord connector status poll failed.\",\n ),\n );\n }\n })();\n }, LOGIN_POLL_INTERVAL_MS);\n } else if (!shouldPoll) {\n clearPoll();\n }\n }, [status?.reason, side, clearPoll]);\n\n return {\n status,\n loading,\n error,\n refresh,\n } as const;\n}\n"],"mappings":"AAIA,SAAS,cAAc;AACvB,SAAS,aAAa,WAAW,QAAQ,gBAAgB;AACzD,SAAS,4BAA4B;AAMrC,MAAM,yBAAyB;AAExB,SAAS,oBAAoB,UAAsC,CAAC,GAAG;AAC5E,QAAM,OAAO,QAAQ,QAAQ;AAC7B,QAAM,CAAC,QAAQ,SAAS,IAAI;AAAA,IAC1B;AAAA,EACF;AACA,QAAM,CAAC,SAAS,UAAU,IAAI,SAAS,IAAI;AAC3C,QAAM,CAAC,OAAO,QAAQ,IAAI,SAAwB,IAAI;AACtD,QAAM,UAAU,OAA8C,IAAI;AAElE,QAAM,YAAY,YAAY,MAAM;AAClC,QAAI,QAAQ,SAAS;AACnB,oBAAc,QAAQ,OAAO;AAC7B,cAAQ,UAAU;AAAA,IACpB;AAAA,EACF,GAAG,CAAC,CAAC;AAEL,QAAM,UAAU,YAAY,YAAY;AACtC,eAAW,IAAI;AACf,QAAI;AACF,YAAM,aAAa,MAAM,OAAO,0BAA0B,IAAI;AAC9D,gBAAU,UAAU;AACpB,eAAS,IAAI;AAAA,IACf,SAAS,OAAO;AACd;AAAA,QACE,qBAAqB,OAAO,0CAA0C;AAAA,MACxE;AAAA,IACF,UAAE;AACA,iBAAW,KAAK;AAAA,IAClB;AAAA,EACF,GAAG,CAAC,IAAI,CAAC;AAET,YAAU,MAAM;AACd,QAAI,YAAY;AAChB,UAAM,YAAY;AAChB,iBAAW,IAAI;AACf,UAAI;AACF,cAAM,aAAa,MAAM,OAAO,0BAA0B,IAAI;AAC9D,YAAI,UAAW;AACf,kBAAU,UAAU;AACpB,iBAAS,IAAI;AAAA,MACf,SAAS,OAAO;AACd,YAAI,UAAW;AACf;AAAA,UACE;AAAA,YACE;AAAA,YACA;AAAA,UACF;AAAA,QACF;AAAA,MACF,UAAE;AACA,YAAI,CAAC,UAAW,YAAW,KAAK;AAAA,MAClC;AAAA,IACF,GAAG;AACH,WAAO,MAAM;AACX,kBAAY;AAAA,IACd;AAAA,EACF,GAAG,CAAC,IAAI,CAAC;AAET,YAAU,MAAM,MAAM,UAAU,GAAG,CAAC,SAAS,CAAC;AAE9C,YAAU,MAAM;AACd,UAAM,aACJ,QAAQ,WAAW,aAAa,QAAQ,WAAW;AACrD,QAAI,cAAc,CAAC,QAAQ,SAAS;AAClC,cAAQ,UAAU,YAAY,MAAM;AAClC,cAAM,YAAY;AAChB,cAAI;AACF,kBAAM,OAAO,MAAM,OAAO,0BAA0B,IAAI;AACxD,sBAAU,IAAI;AACd,gBAAI,KAAK,WAAW,aAAa,KAAK,WAAW,gBAAgB;AAC/D,wBAAU;AAAA,YACZ;AACA,qBAAS,IAAI;AAAA,UACf,SAAS,OAAO;AACd;AAAA,cACE;AAAA,gBACE;AAAA,gBACA;AAAA,cACF;AAAA,YACF;AAAA,UACF;AAAA,QACF,GAAG;AAAA,MACL,GAAG,sBAAsB;AAAA,IAC3B,WAAW,CAAC,YAAY;AACtB,gBAAU;AAAA,IACZ;AAAA,EACF,GAAG,CAAC,QAAQ,QAAQ,MAAM,SAAS,CAAC;AAEpC,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;","names":[]}
@@ -0,0 +1,23 @@
1
+ import type { LifeOpsConnectorMode, LifeOpsConnectorSide, LifeOpsGoogleConnectorStatus } from "../contracts/index.js";
2
+ export interface UseGoogleLifeOpsConnectorOptions {
3
+ includeAccounts?: boolean;
4
+ pollIntervalMs?: number;
5
+ pollWhileDisconnected?: boolean;
6
+ side?: LifeOpsConnectorSide;
7
+ }
8
+ export declare function useGoogleLifeOpsConnector(options?: UseGoogleLifeOpsConnectorOptions): {
9
+ readonly accounts: LifeOpsGoogleConnectorStatus[];
10
+ readonly activeMode: "local" | "remote" | "cloud_managed";
11
+ readonly error: string | null;
12
+ readonly loading: boolean;
13
+ readonly modeOptions: ("local" | "remote" | "cloud_managed")[];
14
+ readonly refresh: ({ silent, mode, }?: {
15
+ silent?: boolean;
16
+ mode?: LifeOpsConnectorMode | null;
17
+ }) => Promise<void>;
18
+ readonly selectMode: (mode: LifeOpsConnectorMode) => Promise<void>;
19
+ readonly selectedMode: "local" | "remote" | "cloud_managed" | null;
20
+ readonly side: "owner" | "agent";
21
+ readonly status: LifeOpsGoogleConnectorStatus | null;
22
+ };
23
+ //# sourceMappingURL=useGoogleLifeOpsConnector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useGoogleLifeOpsConnector.d.ts","sourceRoot":"","sources":["../../src/hooks/useGoogleLifeOpsConnector.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAEV,oBAAoB,EACpB,oBAAoB,EAEpB,4BAA4B,EAC7B,MAAM,uBAAuB,CAAC;AA6e/B,MAAM,WAAW,gCAAgC;IAC/C,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,IAAI,CAAC,EAAE,oBAAoB,CAAC;CAC7B;AAED,wBAAgB,yBAAyB,CACvC,OAAO,GAAE,gCAAqC;;;;;;2CAwCzC;QACD,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,IAAI,CAAC,EAAE,oBAAoB,GAAG,IAAI,CAAC;KACpC;gCA2OY,oBAAoB;;;;EA0CpC"}