@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.
- package/dist/actions/app-block.d.ts +15 -0
- package/dist/actions/app-block.d.ts.map +1 -0
- package/dist/actions/app-block.js +349 -0
- package/dist/actions/app-block.js.map +1 -0
- package/dist/actions/autofill.d.ts +20 -0
- package/dist/actions/autofill.d.ts.map +1 -0
- package/dist/actions/autofill.js +370 -0
- package/dist/actions/autofill.js.map +1 -0
- package/dist/actions/block.d.ts +30 -0
- package/dist/actions/block.d.ts.map +1 -0
- package/dist/actions/block.js +326 -0
- package/dist/actions/block.js.map +1 -0
- package/dist/actions/book-travel.d.ts +10 -0
- package/dist/actions/book-travel.d.ts.map +1 -0
- package/dist/actions/book-travel.js +467 -0
- package/dist/actions/book-travel.js.map +1 -0
- package/dist/actions/brief.d.ts +60 -0
- package/dist/actions/brief.d.ts.map +1 -0
- package/dist/actions/brief.js +485 -0
- package/dist/actions/brief.js.map +1 -0
- package/dist/actions/calendar.d.ts +22 -0
- package/dist/actions/calendar.d.ts.map +1 -0
- package/dist/actions/calendar.js +832 -0
- package/dist/actions/calendar.js.map +1 -0
- package/dist/actions/conflict-detect.d.ts +67 -0
- package/dist/actions/conflict-detect.d.ts.map +1 -0
- package/dist/actions/conflict-detect.js +310 -0
- package/dist/actions/conflict-detect.js.map +1 -0
- package/dist/actions/connector.d.ts +5 -0
- package/dist/actions/connector.d.ts.map +1 -0
- package/dist/actions/connector.js +1354 -0
- package/dist/actions/connector.js.map +1 -0
- package/dist/actions/credentials.d.ts +14 -0
- package/dist/actions/credentials.d.ts.map +1 -0
- package/dist/actions/credentials.js +191 -0
- package/dist/actions/credentials.js.map +1 -0
- package/dist/actions/document.d.ts +36 -0
- package/dist/actions/document.d.ts.map +1 -0
- package/dist/actions/document.js +613 -0
- package/dist/actions/document.js.map +1 -0
- package/dist/actions/entity.d.ts +20 -0
- package/dist/actions/entity.d.ts.map +1 -0
- package/dist/actions/entity.js +785 -0
- package/dist/actions/entity.js.map +1 -0
- package/dist/actions/health.d.ts +4 -0
- package/dist/actions/health.d.ts.map +1 -0
- package/dist/actions/health.js +37 -0
- package/dist/actions/health.js.map +1 -0
- package/dist/actions/inbox.d.ts +12 -0
- package/dist/actions/inbox.d.ts.map +1 -0
- package/dist/actions/inbox.js +13 -0
- package/dist/actions/inbox.js.map +1 -0
- package/dist/actions/lib/calendly-handler.d.ts +3 -0
- package/dist/actions/lib/calendly-handler.d.ts.map +1 -0
- package/dist/actions/lib/calendly-handler.js +506 -0
- package/dist/actions/lib/calendly-handler.js.map +1 -0
- package/dist/actions/lib/extract-goal-plan.d.ts +69 -0
- package/dist/actions/lib/extract-goal-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-goal-plan.js +488 -0
- package/dist/actions/lib/extract-goal-plan.js.map +1 -0
- package/dist/actions/lib/extract-life-operation.d.ts +18 -0
- package/dist/actions/lib/extract-life-operation.d.ts.map +1 -0
- package/dist/actions/lib/extract-life-operation.js +318 -0
- package/dist/actions/lib/extract-life-operation.js.map +1 -0
- package/dist/actions/lib/extract-task-plan.d.ts +78 -0
- package/dist/actions/lib/extract-task-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-task-plan.js +355 -0
- package/dist/actions/lib/extract-task-plan.js.map +1 -0
- package/dist/actions/lib/extract-update-fields.d.ts +27 -0
- package/dist/actions/lib/extract-update-fields.d.ts.map +1 -0
- package/dist/actions/lib/extract-update-fields.js +172 -0
- package/dist/actions/lib/extract-update-fields.js.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts +68 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.js +315 -0
- package/dist/actions/lib/lifeops-deferred-draft.js.map +1 -0
- package/dist/actions/lib/messaging-helpers.d.ts +20 -0
- package/dist/actions/lib/messaging-helpers.d.ts.map +1 -0
- package/dist/actions/lib/messaging-helpers.js +103 -0
- package/dist/actions/lib/messaging-helpers.js.map +1 -0
- package/dist/actions/lib/owner-policy-writes.d.ts +49 -0
- package/dist/actions/lib/owner-policy-writes.d.ts.map +1 -0
- package/dist/actions/lib/owner-policy-writes.js +157 -0
- package/dist/actions/lib/owner-policy-writes.js.map +1 -0
- package/dist/actions/lib/prompt-format.d.ts +3 -0
- package/dist/actions/lib/prompt-format.d.ts.map +1 -0
- package/dist/actions/lib/prompt-format.js +42 -0
- package/dist/actions/lib/prompt-format.js.map +1 -0
- package/dist/actions/lib/scheduling-handler.d.ts +93 -0
- package/dist/actions/lib/scheduling-handler.d.ts.map +1 -0
- package/dist/actions/lib/scheduling-handler.js +868 -0
- package/dist/actions/lib/scheduling-handler.js.map +1 -0
- package/dist/actions/life.d.ts +13 -0
- package/dist/actions/life.d.ts.map +1 -0
- package/dist/actions/life.js +2524 -0
- package/dist/actions/life.js.map +1 -0
- package/dist/actions/money.d.ts +24 -0
- package/dist/actions/money.d.ts.map +1 -0
- package/dist/actions/money.js +41 -0
- package/dist/actions/money.js.map +1 -0
- package/dist/actions/owner-surfaces.d.ts +11 -0
- package/dist/actions/owner-surfaces.d.ts.map +1 -0
- package/dist/actions/owner-surfaces.js +493 -0
- package/dist/actions/owner-surfaces.js.map +1 -0
- package/dist/actions/password-manager.d.ts +10 -0
- package/dist/actions/password-manager.d.ts.map +1 -0
- package/dist/actions/password-manager.js +195 -0
- package/dist/actions/password-manager.js.map +1 -0
- package/dist/actions/payments.d.ts +10 -0
- package/dist/actions/payments.d.ts.map +1 -0
- package/dist/actions/payments.js +5 -0
- package/dist/actions/payments.js.map +1 -0
- package/dist/actions/prioritize.d.ts +49 -0
- package/dist/actions/prioritize.d.ts.map +1 -0
- package/dist/actions/prioritize.js +313 -0
- package/dist/actions/prioritize.js.map +1 -0
- package/dist/actions/remote-desktop.d.ts +13 -0
- package/dist/actions/remote-desktop.d.ts.map +1 -0
- package/dist/actions/remote-desktop.js +11 -0
- package/dist/actions/remote-desktop.js.map +1 -0
- package/dist/actions/resolve-request.d.ts +12 -0
- package/dist/actions/resolve-request.d.ts.map +1 -0
- package/dist/actions/resolve-request.js +427 -0
- package/dist/actions/resolve-request.js.map +1 -0
- package/dist/actions/schedule.d.ts +10 -0
- package/dist/actions/schedule.d.ts.map +1 -0
- package/dist/actions/schedule.js +113 -0
- package/dist/actions/schedule.js.map +1 -0
- package/dist/actions/scheduled-task.d.ts +32 -0
- package/dist/actions/scheduled-task.d.ts.map +1 -0
- package/dist/actions/scheduled-task.js +661 -0
- package/dist/actions/scheduled-task.js.map +1 -0
- package/dist/actions/screen-time.d.ts +4 -0
- package/dist/actions/screen-time.d.ts.map +1 -0
- package/dist/actions/screen-time.js +47 -0
- package/dist/actions/screen-time.js.map +1 -0
- package/dist/actions/subscriptions.d.ts +8 -0
- package/dist/actions/subscriptions.d.ts.map +1 -0
- package/dist/actions/subscriptions.js +327 -0
- package/dist/actions/subscriptions.js.map +1 -0
- package/dist/actions/voice-call.d.ts +16 -0
- package/dist/actions/voice-call.d.ts.map +1 -0
- package/dist/actions/voice-call.js +756 -0
- package/dist/actions/voice-call.js.map +1 -0
- package/dist/actions/website-block.d.ts +15 -0
- package/dist/actions/website-block.d.ts.map +1 -0
- package/dist/actions/website-block.js +719 -0
- package/dist/actions/website-block.js.map +1 -0
- package/dist/actions/work-thread.d.ts +5 -0
- package/dist/actions/work-thread.d.ts.map +1 -0
- package/dist/actions/work-thread.js +556 -0
- package/dist/actions/work-thread.js.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts +28 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.js +61 -0
- package/dist/activity-profile/activity-tracker-repo.js.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts +52 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.js +119 -0
- package/dist/activity-profile/activity-tracker-reporting.js.map +1 -0
- package/dist/activity-profile/activity-tracker-service.d.ts +36 -0
- package/dist/activity-profile/activity-tracker-service.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-service.js +187 -0
- package/dist/activity-profile/activity-tracker-service.js.map +1 -0
- package/dist/activity-profile/analyzer.d.ts +23 -0
- package/dist/activity-profile/analyzer.d.ts.map +1 -0
- package/dist/activity-profile/analyzer.js +485 -0
- package/dist/activity-profile/analyzer.js.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts +14 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.js +159 -0
- package/dist/activity-profile/presence-signal-bridge-service.js.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts +3 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.js +21 -0
- package/dist/activity-profile/proactive-inbox-digest.js.map +1 -0
- package/dist/activity-profile/proactive-planner.d.ts +150 -0
- package/dist/activity-profile/proactive-planner.d.ts.map +1 -0
- package/dist/activity-profile/proactive-planner.js +529 -0
- package/dist/activity-profile/proactive-planner.js.map +1 -0
- package/dist/activity-profile/proactive-worker.d.ts +33 -0
- package/dist/activity-profile/proactive-worker.d.ts.map +1 -0
- package/dist/activity-profile/proactive-worker.js +779 -0
- package/dist/activity-profile/proactive-worker.js.map +1 -0
- package/dist/activity-profile/profile-metadata.d.ts +10 -0
- package/dist/activity-profile/profile-metadata.d.ts.map +1 -0
- package/dist/activity-profile/profile-metadata.js +16 -0
- package/dist/activity-profile/profile-metadata.js.map +1 -0
- package/dist/activity-profile/redactor.d.ts +15 -0
- package/dist/activity-profile/redactor.d.ts.map +1 -0
- package/dist/activity-profile/redactor.js +22 -0
- package/dist/activity-profile/redactor.js.map +1 -0
- package/dist/activity-profile/service.d.ts +11 -0
- package/dist/activity-profile/service.d.ts.map +1 -0
- package/dist/activity-profile/service.js +272 -0
- package/dist/activity-profile/service.js.map +1 -0
- package/dist/activity-profile/types.d.ts +97 -0
- package/dist/activity-profile/types.d.ts.map +1 -0
- package/dist/activity-profile/types.js +36 -0
- package/dist/activity-profile/types.js.map +1 -0
- package/dist/agent-lifeops.d.ts +2 -0
- package/dist/agent-lifeops.d.ts.map +1 -0
- package/dist/agent-lifeops.js +2 -0
- package/dist/agent-lifeops.js.map +1 -0
- package/dist/api/client-lifeops.d.ts +319 -0
- package/dist/api/client-lifeops.d.ts.map +1 -0
- package/dist/api/client-lifeops.js +794 -0
- package/dist/api/client-lifeops.js.map +1 -0
- package/dist/automation-node-contributor.d.ts +2 -0
- package/dist/automation-node-contributor.d.ts.map +1 -0
- package/dist/automation-node-contributor.js +184 -0
- package/dist/automation-node-contributor.js.map +1 -0
- package/dist/client.d.ts +16 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +18 -0
- package/dist/client.js.map +1 -0
- package/dist/components/AppBlockerSettingsCard.d.ts +3 -0
- package/dist/components/AppBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/AppBlockerSettingsCard.js +538 -0
- package/dist/components/AppBlockerSettingsCard.js.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts +3 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.js +148 -0
- package/dist/components/WebsiteBlockerSettingsCard.js.map +1 -0
- package/dist/contracts/index.d.ts +2 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/index.js +2 -0
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/lifeops.d.ts +2 -0
- package/dist/contracts/lifeops.d.ts.map +1 -0
- package/dist/contracts/lifeops.js +2 -0
- package/dist/contracts/lifeops.js.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts +17 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.js +56 -0
- package/dist/default-packs/autofill-whitelist-pack.js.map +1 -0
- package/dist/default-packs/consolidation-policies.d.ts +14 -0
- package/dist/default-packs/consolidation-policies.d.ts.map +1 -0
- package/dist/default-packs/consolidation-policies.js +17 -0
- package/dist/default-packs/consolidation-policies.js.map +1 -0
- package/dist/default-packs/contract-types.d.ts +200 -0
- package/dist/default-packs/contract-types.d.ts.map +1 -0
- package/dist/default-packs/contract-types.js +1 -0
- package/dist/default-packs/contract-types.js.map +1 -0
- package/dist/default-packs/daily-rhythm.d.ts +28 -0
- package/dist/default-packs/daily-rhythm.d.ts.map +1 -0
- package/dist/default-packs/daily-rhythm.js +136 -0
- package/dist/default-packs/daily-rhythm.js.map +1 -0
- package/dist/default-packs/escalation-ladders.d.ts +18 -0
- package/dist/default-packs/escalation-ladders.d.ts.map +1 -0
- package/dist/default-packs/escalation-ladders.js +17 -0
- package/dist/default-packs/escalation-ladders.js.map +1 -0
- package/dist/default-packs/executive-assistant.d.ts +50 -0
- package/dist/default-packs/executive-assistant.d.ts.map +1 -0
- package/dist/default-packs/executive-assistant.js +745 -0
- package/dist/default-packs/executive-assistant.js.map +1 -0
- package/dist/default-packs/followup-starter.d.ts +49 -0
- package/dist/default-packs/followup-starter.d.ts.map +1 -0
- package/dist/default-packs/followup-starter.js +104 -0
- package/dist/default-packs/followup-starter.js.map +1 -0
- package/dist/default-packs/habit-starters.d.ts +37 -0
- package/dist/default-packs/habit-starters.d.ts.map +1 -0
- package/dist/default-packs/habit-starters.js +255 -0
- package/dist/default-packs/habit-starters.js.map +1 -0
- package/dist/default-packs/inbox-triage-starter.d.ts +23 -0
- package/dist/default-packs/inbox-triage-starter.d.ts.map +1 -0
- package/dist/default-packs/inbox-triage-starter.js +61 -0
- package/dist/default-packs/inbox-triage-starter.js.map +1 -0
- package/dist/default-packs/index.d.ts +54 -0
- package/dist/default-packs/index.d.ts.map +1 -0
- package/dist/default-packs/index.js +150 -0
- package/dist/default-packs/index.js.map +1 -0
- package/dist/default-packs/lint.d.ts +62 -0
- package/dist/default-packs/lint.d.ts.map +1 -0
- package/dist/default-packs/lint.js +161 -0
- package/dist/default-packs/lint.js.map +1 -0
- package/dist/default-packs/morning-brief.d.ts +44 -0
- package/dist/default-packs/morning-brief.d.ts.map +1 -0
- package/dist/default-packs/morning-brief.js +69 -0
- package/dist/default-packs/morning-brief.js.map +1 -0
- package/dist/default-packs/quiet-user-watcher.d.ts +49 -0
- package/dist/default-packs/quiet-user-watcher.d.ts.map +1 -0
- package/dist/default-packs/quiet-user-watcher.js +92 -0
- package/dist/default-packs/quiet-user-watcher.js.map +1 -0
- package/dist/default-packs/registry-types.d.ts +51 -0
- package/dist/default-packs/registry-types.d.ts.map +1 -0
- package/dist/default-packs/registry-types.js +1 -0
- package/dist/default-packs/registry-types.js.map +1 -0
- package/dist/default-packs/task-definitions.d.ts +88 -0
- package/dist/default-packs/task-definitions.d.ts.map +1 -0
- package/dist/default-packs/task-definitions.js +87 -0
- package/dist/default-packs/task-definitions.js.map +1 -0
- package/dist/events/index.d.ts +34 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +30 -0
- package/dist/events/index.js.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts +3 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.js +90 -0
- package/dist/followup/actions/listOverdueFollowups.js.map +1 -0
- package/dist/followup/actions/markFollowupDone.d.ts +3 -0
- package/dist/followup/actions/markFollowupDone.d.ts.map +1 -0
- package/dist/followup/actions/markFollowupDone.js +171 -0
- package/dist/followup/actions/markFollowupDone.js.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts +3 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.js +171 -0
- package/dist/followup/actions/setFollowupThreshold.js.map +1 -0
- package/dist/followup/followup-tracker.d.ts +83 -0
- package/dist/followup/followup-tracker.d.ts.map +1 -0
- package/dist/followup/followup-tracker.js +311 -0
- package/dist/followup/followup-tracker.js.map +1 -0
- package/dist/followup/index.d.ts +5 -0
- package/dist/followup/index.d.ts.map +1 -0
- package/dist/followup/index.js +39 -0
- package/dist/followup/index.js.map +1 -0
- package/dist/hooks/connector-error.d.ts +2 -0
- package/dist/hooks/connector-error.d.ts.map +1 -0
- package/dist/hooks/connector-error.js +13 -0
- package/dist/hooks/connector-error.js.map +1 -0
- package/dist/hooks/useDiscordConnector.d.ts +11 -0
- package/dist/hooks/useDiscordConnector.d.ts.map +1 -0
- package/dist/hooks/useDiscordConnector.js +95 -0
- package/dist/hooks/useDiscordConnector.js.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts +23 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js +630 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js.map +1 -0
- package/dist/hooks/useIMessageConnector.d.ts +10 -0
- package/dist/hooks/useIMessageConnector.d.ts.map +1 -0
- package/dist/hooks/useIMessageConnector.js +57 -0
- package/dist/hooks/useIMessageConnector.js.map +1 -0
- package/dist/hooks/useInbox.d.ts +36 -0
- package/dist/hooks/useInbox.d.ts.map +1 -0
- package/dist/hooks/useInbox.js +96 -0
- package/dist/hooks/useInbox.js.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts +2 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.js +358 -0
- package/dist/hooks/useLifeOpsActivitySignals.js.map +1 -0
- package/dist/hooks/useLifeOpsAppState.d.ts +9 -0
- package/dist/hooks/useLifeOpsAppState.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsAppState.js +79 -0
- package/dist/hooks/useLifeOpsAppState.js.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts +8 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js +60 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts +11 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.js +92 -0
- package/dist/hooks/useLifeOpsXConnector.js.map +1 -0
- package/dist/hooks/useSignalConnector.d.ts +14 -0
- package/dist/hooks/useSignalConnector.d.ts.map +1 -0
- package/dist/hooks/useSignalConnector.js +89 -0
- package/dist/hooks/useSignalConnector.js.map +1 -0
- package/dist/hooks/useTelegramConnector.d.ts +14 -0
- package/dist/hooks/useTelegramConnector.d.ts.map +1 -0
- package/dist/hooks/useTelegramConnector.js +97 -0
- package/dist/hooks/useTelegramConnector.js.map +1 -0
- package/dist/hooks/useWhatsAppConnector.d.ts +8 -0
- package/dist/hooks/useWhatsAppConnector.d.ts.map +1 -0
- package/dist/hooks/useWhatsAppConnector.js +62 -0
- package/dist/hooks/useWhatsAppConnector.js.map +1 -0
- package/dist/inbox/message-fetcher.d.ts +11 -0
- package/dist/inbox/message-fetcher.d.ts.map +1 -0
- package/dist/inbox/message-fetcher.js +13 -0
- package/dist/inbox/message-fetcher.js.map +1 -0
- package/dist/inbox/repository.d.ts +11 -0
- package/dist/inbox/repository.d.ts.map +1 -0
- package/dist/inbox/repository.js +5 -0
- package/dist/inbox/repository.js.map +1 -0
- package/dist/inbox/types.d.ts +10 -0
- package/dist/inbox/types.d.ts.map +1 -0
- package/dist/inbox/types.js +2 -0
- package/dist/inbox/types.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +188 -0
- package/dist/index.js.map +1 -0
- package/dist/lifeops/access.d.ts +29 -0
- package/dist/lifeops/access.d.ts.map +1 -0
- package/dist/lifeops/access.js +56 -0
- package/dist/lifeops/access.js.map +1 -0
- package/dist/lifeops/app-state.d.ts +22 -0
- package/dist/lifeops/app-state.d.ts.map +1 -0
- package/dist/lifeops/app-state.js +67 -0
- package/dist/lifeops/app-state.js.map +1 -0
- package/dist/lifeops/apple-reminders.d.ts +67 -0
- package/dist/lifeops/apple-reminders.d.ts.map +1 -0
- package/dist/lifeops/apple-reminders.js +396 -0
- package/dist/lifeops/apple-reminders.js.map +1 -0
- package/dist/lifeops/approval-queue.d.ts +38 -0
- package/dist/lifeops/approval-queue.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.js +575 -0
- package/dist/lifeops/approval-queue.js.map +1 -0
- package/dist/lifeops/approval-queue.types.d.ts +172 -0
- package/dist/lifeops/approval-queue.types.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.types.js +27 -0
- package/dist/lifeops/approval-queue.types.js.map +1 -0
- package/dist/lifeops/autofill-whitelist.d.ts +20 -0
- package/dist/lifeops/autofill-whitelist.d.ts.map +1 -0
- package/dist/lifeops/autofill-whitelist.js +59 -0
- package/dist/lifeops/autofill-whitelist.js.map +1 -0
- package/dist/lifeops/background-planner-dispatch.d.ts +60 -0
- package/dist/lifeops/background-planner-dispatch.d.ts.map +1 -0
- package/dist/lifeops/background-planner-dispatch.js +113 -0
- package/dist/lifeops/background-planner-dispatch.js.map +1 -0
- package/dist/lifeops/background-planner.d.ts +140 -0
- package/dist/lifeops/background-planner.d.ts.map +1 -0
- package/dist/lifeops/background-planner.js +359 -0
- package/dist/lifeops/background-planner.js.map +1 -0
- package/dist/lifeops/bill-extraction.d.ts +46 -0
- package/dist/lifeops/bill-extraction.d.ts.map +1 -0
- package/dist/lifeops/bill-extraction.js +325 -0
- package/dist/lifeops/bill-extraction.js.map +1 -0
- package/dist/lifeops/browser-constants.d.ts +4 -0
- package/dist/lifeops/browser-constants.d.ts.map +1 -0
- package/dist/lifeops/browser-constants.js +27 -0
- package/dist/lifeops/browser-constants.js.map +1 -0
- package/dist/lifeops/browser-extension-store.d.ts +61 -0
- package/dist/lifeops/browser-extension-store.d.ts.map +1 -0
- package/dist/lifeops/browser-extension-store.js +176 -0
- package/dist/lifeops/browser-extension-store.js.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts +57 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.js +308 -0
- package/dist/lifeops/browser-session-lifecycle.js.map +1 -0
- package/dist/lifeops/bulk-review.d.ts +333 -0
- package/dist/lifeops/bulk-review.d.ts.map +1 -0
- package/dist/lifeops/bulk-review.js +1120 -0
- package/dist/lifeops/bulk-review.js.map +1 -0
- package/dist/lifeops/calendar-gate.d.ts +20 -0
- package/dist/lifeops/calendar-gate.d.ts.map +1 -0
- package/dist/lifeops/calendar-gate.js +30 -0
- package/dist/lifeops/calendar-gate.js.map +1 -0
- package/dist/lifeops/channels/contract.d.ts +47 -0
- package/dist/lifeops/channels/contract.d.ts.map +1 -0
- package/dist/lifeops/channels/contract.js +1 -0
- package/dist/lifeops/channels/contract.js.map +1 -0
- package/dist/lifeops/channels/default-pack.d.ts +26 -0
- package/dist/lifeops/channels/default-pack.d.ts.map +1 -0
- package/dist/lifeops/channels/default-pack.js +243 -0
- package/dist/lifeops/channels/default-pack.js.map +1 -0
- package/dist/lifeops/channels/index.d.ts +5 -0
- package/dist/lifeops/channels/index.d.ts.map +1 -0
- package/dist/lifeops/channels/index.js +23 -0
- package/dist/lifeops/channels/index.js.map +1 -0
- package/dist/lifeops/channels/priority-posture.d.ts +36 -0
- package/dist/lifeops/channels/priority-posture.d.ts.map +1 -0
- package/dist/lifeops/channels/priority-posture.js +27 -0
- package/dist/lifeops/channels/priority-posture.js.map +1 -0
- package/dist/lifeops/channels/registry.d.ts +7 -0
- package/dist/lifeops/channels/registry.d.ts.map +1 -0
- package/dist/lifeops/channels/registry.js +49 -0
- package/dist/lifeops/channels/registry.js.map +1 -0
- package/dist/lifeops/checkin/checkin-service.d.ts +66 -0
- package/dist/lifeops/checkin/checkin-service.d.ts.map +1 -0
- package/dist/lifeops/checkin/checkin-service.js +1084 -0
- package/dist/lifeops/checkin/checkin-service.js.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts +17 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.js +26 -0
- package/dist/lifeops/checkin/schedule-resolver.js.map +1 -0
- package/dist/lifeops/checkin/types.d.ts +106 -0
- package/dist/lifeops/checkin/types.d.ts.map +1 -0
- package/dist/lifeops/checkin/types.js +1 -0
- package/dist/lifeops/checkin/types.js.map +1 -0
- package/dist/lifeops/connectors/_helpers.d.ts +51 -0
- package/dist/lifeops/connectors/_helpers.d.ts.map +1 -0
- package/dist/lifeops/connectors/_helpers.js +104 -0
- package/dist/lifeops/connectors/_helpers.js.map +1 -0
- package/dist/lifeops/connectors/calendly.d.ts +11 -0
- package/dist/lifeops/connectors/calendly.d.ts.map +1 -0
- package/dist/lifeops/connectors/calendly.js +61 -0
- package/dist/lifeops/connectors/calendly.js.map +1 -0
- package/dist/lifeops/connectors/contract.d.ts +88 -0
- package/dist/lifeops/connectors/contract.d.ts.map +1 -0
- package/dist/lifeops/connectors/contract.js +1 -0
- package/dist/lifeops/connectors/contract.js.map +1 -0
- package/dist/lifeops/connectors/default-pack.d.ts +35 -0
- package/dist/lifeops/connectors/default-pack.d.ts.map +1 -0
- package/dist/lifeops/connectors/default-pack.js +37 -0
- package/dist/lifeops/connectors/default-pack.js.map +1 -0
- package/dist/lifeops/connectors/discord.d.ts +8 -0
- package/dist/lifeops/connectors/discord.d.ts.map +1 -0
- package/dist/lifeops/connectors/discord.js +53 -0
- package/dist/lifeops/connectors/discord.js.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts +75 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.js +35 -0
- package/dist/lifeops/connectors/dispatch-policy.js.map +1 -0
- package/dist/lifeops/connectors/duffel.d.ts +11 -0
- package/dist/lifeops/connectors/duffel.d.ts.map +1 -0
- package/dist/lifeops/connectors/duffel.js +74 -0
- package/dist/lifeops/connectors/duffel.js.map +1 -0
- package/dist/lifeops/connectors/google.d.ts +27 -0
- package/dist/lifeops/connectors/google.d.ts.map +1 -0
- package/dist/lifeops/connectors/google.js +80 -0
- package/dist/lifeops/connectors/google.js.map +1 -0
- package/dist/lifeops/connectors/imessage.d.ts +11 -0
- package/dist/lifeops/connectors/imessage.d.ts.map +1 -0
- package/dist/lifeops/connectors/imessage.js +55 -0
- package/dist/lifeops/connectors/imessage.js.map +1 -0
- package/dist/lifeops/connectors/index.d.ts +5 -0
- package/dist/lifeops/connectors/index.d.ts.map +1 -0
- package/dist/lifeops/connectors/index.js +23 -0
- package/dist/lifeops/connectors/index.js.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts +54 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.js +71 -0
- package/dist/lifeops/connectors/mockoon-redirect.js.map +1 -0
- package/dist/lifeops/connectors/registry.d.ts +7 -0
- package/dist/lifeops/connectors/registry.d.ts.map +1 -0
- package/dist/lifeops/connectors/registry.js +55 -0
- package/dist/lifeops/connectors/registry.js.map +1 -0
- package/dist/lifeops/connectors/signal.d.ts +8 -0
- package/dist/lifeops/connectors/signal.d.ts.map +1 -0
- package/dist/lifeops/connectors/signal.js +60 -0
- package/dist/lifeops/connectors/signal.js.map +1 -0
- package/dist/lifeops/connectors/telegram.d.ts +12 -0
- package/dist/lifeops/connectors/telegram.d.ts.map +1 -0
- package/dist/lifeops/connectors/telegram.js +65 -0
- package/dist/lifeops/connectors/telegram.js.map +1 -0
- package/dist/lifeops/connectors/twilio.d.ts +15 -0
- package/dist/lifeops/connectors/twilio.d.ts.map +1 -0
- package/dist/lifeops/connectors/twilio.js +126 -0
- package/dist/lifeops/connectors/twilio.js.map +1 -0
- package/dist/lifeops/connectors/whatsapp.d.ts +10 -0
- package/dist/lifeops/connectors/whatsapp.d.ts.map +1 -0
- package/dist/lifeops/connectors/whatsapp.js +56 -0
- package/dist/lifeops/connectors/whatsapp.js.map +1 -0
- package/dist/lifeops/connectors/x.d.ts +8 -0
- package/dist/lifeops/connectors/x.d.ts.map +1 -0
- package/dist/lifeops/connectors/x.js +62 -0
- package/dist/lifeops/connectors/x.js.map +1 -0
- package/dist/lifeops/contact-route-policy.d.ts +27 -0
- package/dist/lifeops/contact-route-policy.d.ts.map +1 -0
- package/dist/lifeops/contact-route-policy.js +153 -0
- package/dist/lifeops/contact-route-policy.js.map +1 -0
- package/dist/lifeops/continuity-probe.d.ts +49 -0
- package/dist/lifeops/continuity-probe.d.ts.map +1 -0
- package/dist/lifeops/continuity-probe.js +161 -0
- package/dist/lifeops/continuity-probe.js.map +1 -0
- package/dist/lifeops/cross-channel-search.d.ts +108 -0
- package/dist/lifeops/cross-channel-search.d.ts.map +1 -0
- package/dist/lifeops/cross-channel-search.js +888 -0
- package/dist/lifeops/cross-channel-search.js.map +1 -0
- package/dist/lifeops/defaults.d.ts +30 -0
- package/dist/lifeops/defaults.d.ts.map +1 -0
- package/dist/lifeops/defaults.js +206 -0
- package/dist/lifeops/defaults.js.map +1 -0
- package/dist/lifeops/device-bus-service.d.ts +16 -0
- package/dist/lifeops/device-bus-service.d.ts.map +1 -0
- package/dist/lifeops/device-bus-service.js +20 -0
- package/dist/lifeops/device-bus-service.js.map +1 -0
- package/dist/lifeops/device-identity.d.ts +31 -0
- package/dist/lifeops/device-identity.d.ts.map +1 -0
- package/dist/lifeops/device-identity.js +94 -0
- package/dist/lifeops/device-identity.js.map +1 -0
- package/dist/lifeops/document-review.d.ts +264 -0
- package/dist/lifeops/document-review.d.ts.map +1 -0
- package/dist/lifeops/document-review.js +925 -0
- package/dist/lifeops/document-review.js.map +1 -0
- package/dist/lifeops/email-classifier.d.ts +9 -0
- package/dist/lifeops/email-classifier.d.ts.map +1 -0
- package/dist/lifeops/email-classifier.js +15 -0
- package/dist/lifeops/email-classifier.js.map +1 -0
- package/dist/lifeops/email-curation.d.ts +13 -0
- package/dist/lifeops/email-curation.d.ts.map +1 -0
- package/dist/lifeops/email-curation.js +2 -0
- package/dist/lifeops/email-curation.js.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts +7 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.js +1 -0
- package/dist/lifeops/email-unsubscribe-types.js.map +1 -0
- package/dist/lifeops/enforcement-windows.d.ts +34 -0
- package/dist/lifeops/enforcement-windows.d.ts.map +1 -0
- package/dist/lifeops/enforcement-windows.js +80 -0
- package/dist/lifeops/enforcement-windows.js.map +1 -0
- package/dist/lifeops/engine.d.ts +8 -0
- package/dist/lifeops/engine.d.ts.map +1 -0
- package/dist/lifeops/engine.js +540 -0
- package/dist/lifeops/engine.js.map +1 -0
- package/dist/lifeops/entities/index.d.ts +4 -0
- package/dist/lifeops/entities/index.d.ts.map +1 -0
- package/dist/lifeops/entities/index.js +29 -0
- package/dist/lifeops/entities/index.js.map +1 -0
- package/dist/lifeops/entities/merge.d.ts +9 -0
- package/dist/lifeops/entities/merge.d.ts.map +1 -0
- package/dist/lifeops/entities/merge.js +17 -0
- package/dist/lifeops/entities/merge.js.map +1 -0
- package/dist/lifeops/entities/store.d.ts +13 -0
- package/dist/lifeops/entities/store.d.ts.map +1 -0
- package/dist/lifeops/entities/store.js +7 -0
- package/dist/lifeops/entities/store.js.map +1 -0
- package/dist/lifeops/entities/types.d.ts +9 -0
- package/dist/lifeops/entities/types.d.ts.map +1 -0
- package/dist/lifeops/entities/types.js +13 -0
- package/dist/lifeops/entities/types.js.map +1 -0
- package/dist/lifeops/entities/voice-attribution.d.ts +70 -0
- package/dist/lifeops/entities/voice-attribution.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-attribution.js +121 -0
- package/dist/lifeops/entities/voice-attribution.js.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts +32 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.js +68 -0
- package/dist/lifeops/entities/voice-observer-bridge.js.map +1 -0
- package/dist/lifeops/entities/voice-observer.d.ts +72 -0
- package/dist/lifeops/entities/voice-observer.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer.js +97 -0
- package/dist/lifeops/entities/voice-observer.js.map +1 -0
- package/dist/lifeops/escalation-ladders.d.ts +28 -0
- package/dist/lifeops/escalation-ladders.d.ts.map +1 -0
- package/dist/lifeops/escalation-ladders.js +17 -0
- package/dist/lifeops/escalation-ladders.js.map +1 -0
- package/dist/lifeops/fda-probe.d.ts +23 -0
- package/dist/lifeops/fda-probe.d.ts.map +1 -0
- package/dist/lifeops/fda-probe.js +59 -0
- package/dist/lifeops/fda-probe.js.map +1 -0
- package/dist/lifeops/feature-flags.d.ts +24 -0
- package/dist/lifeops/feature-flags.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.js +261 -0
- package/dist/lifeops/feature-flags.js.map +1 -0
- package/dist/lifeops/feature-flags.types.d.ts +156 -0
- package/dist/lifeops/feature-flags.types.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.types.js +129 -0
- package/dist/lifeops/feature-flags.types.js.map +1 -0
- package/dist/lifeops/first-run/defaults.d.ts +57 -0
- package/dist/lifeops/first-run/defaults.d.ts.map +1 -0
- package/dist/lifeops/first-run/defaults.js +159 -0
- package/dist/lifeops/first-run/defaults.js.map +1 -0
- package/dist/lifeops/first-run/questions.d.ts +74 -0
- package/dist/lifeops/first-run/questions.d.ts.map +1 -0
- package/dist/lifeops/first-run/questions.js +184 -0
- package/dist/lifeops/first-run/questions.js.map +1 -0
- package/dist/lifeops/first-run/replay.d.ts +41 -0
- package/dist/lifeops/first-run/replay.d.ts.map +1 -0
- package/dist/lifeops/first-run/replay.js +34 -0
- package/dist/lifeops/first-run/replay.js.map +1 -0
- package/dist/lifeops/first-run/service.d.ts +147 -0
- package/dist/lifeops/first-run/service.d.ts.map +1 -0
- package/dist/lifeops/first-run/service.js +455 -0
- package/dist/lifeops/first-run/service.js.map +1 -0
- package/dist/lifeops/first-run/state.d.ts +36 -0
- package/dist/lifeops/first-run/state.d.ts.map +1 -0
- package/dist/lifeops/first-run/state.js +128 -0
- package/dist/lifeops/first-run/state.js.map +1 -0
- package/dist/lifeops/global-pause/store.d.ts +22 -0
- package/dist/lifeops/global-pause/store.d.ts.map +1 -0
- package/dist/lifeops/global-pause/store.js +18 -0
- package/dist/lifeops/global-pause/store.js.map +1 -0
- package/dist/lifeops/goal-grounding.d.ts +9 -0
- package/dist/lifeops/goal-grounding.d.ts.map +1 -0
- package/dist/lifeops/goal-grounding.js +19 -0
- package/dist/lifeops/goal-grounding.js.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts +8 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.js +7 -0
- package/dist/lifeops/goal-semantic-evaluator.js.map +1 -0
- package/dist/lifeops/google/format-helpers.d.ts +63 -0
- package/dist/lifeops/google/format-helpers.d.ts.map +1 -0
- package/dist/lifeops/google/format-helpers.js +597 -0
- package/dist/lifeops/google/format-helpers.js.map +1 -0
- package/dist/lifeops/google-plugin-delegates.d.ts +59 -0
- package/dist/lifeops/google-plugin-delegates.d.ts.map +1 -0
- package/dist/lifeops/google-plugin-delegates.js +408 -0
- package/dist/lifeops/google-plugin-delegates.js.map +1 -0
- package/dist/lifeops/google-scopes.d.ts +15 -0
- package/dist/lifeops/google-scopes.d.ts.map +1 -0
- package/dist/lifeops/google-scopes.js +118 -0
- package/dist/lifeops/google-scopes.js.map +1 -0
- package/dist/lifeops/handoff/store.d.ts +23 -0
- package/dist/lifeops/handoff/store.d.ts.map +1 -0
- package/dist/lifeops/handoff/store.js +20 -0
- package/dist/lifeops/handoff/store.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts +16 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.js +33 -0
- package/dist/lifeops/i18n/localized-examples-provider.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts +32 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js +28 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts +64 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.js +283 -0
- package/dist/lifeops/i18n/prompt-registry.js.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts +7 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.js +81 -0
- package/dist/lifeops/imessage-outbound-probe.js.map +1 -0
- package/dist/lifeops/index.d.ts +24 -0
- package/dist/lifeops/index.d.ts.map +1 -0
- package/dist/lifeops/index.js +24 -0
- package/dist/lifeops/index.js.map +1 -0
- package/dist/lifeops/intent-sync.d.ts +64 -0
- package/dist/lifeops/intent-sync.d.ts.map +1 -0
- package/dist/lifeops/intent-sync.js +321 -0
- package/dist/lifeops/intent-sync.js.map +1 -0
- package/dist/lifeops/messaging/index.d.ts +2 -0
- package/dist/lifeops/messaging/index.d.ts.map +1 -0
- package/dist/lifeops/messaging/index.js +5 -0
- package/dist/lifeops/messaging/index.js.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts +3 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.js +83 -0
- package/dist/lifeops/messaging/owner-send-policy.js.map +1 -0
- package/dist/lifeops/notifications-push.d.ts +37 -0
- package/dist/lifeops/notifications-push.d.ts.map +1 -0
- package/dist/lifeops/notifications-push.js +95 -0
- package/dist/lifeops/notifications-push.js.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts +5 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.js +48 -0
- package/dist/lifeops/optimized-prompt-instructions.js.map +1 -0
- package/dist/lifeops/owner/fact-store.d.ts +143 -0
- package/dist/lifeops/owner/fact-store.d.ts.map +1 -0
- package/dist/lifeops/owner/fact-store.js +446 -0
- package/dist/lifeops/owner/fact-store.js.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts +3 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js +241 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js.map +1 -0
- package/dist/lifeops/owner-profile.d.ts +61 -0
- package/dist/lifeops/owner-profile.d.ts.map +1 -0
- package/dist/lifeops/owner-profile.js +407 -0
- package/dist/lifeops/owner-profile.js.map +1 -0
- package/dist/lifeops/pending-prompts/store.d.ts +23 -0
- package/dist/lifeops/pending-prompts/store.d.ts.map +1 -0
- package/dist/lifeops/pending-prompts/store.js +16 -0
- package/dist/lifeops/pending-prompts/store.js.map +1 -0
- package/dist/lifeops/policy-memory.d.ts +190 -0
- package/dist/lifeops/policy-memory.d.ts.map +1 -0
- package/dist/lifeops/policy-memory.js +1026 -0
- package/dist/lifeops/policy-memory.js.map +1 -0
- package/dist/lifeops/priority-scoring.d.ts +51 -0
- package/dist/lifeops/priority-scoring.d.ts.map +1 -0
- package/dist/lifeops/priority-scoring.js +305 -0
- package/dist/lifeops/priority-scoring.js.map +1 -0
- package/dist/lifeops/privacy-egress.d.ts +92 -0
- package/dist/lifeops/privacy-egress.d.ts.map +1 -0
- package/dist/lifeops/privacy-egress.js +230 -0
- package/dist/lifeops/privacy-egress.js.map +1 -0
- package/dist/lifeops/privacy.d.ts +49 -0
- package/dist/lifeops/privacy.d.ts.map +1 -0
- package/dist/lifeops/privacy.js +66 -0
- package/dist/lifeops/privacy.js.map +1 -0
- package/dist/lifeops/redact-sensitive-data.d.ts +32 -0
- package/dist/lifeops/redact-sensitive-data.d.ts.map +1 -0
- package/dist/lifeops/redact-sensitive-data.js +98 -0
- package/dist/lifeops/redact-sensitive-data.js.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts +13 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.js +73 -0
- package/dist/lifeops/registries/app-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/blocker-registry.d.ts +76 -0
- package/dist/lifeops/registries/blocker-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/blocker-registry.js +40 -0
- package/dist/lifeops/registries/blocker-registry.js.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts +57 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.js +82 -0
- package/dist/lifeops/registries/event-kind-registry.js.map +1 -0
- package/dist/lifeops/registries/family-registry.d.ts +72 -0
- package/dist/lifeops/registries/family-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/family-registry.js +98 -0
- package/dist/lifeops/registries/family-registry.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts +32 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js +36 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts +76 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.js +68 -0
- package/dist/lifeops/registries/feature-flag-registry.js.map +1 -0
- package/dist/lifeops/registries/index.d.ts +24 -0
- package/dist/lifeops/registries/index.d.ts.map +1 -0
- package/dist/lifeops/registries/index.js +115 -0
- package/dist/lifeops/registries/index.js.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts +21 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.js +76 -0
- package/dist/lifeops/registries/website-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts +30 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js +315 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts +101 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.js +56 -0
- package/dist/lifeops/registries/workflow-step-registry.js.map +1 -0
- package/dist/lifeops/relationships/extraction.d.ts +77 -0
- package/dist/lifeops/relationships/extraction.d.ts.map +1 -0
- package/dist/lifeops/relationships/extraction.js +146 -0
- package/dist/lifeops/relationships/extraction.js.map +1 -0
- package/dist/lifeops/relationships/index.d.ts +4 -0
- package/dist/lifeops/relationships/index.d.ts.map +1 -0
- package/dist/lifeops/relationships/index.js +19 -0
- package/dist/lifeops/relationships/index.js.map +1 -0
- package/dist/lifeops/relationships/mapping.d.ts +34 -0
- package/dist/lifeops/relationships/mapping.d.ts.map +1 -0
- package/dist/lifeops/relationships/mapping.js +87 -0
- package/dist/lifeops/relationships/mapping.js.map +1 -0
- package/dist/lifeops/relationships/store.d.ts +12 -0
- package/dist/lifeops/relationships/store.d.ts.map +1 -0
- package/dist/lifeops/relationships/store.js +5 -0
- package/dist/lifeops/relationships/store.js.map +1 -0
- package/dist/lifeops/relationships/types.d.ts +9 -0
- package/dist/lifeops/relationships/types.d.ts.map +1 -0
- package/dist/lifeops/relationships/types.js +11 -0
- package/dist/lifeops/relationships/types.js.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts +13 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.js +107 -0
- package/dist/lifeops/relative-schedule-resolver.js.map +1 -0
- package/dist/lifeops/relative-time.d.ts +15 -0
- package/dist/lifeops/relative-time.d.ts.map +1 -0
- package/dist/lifeops/relative-time.js +191 -0
- package/dist/lifeops/relative-time.js.map +1 -0
- package/dist/lifeops/repository.d.ts +638 -0
- package/dist/lifeops/repository.d.ts.map +1 -0
- package/dist/lifeops/repository.js +6289 -0
- package/dist/lifeops/repository.js.map +1 -0
- package/dist/lifeops/runtime-cache.d.ts +4 -0
- package/dist/lifeops/runtime-cache.d.ts.map +1 -0
- package/dist/lifeops/runtime-cache.js +7 -0
- package/dist/lifeops/runtime-cache.js.map +1 -0
- package/dist/lifeops/runtime-service-delegates.d.ts +236 -0
- package/dist/lifeops/runtime-service-delegates.d.ts.map +1 -0
- package/dist/lifeops/runtime-service-delegates.js +839 -0
- package/dist/lifeops/runtime-service-delegates.js.map +1 -0
- package/dist/lifeops/runtime.d.ts +13 -0
- package/dist/lifeops/runtime.d.ts.map +1 -0
- package/dist/lifeops/runtime.js +104 -0
- package/dist/lifeops/runtime.js.map +1 -0
- package/dist/lifeops/schedule-insight.d.ts +133 -0
- package/dist/lifeops/schedule-insight.d.ts.map +1 -0
- package/dist/lifeops/schedule-insight.js +726 -0
- package/dist/lifeops/schedule-insight.js.map +1 -0
- package/dist/lifeops/schedule-state.d.ts +39 -0
- package/dist/lifeops/schedule-state.d.ts.map +1 -0
- package/dist/lifeops/schedule-state.js +671 -0
- package/dist/lifeops/schedule-state.js.map +1 -0
- package/dist/lifeops/schedule-sync-config.d.ts +3 -0
- package/dist/lifeops/schedule-sync-config.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-config.js +23 -0
- package/dist/lifeops/schedule-sync-config.js.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts +2 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.js +2 -0
- package/dist/lifeops/schedule-sync-contracts.js.map +1 -0
- package/dist/lifeops/scheduled-task/index.d.ts +13 -0
- package/dist/lifeops/scheduled-task/index.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/index.js +14 -0
- package/dist/lifeops/scheduled-task/index.js.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts +33 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js +334 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts +28 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.js +202 -0
- package/dist/lifeops/scheduled-task/scheduler.js.map +1 -0
- package/dist/lifeops/scheduled-task/service.d.ts +61 -0
- package/dist/lifeops/scheduled-task/service.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/service.js +64 -0
- package/dist/lifeops/scheduled-task/service.js.map +1 -0
- package/dist/lifeops/scheduler-task.d.ts +19 -0
- package/dist/lifeops/scheduler-task.d.ts.map +1 -0
- package/dist/lifeops/scheduler-task.js +201 -0
- package/dist/lifeops/scheduler-task.js.map +1 -0
- package/dist/lifeops/schema.d.ts +28068 -0
- package/dist/lifeops/schema.d.ts.map +1 -0
- package/dist/lifeops/schema.js +1689 -0
- package/dist/lifeops/schema.js.map +1 -0
- package/dist/lifeops/screen-context.d.ts +66 -0
- package/dist/lifeops/screen-context.d.ts.map +1 -0
- package/dist/lifeops/screen-context.js +347 -0
- package/dist/lifeops/screen-context.js.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts +113 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.js +142 -0
- package/dist/lifeops/seed-routine-migration/migrator.js.map +1 -0
- package/dist/lifeops/seed-routines.d.ts +24 -0
- package/dist/lifeops/seed-routines.d.ts.map +1 -0
- package/dist/lifeops/seed-routines.js +140 -0
- package/dist/lifeops/seed-routines.js.map +1 -0
- package/dist/lifeops/send-policy/contract.d.ts +81 -0
- package/dist/lifeops/send-policy/contract.d.ts.map +1 -0
- package/dist/lifeops/send-policy/contract.js +1 -0
- package/dist/lifeops/send-policy/contract.js.map +1 -0
- package/dist/lifeops/send-policy/index.d.ts +3 -0
- package/dist/lifeops/send-policy/index.d.ts.map +1 -0
- package/dist/lifeops/send-policy/index.js +13 -0
- package/dist/lifeops/send-policy/index.js.map +1 -0
- package/dist/lifeops/send-policy/registry.d.ts +7 -0
- package/dist/lifeops/send-policy/registry.d.ts.map +1 -0
- package/dist/lifeops/send-policy/registry.js +62 -0
- package/dist/lifeops/send-policy/registry.js.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts +46 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.js +103 -0
- package/dist/lifeops/sensitive-request-delivery.js.map +1 -0
- package/dist/lifeops/service-constants.d.ts +10 -0
- package/dist/lifeops/service-constants.d.ts.map +1 -0
- package/dist/lifeops/service-constants.js +129 -0
- package/dist/lifeops/service-constants.js.map +1 -0
- package/dist/lifeops/service-helpers-browser.d.ts +41 -0
- package/dist/lifeops/service-helpers-browser.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-browser.js +290 -0
- package/dist/lifeops/service-helpers-browser.js.map +1 -0
- package/dist/lifeops/service-helpers-misc.d.ts +68 -0
- package/dist/lifeops/service-helpers-misc.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-misc.js +531 -0
- package/dist/lifeops/service-helpers-misc.js.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts +23 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.js +257 -0
- package/dist/lifeops/service-helpers-occurrence.js.map +1 -0
- package/dist/lifeops/service-helpers-reminder.d.ts +260 -0
- package/dist/lifeops/service-helpers-reminder.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-reminder.js +1186 -0
- package/dist/lifeops/service-helpers-reminder.js.map +1 -0
- package/dist/lifeops/service-mixin-browser.d.ts +31 -0
- package/dist/lifeops/service-mixin-browser.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-browser.js +975 -0
- package/dist/lifeops/service-mixin-browser.js.map +1 -0
- package/dist/lifeops/service-mixin-calendar.d.ts +53 -0
- package/dist/lifeops/service-mixin-calendar.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-calendar.js +68 -0
- package/dist/lifeops/service-mixin-calendar.js.map +1 -0
- package/dist/lifeops/service-mixin-core.d.ts +51 -0
- package/dist/lifeops/service-mixin-core.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-core.js +500 -0
- package/dist/lifeops/service-mixin-core.js.map +1 -0
- package/dist/lifeops/service-mixin-definitions.d.ts +14 -0
- package/dist/lifeops/service-mixin-definitions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-definitions.js +470 -0
- package/dist/lifeops/service-mixin-definitions.js.map +1 -0
- package/dist/lifeops/service-mixin-discord.d.ts +49 -0
- package/dist/lifeops/service-mixin-discord.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-discord.js +1253 -0
- package/dist/lifeops/service-mixin-discord.js.map +1 -0
- package/dist/lifeops/service-mixin-drive.d.ts +96 -0
- package/dist/lifeops/service-mixin-drive.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-drive.js +213 -0
- package/dist/lifeops/service-mixin-drive.js.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts +23 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js +27 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js.map +1 -0
- package/dist/lifeops/service-mixin-gmail.d.ts +43 -0
- package/dist/lifeops/service-mixin-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-gmail.js +727 -0
- package/dist/lifeops/service-mixin-gmail.js.map +1 -0
- package/dist/lifeops/service-mixin-goals.d.ts +22 -0
- package/dist/lifeops/service-mixin-goals.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-goals.js +884 -0
- package/dist/lifeops/service-mixin-goals.js.map +1 -0
- package/dist/lifeops/service-mixin-google.d.ts +13 -0
- package/dist/lifeops/service-mixin-google.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-google.js +398 -0
- package/dist/lifeops/service-mixin-google.js.map +1 -0
- package/dist/lifeops/service-mixin-health.d.ts +27 -0
- package/dist/lifeops/service-mixin-health.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-health.js +670 -0
- package/dist/lifeops/service-mixin-health.js.map +1 -0
- package/dist/lifeops/service-mixin-imessage.d.ts +106 -0
- package/dist/lifeops/service-mixin-imessage.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-imessage.js +303 -0
- package/dist/lifeops/service-mixin-imessage.js.map +1 -0
- package/dist/lifeops/service-mixin-inbox.d.ts +55 -0
- package/dist/lifeops/service-mixin-inbox.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-inbox.js +597 -0
- package/dist/lifeops/service-mixin-inbox.js.map +1 -0
- package/dist/lifeops/service-mixin-relationships.d.ts +65 -0
- package/dist/lifeops/service-mixin-relationships.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-relationships.js +150 -0
- package/dist/lifeops/service-mixin-relationships.js.map +1 -0
- package/dist/lifeops/service-mixin-reminders.d.ts +62 -0
- package/dist/lifeops/service-mixin-reminders.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-reminders.js +4003 -0
- package/dist/lifeops/service-mixin-reminders.js.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts +53 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.js +405 -0
- package/dist/lifeops/service-mixin-scheduling.js.map +1 -0
- package/dist/lifeops/service-mixin-screentime.d.ts +71 -0
- package/dist/lifeops/service-mixin-screentime.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-screentime.js +530 -0
- package/dist/lifeops/service-mixin-screentime.js.map +1 -0
- package/dist/lifeops/service-mixin-signal.d.ts +74 -0
- package/dist/lifeops/service-mixin-signal.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-signal.js +214 -0
- package/dist/lifeops/service-mixin-signal.js.map +1 -0
- package/dist/lifeops/service-mixin-sleep.d.ts +68 -0
- package/dist/lifeops/service-mixin-sleep.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-sleep.js +43 -0
- package/dist/lifeops/service-mixin-sleep.js.map +1 -0
- package/dist/lifeops/service-mixin-status.d.ts +31 -0
- package/dist/lifeops/service-mixin-status.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-status.js +373 -0
- package/dist/lifeops/service-mixin-status.js.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts +101 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.js +50 -0
- package/dist/lifeops/service-mixin-subscriptions.js.map +1 -0
- package/dist/lifeops/service-mixin-telegram.d.ts +104 -0
- package/dist/lifeops/service-mixin-telegram.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-telegram.js +280 -0
- package/dist/lifeops/service-mixin-telegram.js.map +1 -0
- package/dist/lifeops/service-mixin-travel.d.ts +66 -0
- package/dist/lifeops/service-mixin-travel.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-travel.js +275 -0
- package/dist/lifeops/service-mixin-travel.js.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts +96 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.js +186 -0
- package/dist/lifeops/service-mixin-whatsapp.js.map +1 -0
- package/dist/lifeops/service-mixin-workflows.d.ts +15 -0
- package/dist/lifeops/service-mixin-workflows.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-workflows.js +710 -0
- package/dist/lifeops/service-mixin-workflows.js.map +1 -0
- package/dist/lifeops/service-mixin-x-read.d.ts +31 -0
- package/dist/lifeops/service-mixin-x-read.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x-read.js +267 -0
- package/dist/lifeops/service-mixin-x-read.js.map +1 -0
- package/dist/lifeops/service-mixin-x.d.ts +66 -0
- package/dist/lifeops/service-mixin-x.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x.js +501 -0
- package/dist/lifeops/service-mixin-x.js.map +1 -0
- package/dist/lifeops/service-normalize-connector.d.ts +19 -0
- package/dist/lifeops/service-normalize-connector.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-connector.js +816 -0
- package/dist/lifeops/service-normalize-connector.js.map +1 -0
- package/dist/lifeops/service-normalize-gmail.d.ts +11 -0
- package/dist/lifeops/service-normalize-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-gmail.js +85 -0
- package/dist/lifeops/service-normalize-gmail.js.map +1 -0
- package/dist/lifeops/service-normalize-task.d.ts +9 -0
- package/dist/lifeops/service-normalize-task.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-task.js +567 -0
- package/dist/lifeops/service-normalize-task.js.map +1 -0
- package/dist/lifeops/service-normalize.d.ts +9 -0
- package/dist/lifeops/service-normalize.d.ts.map +1 -0
- package/dist/lifeops/service-normalize.js +53 -0
- package/dist/lifeops/service-normalize.js.map +1 -0
- package/dist/lifeops/service-types.d.ts +75 -0
- package/dist/lifeops/service-types.d.ts.map +1 -0
- package/dist/lifeops/service-types.js +5 -0
- package/dist/lifeops/service-types.js.map +1 -0
- package/dist/lifeops/service.d.ts +482 -0
- package/dist/lifeops/service.d.ts.map +1 -0
- package/dist/lifeops/service.js +62 -0
- package/dist/lifeops/service.js.map +1 -0
- package/dist/lifeops/signal-runtime-config.d.ts +13 -0
- package/dist/lifeops/signal-runtime-config.d.ts.map +1 -0
- package/dist/lifeops/signal-runtime-config.js +44 -0
- package/dist/lifeops/signal-runtime-config.js.map +1 -0
- package/dist/lifeops/signals/bus.d.ts +78 -0
- package/dist/lifeops/signals/bus.d.ts.map +1 -0
- package/dist/lifeops/signals/bus.js +117 -0
- package/dist/lifeops/signals/bus.js.map +1 -0
- package/dist/lifeops/sql.d.ts +65 -0
- package/dist/lifeops/sql.d.ts.map +1 -0
- package/dist/lifeops/sql.js +182 -0
- package/dist/lifeops/sql.js.map +1 -0
- package/dist/lifeops/stretch-decider.d.ts +73 -0
- package/dist/lifeops/stretch-decider.d.ts.map +1 -0
- package/dist/lifeops/stretch-decider.js +49 -0
- package/dist/lifeops/stretch-decider.js.map +1 -0
- package/dist/lifeops/telemetry-mapping.d.ts +14 -0
- package/dist/lifeops/telemetry-mapping.d.ts.map +1 -0
- package/dist/lifeops/telemetry-mapping.js +115 -0
- package/dist/lifeops/telemetry-mapping.js.map +1 -0
- package/dist/lifeops/telemetry-retention.d.ts +21 -0
- package/dist/lifeops/telemetry-retention.d.ts.map +1 -0
- package/dist/lifeops/telemetry-retention.js +13 -0
- package/dist/lifeops/telemetry-retention.js.map +1 -0
- package/dist/lifeops/time/timezone.d.ts +4 -0
- package/dist/lifeops/time/timezone.d.ts.map +1 -0
- package/dist/lifeops/time/timezone.js +154 -0
- package/dist/lifeops/time/timezone.js.map +1 -0
- package/dist/lifeops/time-util.d.ts +10 -0
- package/dist/lifeops/time-util.d.ts.map +1 -0
- package/dist/lifeops/time-util.js +14 -0
- package/dist/lifeops/time-util.js.map +1 -0
- package/dist/lifeops/time.d.ts +17 -0
- package/dist/lifeops/time.d.ts.map +1 -0
- package/dist/lifeops/time.js +152 -0
- package/dist/lifeops/time.js.map +1 -0
- package/dist/lifeops/travel-booking.types.d.ts +46 -0
- package/dist/lifeops/travel-booking.types.d.ts.map +1 -0
- package/dist/lifeops/travel-booking.types.js +1 -0
- package/dist/lifeops/travel-booking.types.js.map +1 -0
- package/dist/lifeops/triggers/schedule-once.d.ts +19 -0
- package/dist/lifeops/triggers/schedule-once.d.ts.map +1 -0
- package/dist/lifeops/triggers/schedule-once.js +99 -0
- package/dist/lifeops/triggers/schedule-once.js.map +1 -0
- package/dist/lifeops/validate/coding-task-request.d.ts +18 -0
- package/dist/lifeops/validate/coding-task-request.d.ts.map +1 -0
- package/dist/lifeops/validate/coding-task-request.js +16 -0
- package/dist/lifeops/validate/coding-task-request.js.map +1 -0
- package/dist/lifeops/voice/grounded-reply.d.ts +41 -0
- package/dist/lifeops/voice/grounded-reply.d.ts.map +1 -0
- package/dist/lifeops/voice/grounded-reply.js +24 -0
- package/dist/lifeops/voice/grounded-reply.js.map +1 -0
- package/dist/lifeops/voice-affect.d.ts +79 -0
- package/dist/lifeops/voice-affect.d.ts.map +1 -0
- package/dist/lifeops/voice-affect.js +253 -0
- package/dist/lifeops/voice-affect.js.map +1 -0
- package/dist/lifeops/wave1-types.d.ts +125 -0
- package/dist/lifeops/wave1-types.d.ts.map +1 -0
- package/dist/lifeops/wave1-types.js +1 -0
- package/dist/lifeops/wave1-types.js.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts +33 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js +226 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js.map +1 -0
- package/dist/lifeops/work-threads/index.d.ts +3 -0
- package/dist/lifeops/work-threads/index.d.ts.map +1 -0
- package/dist/lifeops/work-threads/index.js +7 -0
- package/dist/lifeops/work-threads/index.js.map +1 -0
- package/dist/lifeops/work-threads/store.d.ts +91 -0
- package/dist/lifeops/work-threads/store.d.ts.map +1 -0
- package/dist/lifeops/work-threads/store.js +245 -0
- package/dist/lifeops/work-threads/store.js.map +1 -0
- package/dist/lifeops/work-threads/types.d.ts +58 -0
- package/dist/lifeops/work-threads/types.d.ts.map +1 -0
- package/dist/lifeops/work-threads/types.js +1 -0
- package/dist/lifeops/work-threads/types.js.map +1 -0
- package/dist/platform/host.d.ts +16 -0
- package/dist/platform/host.d.ts.map +1 -0
- package/dist/platform/host.js +22 -0
- package/dist/platform/host.js.map +1 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.d.ts.map +1 -0
- package/dist/platform/index.js +3 -0
- package/dist/platform/index.js.map +1 -0
- package/dist/platform/lifeops-github.d.ts +15 -0
- package/dist/platform/lifeops-github.d.ts.map +1 -0
- package/dist/platform/lifeops-github.js +146 -0
- package/dist/platform/lifeops-github.js.map +1 -0
- package/dist/plugin.d.ts +106 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +989 -0
- package/dist/plugin.js.map +1 -0
- package/dist/provider.d.ts +4 -0
- package/dist/provider.d.ts.map +1 -0
- package/dist/provider.js +108 -0
- package/dist/provider.js.map +1 -0
- package/dist/providers/activity-profile.d.ts +3 -0
- package/dist/providers/activity-profile.d.ts.map +1 -0
- package/dist/providers/activity-profile.js +140 -0
- package/dist/providers/activity-profile.js.map +1 -0
- package/dist/providers/cross-channel-context.d.ts +29 -0
- package/dist/providers/cross-channel-context.d.ts.map +1 -0
- package/dist/providers/cross-channel-context.js +206 -0
- package/dist/providers/cross-channel-context.js.map +1 -0
- package/dist/providers/first-run.d.ts +22 -0
- package/dist/providers/first-run.d.ts.map +1 -0
- package/dist/providers/first-run.js +93 -0
- package/dist/providers/first-run.js.map +1 -0
- package/dist/providers/health.d.ts +2 -0
- package/dist/providers/health.d.ts.map +1 -0
- package/dist/providers/health.js +14 -0
- package/dist/providers/health.js.map +1 -0
- package/dist/providers/inbox-triage.d.ts +3 -0
- package/dist/providers/inbox-triage.d.ts.map +1 -0
- package/dist/providers/inbox-triage.js +134 -0
- package/dist/providers/inbox-triage.js.map +1 -0
- package/dist/providers/lifeops.d.ts +3 -0
- package/dist/providers/lifeops.d.ts.map +1 -0
- package/dist/providers/lifeops.js +548 -0
- package/dist/providers/lifeops.js.map +1 -0
- package/dist/providers/pending-prompts.d.ts +38 -0
- package/dist/providers/pending-prompts.d.ts.map +1 -0
- package/dist/providers/pending-prompts.js +81 -0
- package/dist/providers/pending-prompts.js.map +1 -0
- package/dist/providers/recent-task-states.d.ts +52 -0
- package/dist/providers/recent-task-states.d.ts.map +1 -0
- package/dist/providers/recent-task-states.js +166 -0
- package/dist/providers/recent-task-states.js.map +1 -0
- package/dist/providers/room-policy.d.ts +16 -0
- package/dist/providers/room-policy.d.ts.map +1 -0
- package/dist/providers/room-policy.js +71 -0
- package/dist/providers/room-policy.js.map +1 -0
- package/dist/providers/work-threads.d.ts +3 -0
- package/dist/providers/work-threads.d.ts.map +1 -0
- package/dist/providers/work-threads.js +97 -0
- package/dist/providers/work-threads.js.map +1 -0
- package/dist/public.d.ts +3 -0
- package/dist/public.d.ts.map +1 -0
- package/dist/public.js +17 -0
- package/dist/public.js.map +1 -0
- package/dist/routes/cloud-features-routes.d.ts +9 -0
- package/dist/routes/cloud-features-routes.d.ts.map +1 -0
- package/dist/routes/cloud-features-routes.js +164 -0
- package/dist/routes/cloud-features-routes.js.map +1 -0
- package/dist/routes/entities.d.ts +14 -0
- package/dist/routes/entities.d.ts.map +1 -0
- package/dist/routes/entities.js +203 -0
- package/dist/routes/entities.js.map +1 -0
- package/dist/routes/lifeops-routes.d.ts +20 -0
- package/dist/routes/lifeops-routes.d.ts.map +1 -0
- package/dist/routes/lifeops-routes.js +2337 -0
- package/dist/routes/lifeops-routes.js.map +1 -0
- package/dist/routes/plugin.d.ts +9 -0
- package/dist/routes/plugin.d.ts.map +1 -0
- package/dist/routes/plugin.js +568 -0
- package/dist/routes/plugin.js.map +1 -0
- package/dist/routes/relationships.d.ts +13 -0
- package/dist/routes/relationships.d.ts.map +1 -0
- package/dist/routes/relationships.js +195 -0
- package/dist/routes/relationships.js.map +1 -0
- package/dist/routes/scheduled-tasks.d.ts +102 -0
- package/dist/routes/scheduled-tasks.d.ts.map +1 -0
- package/dist/routes/scheduled-tasks.js +322 -0
- package/dist/routes/scheduled-tasks.js.map +1 -0
- package/dist/routes/sleep-routes.d.ts +3 -0
- package/dist/routes/sleep-routes.d.ts.map +1 -0
- package/dist/routes/sleep-routes.js +33 -0
- package/dist/routes/sleep-routes.js.map +1 -0
- package/dist/routes/travel-provider-relay-routes.d.ts +2 -0
- package/dist/routes/travel-provider-relay-routes.d.ts.map +1 -0
- package/dist/routes/travel-provider-relay-routes.js +7 -0
- package/dist/routes/travel-provider-relay-routes.js.map +1 -0
- package/dist/routes/website-blocker-routes.d.ts +6 -0
- package/dist/routes/website-blocker-routes.d.ts.map +1 -0
- package/dist/routes/website-blocker-routes.js +218 -0
- package/dist/routes/website-blocker-routes.js.map +1 -0
- package/dist/security/action-confirmation.d.ts +12 -0
- package/dist/security/action-confirmation.d.ts.map +1 -0
- package/dist/security/action-confirmation.js +36 -0
- package/dist/security/action-confirmation.js.map +1 -0
- package/dist/service.d.ts +34 -0
- package/dist/service.d.ts.map +1 -0
- package/dist/service.js +111 -0
- package/dist/service.js.map +1 -0
- package/dist/travel-time/calendar-create.d.ts +17 -0
- package/dist/travel-time/calendar-create.d.ts.map +1 -0
- package/dist/travel-time/calendar-create.js +28 -0
- package/dist/travel-time/calendar-create.js.map +1 -0
- package/dist/travel-time/service.d.ts +114 -0
- package/dist/travel-time/service.d.ts.map +1 -0
- package/dist/travel-time/service.js +209 -0
- package/dist/travel-time/service.js.map +1 -0
- package/dist/types/app-blocker-settings-card.d.ts +2 -0
- package/dist/types/app-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/app-blocker-settings-card.js +1 -0
- package/dist/types/app-blocker-settings-card.js.map +1 -0
- package/dist/types/briefing.d.ts +59 -0
- package/dist/types/briefing.d.ts.map +1 -0
- package/dist/types/briefing.js +1 -0
- package/dist/types/briefing.js.map +1 -0
- package/dist/types/document-request.d.ts +41 -0
- package/dist/types/document-request.d.ts.map +1 -0
- package/dist/types/document-request.js +1 -0
- package/dist/types/document-request.js.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/website-blocker-settings-card.d.ts +2 -0
- package/dist/types/website-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/website-blocker-settings-card.js +1 -0
- package/dist/types/website-blocker-settings-card.js.map +1 -0
- package/dist/ui.d.ts +13 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +25 -0
- package/dist/ui.js.map +1 -0
- package/dist/utils/format-duration.d.ts +2 -0
- package/dist/utils/format-duration.d.ts.map +1 -0
- package/dist/utils/format-duration.js +13 -0
- package/dist/utils/format-duration.js.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +3 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/lifeops-url.d.ts +3 -0
- package/dist/utils/lifeops-url.d.ts.map +1 -0
- package/dist/utils/lifeops-url.js +28 -0
- package/dist/utils/lifeops-url.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts +32 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.js +30 -0
- package/dist/website-blocker/chat-integration/block-activator.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts +7 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js +115 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts +39 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js +133 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts +21 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js +230 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts +13 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js +22 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js.map +1 -0
- package/dist/website-blocker/chat-integration/index.d.ts +5 -0
- package/dist/website-blocker/chat-integration/index.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/index.js +26 -0
- package/dist/website-blocker/chat-integration/index.js.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts +75 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.js +154 -0
- package/dist/website-blocker/proactive-block-bridge.js.map +1 -0
- package/dist/website-blocker/public.d.ts +12 -0
- package/dist/website-blocker/public.d.ts.map +1 -0
- package/dist/website-blocker/public.js +51 -0
- package/dist/website-blocker/public.js.map +1 -0
- 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 @@
|
|
|
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"}
|