@elizaos/plugin-personal-assistant 2.0.3-beta.5 → 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 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/activity-profile/proactive-worker.ts"],"sourcesContent":["import {\n getAgentEventService,\n loadElizaConfig,\n loadOwnerContactsConfig,\n resolveOwnerContactWithFallback,\n} from \"@elizaos/agent\";\nimport type { IAgentRuntime, Task, TaskMetadata, UUID } from \"@elizaos/core\";\nimport {\n logger,\n ModelType,\n parseJsonModelRecord,\n runWithTrajectoryContext,\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\";\nimport { resolveDefaultTimeZone } from \"../lifeops/defaults.js\";\nimport { ensureRuntimeAgentRecord } from \"../lifeops/runtime.js\";\nimport { LifeOpsService, LifeOpsServiceError } from \"../lifeops/service.js\";\nimport { resolveEffectiveDayKey } from \"./analyzer.js\";\nimport { proactiveInboxDigestRequest } from \"./proactive-inbox-digest.js\";\nimport {\n type CalendarEventSlim,\n type GoalSlim,\n type InboxDigestSlim,\n type OccurrenceSlim,\n type ProactiveRelativeTimeSlim,\n planDowntimeNudges,\n planGm,\n planGn,\n planGoalCheckIns,\n planNudges,\n planSocialOveruseCheck,\n SOCIAL_OVERUSE_WINDOW_MINUTES,\n type SocialHabitSummarySlim,\n} from \"./proactive-planner.js\";\nimport {\n buildActivityProfile,\n profileNeedsRebuild,\n readFiredLogFromMetadata,\n readProfileFromMetadata,\n refreshCurrentState,\n resolveOwnerEntityId,\n} from \"./service.js\";\nimport type {\n ActivityProfile,\n FiredActionsLog,\n ProactiveAction,\n} from \"./types.js\";\n\nexport const PROACTIVE_TASK_NAME = \"PROACTIVE_AGENT\" as const;\nexport const PROACTIVE_TASK_TAGS = [\"queue\", \"repeat\", \"proactive\"] as const;\nexport const PROACTIVE_TASK_INTERVAL_MS = 60_000;\nconst CALENDAR_PROACTIVE_CLASSIFICATION_HORIZON_DAYS = 21;\n/**\n * Drop scheduled actions that were due more than this long ago. Without\n * this guard, any planner bug that lands `scheduledFor` in the past\n * would dispatch on every tick of the worker (60s).\n */\nconst STALE_ACTION_THRESHOLD_MS = 4 * 60 * 60 * 1000;\n\nexport function isAppFirstRunComplete(): boolean {\n try {\n return loadElizaConfig().meta?.firstRunComplete === true;\n } catch {\n return false;\n }\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value) && typeof value === \"object\" && !Array.isArray(value);\n}\n\nfunction resolveExecutionNow(options: Record<string, unknown> = {}): Date {\n const raw = options.now;\n if (raw instanceof Date) {\n return new Date(raw.getTime());\n }\n if (typeof raw === \"number\" && Number.isFinite(raw)) {\n return new Date(raw);\n }\n if (typeof raw === \"string\" && raw.trim().length > 0) {\n const parsed = new Date(raw);\n if (Number.isFinite(parsed.getTime())) {\n return parsed;\n }\n }\n return new Date();\n}\n\nfunction isProactiveTask(task: Task): boolean {\n const metadata = isRecord(task.metadata) ? task.metadata : null;\n const agent = metadata?.proactiveAgent;\n return (\n task.name === PROACTIVE_TASK_NAME &&\n isRecord(agent) &&\n agent.kind === \"runtime_runner\"\n );\n}\n\nfunction buildProactiveMetadata(\n current: Record<string, unknown> | null = null,\n): TaskMetadata {\n return {\n ...current,\n updateInterval: PROACTIVE_TASK_INTERVAL_MS,\n baseInterval: PROACTIVE_TASK_INTERVAL_MS,\n blocking: true,\n proactiveAgent: {\n kind: \"runtime_runner\",\n version: 1,\n },\n };\n}\n\ntype ProactiveOwnerContact = {\n entityId?: string;\n channelId?: string;\n roomId?: string;\n};\n\ntype CalendarEventProactiveDecision = {\n id: string;\n shouldCheckIn: boolean;\n reason?: string | null;\n};\n\nfunction normalizePlannerBoolean(value: unknown): boolean | null {\n if (typeof value === \"boolean\") {\n return value;\n }\n if (typeof value === \"string\") {\n const normalized = value.trim().toLowerCase();\n if ([\"true\", \"yes\", \"1\"].includes(normalized)) {\n return true;\n }\n if ([\"false\", \"no\", \"0\"].includes(normalized)) {\n return false;\n }\n }\n return null;\n}\n\nfunction formatPromptScalar(value: unknown, maxLength = 600): string {\n if (value === null || value === undefined) {\n return \"\";\n }\n return String(value).replace(/\\s+/g, \" \").trim().slice(0, maxLength);\n}\n\nfunction formatCalendarEventsForPrompt(events: CalendarEventSlim[]): string {\n return events\n .map((event, index) =>\n [\n `events[${index}]:`,\n ` id: ${formatPromptScalar(event.id, 200)}`,\n ` summary: ${formatPromptScalar(event.summary, 300)}`,\n ` description: ${formatPromptScalar(event.description ?? \"\", 500)}`,\n ` location: ${formatPromptScalar(event.location ?? \"\", 300)}`,\n ` startAt: ${formatPromptScalar(event.startAt, 80)}`,\n ` endAt: ${formatPromptScalar(event.endAt, 80)}`,\n ` isAllDay: ${event.isAllDay}`,\n ` attendeeCount: ${event.attendeeCount ?? 0}`,\n ` hasConferenceLink: ${Boolean(event.conferenceLink)}`,\n ].join(\"\\n\"),\n )\n .join(\"\\n\");\n}\n\nfunction normalizeCalendarEventProactiveDecisions(\n parsed: Record<string, unknown> | null,\n allowedIds: Set<string>,\n): Map<string, CalendarEventProactiveDecision> {\n const records = Array.isArray(parsed?.events)\n ? parsed.events\n : Array.isArray(parsed?.decisions)\n ? parsed.decisions\n : Array.isArray(parsed)\n ? parsed\n : [];\n const decisions = new Map<string, CalendarEventProactiveDecision>();\n for (const item of records) {\n if (!item || typeof item !== \"object\" || Array.isArray(item)) {\n continue;\n }\n const record = item as Record<string, unknown>;\n const id =\n typeof record.id === \"string\" && record.id.trim().length > 0\n ? record.id.trim()\n : null;\n if (!id || !allowedIds.has(id)) {\n continue;\n }\n const shouldCheckIn = normalizePlannerBoolean(\n record.shouldCheckIn ?? record.should_check_in,\n );\n decisions.set(id, {\n id,\n shouldCheckIn: shouldCheckIn === true,\n reason:\n typeof record.reason === \"string\" && record.reason.trim().length > 0\n ? record.reason.trim()\n : null,\n });\n }\n return decisions;\n}\n\nfunction parseCalendarEventProactiveOutput(\n raw: string,\n): Record<string, unknown> | null {\n return parseJsonModelRecord<Record<string, unknown>>(raw);\n}\n\nexport async function classifyCalendarEventsForProactivePlanning(\n runtime: IAgentRuntime,\n events: CalendarEventSlim[],\n timezone: string,\n now: Date,\n): Promise<Map<string, CalendarEventProactiveDecision> | null> {\n if (typeof runtime.useModel !== \"function\") {\n return null;\n }\n\n const horizonMs =\n now.getTime() +\n CALENDAR_PROACTIVE_CLASSIFICATION_HORIZON_DAYS * 24 * 60 * 60 * 1000;\n const candidateEvents = events\n .filter((event) => {\n const startMs = Date.parse(event.startAt);\n return (\n Number.isFinite(startMs) &&\n startMs >= now.getTime() &&\n startMs <= horizonMs\n );\n })\n .sort((left, right) => Date.parse(left.startAt) - Date.parse(right.startAt))\n .slice(0, 40);\n if (candidateEvents.length === 0) {\n return new Map();\n }\n\n const prompt = [\n \"Decide which calendar events deserve a proactive check-in or reminder from the assistant.\",\n \"Do not use fixed numeric weights. Judge naturally from the event details.\",\n \"A proactive check-in should be reserved for events where a gentle heads-up would actually help.\",\n \"Meetings, calls, interviews, appointments, therapy, coffee or dinner with people, and other short scheduled social/professional events usually deserve a check-in.\",\n \"Hotel stays, flights, travel blocks, reservations, check-in/check-out, passive itinerary items, and long all-day or near-all-day logistics usually do not deserve a check-in.\",\n \"If an event would be extremely hard to forget or has no clear actionability, mark shouldCheckIn=false.\",\n 'Return JSON only, for example {\"events\":[{\"id\":\"matching event id\",\"shouldCheckIn\":true,\"reason\":\"short reason\"}]}.',\n \"No prose, markdown, code fences, or <think>.\",\n \"\",\n `Current timezone: ${timezone}`,\n `Current ISO datetime: ${now.toISOString()}`,\n \"Events:\",\n formatCalendarEventsForPrompt(candidateEvents),\n ].join(\"\\n\");\n\n try {\n const result = await runWithTrajectoryContext(\n { purpose: \"lifeops-proactive-worker\" },\n () => runtime.useModel(ModelType.TEXT_LARGE, { prompt }),\n );\n const raw = typeof result === \"string\" ? result : \"\";\n const parsed = parseCalendarEventProactiveOutput(raw);\n if (!parsed) {\n return null;\n }\n return normalizeCalendarEventProactiveDecisions(\n parsed,\n new Set(candidateEvents.map((event) => event.id)),\n );\n } catch (error) {\n logger.warn(\n {\n boundary: \"activity_profile\",\n operation: \"planner_calendar_event_classification\",\n err: error instanceof Error ? error : undefined,\n },\n `[proactive] Failed to classify proactive calendar events: ${String(error)}`,\n );\n return null;\n }\n}\n\nexport function resolveProactiveDeliverySource(targetPlatform: string): string {\n if (\n targetPlatform === \"web_app\" ||\n targetPlatform === \"desktop_app\" ||\n targetPlatform === \"mobile_app\" ||\n targetPlatform === \"macos_activity_collector\"\n ) {\n return \"client_chat\";\n }\n return targetPlatform;\n}\n\nexport function resolveProactiveOwnerContact(args: {\n targetPlatform: string;\n ownerEntityId: string;\n ownerContacts: Record<string, ProactiveOwnerContact>;\n}): { source: string; contact: ProactiveOwnerContact } | null {\n const deliverySource = resolveProactiveDeliverySource(args.targetPlatform);\n if (deliverySource === \"client_chat\") {\n return {\n source: \"client_chat\",\n contact: { entityId: args.ownerEntityId },\n };\n }\n\n const resolved = resolveOwnerContactWithFallback({\n ownerContacts: args.ownerContacts,\n source: deliverySource,\n ownerEntityId: args.ownerEntityId,\n });\n if (resolved) {\n return {\n source: resolved.source,\n contact: resolved.contact,\n };\n }\n\n return null;\n}\n\nexport async function executeProactiveTask(\n runtime: IAgentRuntime,\n options: Record<string, unknown> = {},\n): Promise<{ nextInterval: number }> {\n const now = resolveExecutionNow(options);\n const timezone = resolveDefaultTimeZone();\n\n const ownerEntityId = await resolveOwnerEntityId(runtime);\n if (!ownerEntityId) {\n return { nextInterval: PROACTIVE_TASK_INTERVAL_MS };\n }\n\n // WS5: Route this tick through the shared LLM planner. The planner\n // decides whether any action is warranted and whether it requires\n // human approval. We invoke it up-front so every proactive tick is\n // observable via `planJob` and so sensitive actions are always\n // enqueued into the WS6 approval queue.\n const plannerContext: BackgroundJobContext = {\n jobKind: \"daily_brief\",\n subjectUserId: ownerEntityId,\n snapshot: {\n now: now.toISOString(),\n timezone,\n },\n availableChannels: [\"internal\"],\n trigger: \"proactive_tick\",\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 `[proactive] background planner unavailable — ${error.message}`,\n );\n } else {\n throw error;\n }\n }\n\n const tasks = await runtime.getTasks({\n agentIds: [runtime.agentId],\n tags: [...PROACTIVE_TASK_TAGS],\n });\n const task = tasks.find(isProactiveTask);\n if (!task?.id) {\n return { nextInterval: PROACTIVE_TASK_INTERVAL_MS };\n }\n\n const metadata = isRecord(task.metadata) ? task.metadata : {};\n const currentProfile = readProfileFromMetadata(metadata);\n let profile: ActivityProfile | null;\n if (profileNeedsRebuild(currentProfile, now)) {\n logger.info(\"[proactive] Building full activity profile\");\n profile = await buildActivityProfile(runtime, ownerEntityId, timezone, now);\n } else if (currentProfile) {\n profile = await refreshCurrentState(\n runtime,\n ownerEntityId,\n currentProfile,\n now,\n );\n } else {\n profile = null;\n }\n\n if (!profile) {\n return { nextInterval: PROACTIVE_TASK_INTERVAL_MS };\n }\n\n const todayStr = resolveEffectiveDayKey(profile, timezone, now);\n let firedLog = readFiredLogFromMetadata(metadata, todayStr);\n let inboxDigest: InboxDigestSlim | null = null;\n const { occurrences, calendarEvents, goals, relativeTime } =\n await fetchPlannerContext(runtime, timezone, now);\n // NOTE: planGm/planGn apply their own time-of-day gating today; the\n // canonical source of truth for morning/night enforcement windows is\n // `src/lifeops/enforcement-windows.ts` (getCurrentEnforcementWindow).\n // If planner gating is ever consolidated, switch these helpers to use\n // that utility so the reminder pipeline and the proactive worker agree.\n const gmAction = planGm(\n profile,\n occurrences,\n calendarEvents,\n relativeTime,\n null,\n firedLog,\n timezone,\n now,\n );\n const gnAction = planGn(profile, relativeTime, null, firedLog, timezone, now);\n if (\n isDigestActionReady(gmAction, now) ||\n isDigestActionReady(gnAction, now)\n ) {\n inboxDigest = await loadInboxDigest(runtime);\n }\n const hydratedGmAction = planGm(\n profile,\n occurrences,\n calendarEvents,\n relativeTime,\n inboxDigest,\n firedLog,\n timezone,\n now,\n );\n const hydratedGnAction = planGn(\n profile,\n relativeTime,\n inboxDigest,\n firedLog,\n timezone,\n now,\n );\n const nudgeActions = planNudges(\n profile,\n occurrences,\n calendarEvents,\n firedLog,\n timezone,\n now,\n );\n const downtimeActions = planDowntimeNudges(\n profile,\n occurrences,\n calendarEvents,\n firedLog,\n timezone,\n now,\n );\n const goalCheckInActions = planGoalCheckIns(\n profile,\n goals,\n firedLog,\n timezone,\n now,\n );\n\n const socialSummary = await loadSocialOveruseSummary(runtime, now);\n const socialOveruseAction = socialSummary\n ? planSocialOveruseCheck(profile, socialSummary, firedLog, timezone, now)\n : null;\n\n // Wave-2 W2-A removed the legacy `planSeedingOffer` flow — routine\n // seeding is now a FIRST_RUN customize-path concern.\n\n const allActions = [\n hydratedGmAction,\n hydratedGnAction,\n ...nudgeActions,\n ...downtimeActions,\n ...goalCheckInActions,\n socialOveruseAction,\n ].filter(\n (action): action is ProactiveAction =>\n action !== null && action.status === \"pending\",\n );\n\n const ownerContacts = loadOwnerContactsConfig({\n boundary: \"activity_profile\",\n operation: \"owner_contacts_config\",\n message:\n \"[proactive] Failed to load owner contacts config; proactive messages cannot route to owner channels until config is available.\",\n });\n for (const action of allActions) {\n if (action.scheduledFor > now.getTime()) {\n continue;\n }\n // Defensive: don't dispatch stale actions (e.g. a GN whose target\n // hour resolved to the past). Without this guard a single planner\n // miscomputation will fire every PROACTIVE_TASK_INTERVAL_MS.\n const ageMs = now.getTime() - action.scheduledFor;\n if (ageMs > STALE_ACTION_THRESHOLD_MS) {\n logger.warn(\n `[proactive] Skipping stale ${action.kind} (scheduledFor was ${Math.round(ageMs / 60000)} min ago)`,\n );\n continue;\n }\n\n const resolvedTarget = resolveProactiveOwnerContact({\n targetPlatform: action.targetPlatform,\n ownerEntityId,\n ownerContacts,\n });\n const contact = resolvedTarget?.contact;\n if (!resolvedTarget || !contact) {\n logger.warn(\n `[proactive] No owner contact for platform ${action.targetPlatform}, skipping ${action.kind}`,\n );\n continue;\n }\n\n if (!contact.entityId && !contact.channelId && !contact.roomId) {\n logger.warn(\n `[proactive] No owner contact for platform ${action.targetPlatform}, skipping ${action.kind}`,\n );\n continue;\n }\n\n try {\n if (resolvedTarget.source === \"client_chat\") {\n if (emitProactiveAssistantEvent(runtime, action)) {\n firedLog = recordFiredAction(firedLog, todayStr, action);\n logger.info(`[proactive] Emitted ${action.kind} as assistant event`);\n continue;\n }\n logger.warn(\n `[proactive] AGENT_EVENT emit unavailable for ${action.kind}; skipping in-app proactive delivery`,\n );\n continue;\n }\n\n await runtime.sendMessageToTarget(\n {\n source: resolvedTarget.source,\n entityId: contact.entityId as UUID | undefined,\n channelId: contact.channelId,\n roomId: contact.roomId as UUID | undefined,\n } as Parameters<typeof runtime.sendMessageToTarget>[0],\n buildProactiveDeliveryContent(action, resolvedTarget.source),\n );\n firedLog = recordFiredAction(firedLog, todayStr, action);\n logger.info(\n `[proactive] Fired ${action.kind} on ${resolvedTarget.source}`,\n );\n } catch (err) {\n logger.warn(`[proactive] Failed to send ${action.kind}: ${err}`);\n }\n }\n\n await runtime.updateTask(task.id, {\n metadata: {\n ...metadata,\n activityProfile: profile,\n firedActionsLog: firedLog,\n },\n });\n\n return { nextInterval: PROACTIVE_TASK_INTERVAL_MS };\n}\n\n// Wave-2 W2-A removed `planSeedingOffer` and `SEEDING_MESSAGE`; the\n// legacy `onboarding_seed` proactive action is gone. Routine seeding is\n// now a FIRST_RUN customize-path concern (see\n// `src/lifeops/first-run/service.ts`).\n\nasync function fetchPlannerContext(\n runtime: IAgentRuntime,\n timezone: string,\n now: Date,\n): Promise<{\n occurrences: OccurrenceSlim[];\n calendarEvents: CalendarEventSlim[];\n goals: GoalSlim[];\n relativeTime: ProactiveRelativeTimeSlim | null;\n}> {\n const occurrences: OccurrenceSlim[] = [];\n const calendarEvents: CalendarEventSlim[] = [];\n const goals: GoalSlim[] = [];\n let relativeTime: ProactiveRelativeTimeSlim | null = null;\n const lifeOpsService = new LifeOpsService(runtime);\n\n try {\n const schedule = await lifeOpsService.getScheduleMergedState({\n timezone,\n scope: \"effective\",\n refresh: true,\n now,\n });\n relativeTime = schedule?.relativeTime\n ? {\n wakeAnchorAt: schedule.relativeTime.wakeAnchorAt,\n bedtimeTargetAt: schedule.relativeTime.bedtimeTargetAt,\n minutesSinceWake: schedule.relativeTime.minutesSinceWake,\n minutesUntilBedtimeTarget:\n schedule.relativeTime.minutesUntilBedtimeTarget,\n }\n : null;\n } catch (error) {\n logger.warn(\n {\n boundary: \"activity_profile\",\n operation: \"planner_schedule_state\",\n err: error instanceof Error ? error : undefined,\n },\n `[proactive] Failed to read schedule context for proactive planning: ${String(error)}`,\n );\n }\n\n try {\n const overview = await lifeOpsService.getOverview(now);\n\n for (const occ of overview.occurrences) {\n occurrences.push({\n id: occ.id,\n title: occ.title ?? occ.definitionId ?? \"untitled\",\n dueAt: occ.dueAt,\n state: occ.state,\n definitionKind: occ.definitionKind,\n cadence: occ.cadence ? { kind: occ.cadence.kind } : undefined,\n priority: occ.priority,\n });\n }\n } catch (error) {\n logger.warn(\n {\n boundary: \"activity_profile\",\n operation: \"planner_overview\",\n err: error instanceof Error ? error : undefined,\n },\n `[proactive] Failed to read LifeOps overview for planner context: ${String(error)}`,\n );\n }\n\n try {\n const feed = await lifeOpsService.getCalendarFeed(\n new URL(\"http://localhost/api/lifeops/calendar\"),\n {},\n now,\n );\n const rawCalendarEvents: CalendarEventSlim[] = feed.events.map((event) => ({\n id: event.id,\n summary: event.title ?? \"\",\n startAt: event.startAt,\n endAt: event.endAt,\n isAllDay: event.isAllDay,\n description: event.description ?? \"\",\n location: event.location ?? \"\",\n attendeeCount: Array.isArray(event.attendees)\n ? event.attendees.length\n : 0,\n conferenceLink: event.conferenceLink ?? null,\n }));\n const decisions = await classifyCalendarEventsForProactivePlanning(\n runtime,\n rawCalendarEvents,\n timezone,\n now,\n );\n for (const event of feed.events) {\n const decision = decisions?.get(event.id) ?? null;\n calendarEvents.push({\n id: event.id,\n summary: event.title ?? \"\",\n startAt: event.startAt,\n endAt: event.endAt,\n isAllDay: event.isAllDay,\n description: event.description ?? \"\",\n location: event.location ?? \"\",\n attendeeCount: Array.isArray(event.attendees)\n ? event.attendees.length\n : 0,\n conferenceLink: event.conferenceLink ?? null,\n proactiveCheckIn: decision?.shouldCheckIn ?? null,\n proactiveCheckInReason: decision?.reason ?? null,\n });\n }\n } catch (error) {\n if (error instanceof LifeOpsServiceError && error.status === 409) {\n return { occurrences, calendarEvents, goals, relativeTime };\n }\n logger.warn(\n {\n boundary: \"activity_profile\",\n operation: \"planner_calendar_feed\",\n err: error instanceof Error ? error : undefined,\n },\n `[proactive] Failed to read calendar context for proactive planning: ${String(error)}`,\n );\n }\n\n try {\n const goalRecords = await lifeOpsService.listGoals();\n for (const record of goalRecords) {\n if (record.goal.status !== \"active\") continue;\n const review = await lifeOpsService.reviewGoal(record.goal.id, now);\n const scheduled =\n review.summary.activeOccurrenceCount +\n review.summary.overdueOccurrenceCount +\n review.summary.completedLast7Days;\n goals.push({\n id: record.goal.id,\n title: record.goal.title,\n status: record.goal.status,\n linkedDefinitionCount: review.summary.linkedDefinitionCount,\n recentCompletionRate:\n scheduled > 0 ? review.summary.completedLast7Days / scheduled : 0,\n lastReviewedAt: review.summary.lastActivityAt,\n });\n }\n } catch (error) {\n logger.warn(\n {\n boundary: \"activity_profile\",\n operation: \"planner_goals\",\n err: error instanceof Error ? error : undefined,\n },\n `[proactive] Failed to read goal context for proactive planning: ${String(error)}`,\n );\n }\n\n return { occurrences, calendarEvents, goals, relativeTime };\n}\n\nfunction isDigestActionReady(\n action: ProactiveAction | null,\n now: Date,\n): boolean {\n return Boolean(\n action &&\n (action.kind === \"gm\" || action.kind === \"gn\") &&\n action.status === \"pending\" &&\n action.scheduledFor <= now.getTime(),\n );\n}\n\nasync function loadInboxDigest(\n runtime: IAgentRuntime,\n): Promise<InboxDigestSlim | null> {\n try {\n const inbox = await new LifeOpsService(runtime).getInbox(\n proactiveInboxDigestRequest(),\n );\n const unreadCount = Object.values(inbox.channelCounts).reduce(\n (sum, count) => sum + count.unread,\n 0,\n );\n const channelCounts = Object.entries(inbox.channelCounts)\n .map(([channel, count]) => ({\n channel,\n unreadCount: count.unread,\n }))\n .filter((entry) => entry.unreadCount > 0)\n .sort((left, right) => right.unreadCount - left.unreadCount);\n const highlights = [...inbox.messages]\n .sort((left, right) => {\n const unreadDelta = Number(right.unread) - Number(left.unread);\n if (unreadDelta !== 0) {\n return unreadDelta;\n }\n return Date.parse(right.receivedAt) - Date.parse(left.receivedAt);\n })\n .slice(0, 3)\n .map((message) => ({\n channel: message.channel,\n sender: message.sender.displayName,\n subject: message.subject,\n snippet: message.snippet,\n receivedAt: message.receivedAt,\n unread: message.unread,\n }));\n return {\n unreadCount,\n channelCounts,\n highlights,\n };\n } catch (error) {\n logger.warn(\n {\n boundary: \"activity_profile\",\n operation: \"planner_inbox\",\n err: error instanceof Error ? error : undefined,\n },\n `[proactive] Failed to read inbox for proactive digest: ${String(error)}`,\n );\n return null;\n }\n}\n\nfunction recordFiredAction(\n log: FiredActionsLog | null,\n todayStr: string,\n action: ProactiveAction,\n): FiredActionsLog {\n const current: FiredActionsLog = {\n date: log?.date ?? todayStr,\n gmFiredAt: log?.gmFiredAt,\n gnFiredAt: log?.gnFiredAt,\n nudgedOccurrenceIds: [...(log?.nudgedOccurrenceIds ?? [])],\n nudgedCalendarEventIds: [...(log?.nudgedCalendarEventIds ?? [])],\n checkedGoalIds: [...(log?.checkedGoalIds ?? [])],\n seedingOfferedAt: log?.seedingOfferedAt,\n socialOveruseCheckedAt: log?.socialOveruseCheckedAt,\n };\n\n if (action.kind === \"gm\") {\n current.gmFiredAt = Date.now();\n } else if (action.kind === \"gn\") {\n current.gnFiredAt = Date.now();\n } else if (action.kind === \"pre_activity_nudge\") {\n if (\n action.occurrenceId &&\n !current.nudgedOccurrenceIds.includes(action.occurrenceId)\n ) {\n current.nudgedOccurrenceIds.push(action.occurrenceId);\n }\n if (\n action.calendarEventId &&\n !current.nudgedCalendarEventIds.includes(action.calendarEventId)\n ) {\n current.nudgedCalendarEventIds.push(action.calendarEventId);\n }\n } else if (action.kind === \"goal_check_in\") {\n if (action.goalId && !current.checkedGoalIds?.includes(action.goalId)) {\n current.checkedGoalIds?.push(action.goalId);\n }\n } else if (action.kind === \"social_overuse_check\") {\n current.socialOveruseCheckedAt = Date.now();\n }\n\n return current;\n}\n\nasync function loadSocialOveruseSummary(\n runtime: IAgentRuntime,\n now: Date,\n): Promise<SocialHabitSummarySlim | null> {\n const sinceMs = now.getTime() - SOCIAL_OVERUSE_WINDOW_MINUTES * 60_000;\n const since = new Date(sinceMs).toISOString();\n const until = now.toISOString();\n try {\n // Same pattern as `loadInboxDigest`/`fetchPlannerContext`: a transient\n // screen-time read failure must not abort the whole proactive tick or\n // suppress GM/GN/nudges. Logged and skipped; next tick retries.\n const summary = await new LifeOpsService(runtime).getSocialHabitSummary({\n since,\n until,\n });\n return {\n totalSeconds: summary.totalSeconds,\n services: summary.services.map((entry) => ({\n key: entry.key,\n label: entry.label,\n totalSeconds: entry.totalSeconds,\n })),\n };\n } catch (error) {\n logger.warn(\n {\n boundary: \"activity_profile\",\n operation: \"planner_social_overuse_summary\",\n err: error instanceof Error ? error : undefined,\n },\n `[proactive] Failed to read social-habit summary for overuse planner: ${String(error)}`,\n );\n return null;\n }\n}\n\nfunction buildProactiveDeliveryContent(\n action: ProactiveAction,\n deliverySource: string,\n): { text: string; source: string } {\n const text = action.messageText.trim() || action.contextSummary.trim();\n return { text, source: deliverySource };\n}\n\nfunction emitProactiveAssistantEvent(\n runtime: IAgentRuntime,\n action: ProactiveAction,\n): boolean {\n const eventService = getAgentEventService(runtime) as {\n emit?: (event: {\n runId: string;\n stream: string;\n data: Record<string, unknown>;\n agentId?: string;\n }) => void;\n } | null;\n if (!eventService?.emit) {\n return false;\n }\n\n const text = action.messageText.trim() || action.contextSummary.trim();\n eventService.emit({\n runId: crypto.randomUUID(),\n stream: \"assistant\",\n agentId: runtime.agentId,\n data: {\n text,\n source: resolveProactiveAssistantEventSource(action),\n kind: action.kind,\n scheduledFor: action.scheduledFor,\n targetPlatform: action.targetPlatform,\n occurrenceId: action.occurrenceId,\n calendarEventId: action.calendarEventId,\n goalId: action.goalId,\n },\n });\n return true;\n}\n\nfunction resolveProactiveAssistantEventSource(action: ProactiveAction): string {\n if (action.kind === \"gm\") {\n return \"proactive-gm\";\n }\n if (action.kind === \"gn\") {\n return \"proactive-gn\";\n }\n if (action.kind === \"goal_check_in\") {\n return \"proactive-goal-check-in\";\n }\n if (action.kind === \"social_overuse_check\") {\n return \"proactive-social-overuse\";\n }\n return \"proactive-nudge\";\n}\n\nexport function registerProactiveTaskWorker(runtime: IAgentRuntime): void {\n if (runtime.getTaskWorker(PROACTIVE_TASK_NAME)) {\n return;\n }\n runtime.registerTaskWorker({\n name: PROACTIVE_TASK_NAME,\n // Skip execution when the user has disabled LifeOps via the UI. The task\n // record and worker stay registered so toggling back on requires no\n // restart — cycles just become cheap no-ops while disabled.\n shouldRun: async (rt) => {\n try {\n if (!isAppFirstRunComplete()) return false;\n if (!rt.getModel(ModelType.TEXT_SMALL)) return false;\n const state = await loadLifeOpsAppState(rt as IAgentRuntime);\n return state.enabled;\n } catch (error) {\n logger.warn(\n `[proactive-worker] proactive tick preflight failed; skipping because runtime readiness is unknown: ${\n error instanceof Error ? error.message : String(error)\n }`,\n );\n return false;\n }\n },\n execute: (rt, options) =>\n executeProactiveTask(rt, isRecord(options) ? options : {}),\n });\n}\n\ntype AutonomyServiceLike = {\n getAutonomousRoomId?: () => UUID;\n};\n\nexport async function ensureProactiveAgentTask(\n runtime: IAgentRuntime,\n): Promise<UUID> {\n await ensureRuntimeAgentRecord(runtime);\n const tasks = await runtime.getTasks({\n agentIds: [runtime.agentId],\n tags: [...PROACTIVE_TASK_TAGS],\n });\n const existing = tasks.find(isProactiveTask);\n const metadata = buildProactiveMetadata(\n isRecord(existing?.metadata) ? existing.metadata : null,\n );\n if (existing?.id) {\n await runtime.updateTask(existing.id, {\n description: \"Proactive agent: GM/GN/nudges based on activity profile\",\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(`proactive-agent-room-${runtime.agentId}`);\n\n return runtime.createTask({\n name: PROACTIVE_TASK_NAME,\n description: \"Proactive agent: GM/GN/nudges based on activity profile\",\n roomId,\n tags: [...PROACTIVE_TASK_TAGS],\n metadata,\n dueAt: Date.now(),\n });\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { ActivityProfile } from "./types.js";
|
|
2
|
+
/**
|
|
3
|
+
* Read a previously-persisted {@link ActivityProfile} from entity metadata.
|
|
4
|
+
*
|
|
5
|
+
* Extracted to its own module so that `lifeops/service.ts` can import it
|
|
6
|
+
* without pulling in the full `activity-profile/service.ts` (which itself
|
|
7
|
+
* imports from `lifeops/`), breaking the circular dependency.
|
|
8
|
+
*/
|
|
9
|
+
export declare function readProfileFromMetadata(metadata: Record<string, unknown> | null): ActivityProfile | null;
|
|
10
|
+
//# sourceMappingURL=profile-metadata.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"profile-metadata.d.ts","sourceRoot":"","sources":["../../src/activity-profile/profile-metadata.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAelD;;;;;;GAMG;AACH,wBAAgB,uBAAuB,CACrC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,GACvC,eAAe,GAAG,IAAI,CAKxB"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
function isRecord(value) {
|
|
2
|
+
return Boolean(value) && typeof value === "object" && !Array.isArray(value);
|
|
3
|
+
}
|
|
4
|
+
function isActivityProfile(value) {
|
|
5
|
+
if (!isRecord(value)) return false;
|
|
6
|
+
return typeof value.analyzedAt === "number" && typeof value.ownerEntityId === "string" && typeof value.totalMessages === "number";
|
|
7
|
+
}
|
|
8
|
+
function readProfileFromMetadata(metadata) {
|
|
9
|
+
if (!metadata?.activityProfile) return null;
|
|
10
|
+
const candidate = metadata.activityProfile;
|
|
11
|
+
return isActivityProfile(candidate) ? candidate : null;
|
|
12
|
+
}
|
|
13
|
+
export {
|
|
14
|
+
readProfileFromMetadata
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=profile-metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/activity-profile/profile-metadata.ts"],"sourcesContent":["import type { ActivityProfile } from \"./types.js\";\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value) && typeof value === \"object\" && !Array.isArray(value);\n}\n\nfunction isActivityProfile(value: unknown): value is ActivityProfile {\n if (!isRecord(value)) return false;\n return (\n typeof value.analyzedAt === \"number\" &&\n typeof value.ownerEntityId === \"string\" &&\n typeof value.totalMessages === \"number\"\n );\n}\n\n/**\n * Read a previously-persisted {@link ActivityProfile} from entity metadata.\n *\n * Extracted to its own module so that `lifeops/service.ts` can import it\n * without pulling in the full `activity-profile/service.ts` (which itself\n * imports from `lifeops/`), breaking the circular dependency.\n */\nexport function readProfileFromMetadata(\n metadata: Record<string, unknown> | null,\n): ActivityProfile | null {\n if (!metadata?.activityProfile) return null;\n const candidate = metadata.activityProfile;\n // Reject profiles missing required shape fields (corrupt or stale version)\n return isActivityProfile(candidate) ? candidate : null;\n}\n"],"mappings":"AAEA,SAAS,SAAS,OAAkD;AAClE,SAAO,QAAQ,KAAK,KAAK,OAAO,UAAU,YAAY,CAAC,MAAM,QAAQ,KAAK;AAC5E;AAEA,SAAS,kBAAkB,OAA0C;AACnE,MAAI,CAAC,SAAS,KAAK,EAAG,QAAO;AAC7B,SACE,OAAO,MAAM,eAAe,YAC5B,OAAO,MAAM,kBAAkB,YAC/B,OAAO,MAAM,kBAAkB;AAEnC;AASO,SAAS,wBACd,UACwB;AACxB,MAAI,CAAC,UAAU,gBAAiB,QAAO;AACvC,QAAM,YAAY,SAAS;AAE3B,SAAO,kBAAkB,SAAS,IAAI,YAAY;AACpD;","names":[]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Window-title PII redactor for the T8d activity tracker.
|
|
3
|
+
*
|
|
4
|
+
* Always stripped before reporting:
|
|
5
|
+
* - Email addresses → [redacted-email]
|
|
6
|
+
* - Phone numbers (e.164 / 10-digit US) → [redacted-phone]
|
|
7
|
+
* - Credit-card-like digit runs (13–19 contiguous digits, optional separators) → [redacted-cc]
|
|
8
|
+
*
|
|
9
|
+
* Redaction is applied in the reporting layer before results leave the
|
|
10
|
+
* process.
|
|
11
|
+
*/
|
|
12
|
+
export type RedactorConfig = Record<string, never>;
|
|
13
|
+
export declare function resolveRedactorConfigFromEnv(_env?: NodeJS.ProcessEnv): RedactorConfig;
|
|
14
|
+
export declare function redactWindowTitle(title: string | null | undefined, _config: RedactorConfig): string | null;
|
|
15
|
+
//# sourceMappingURL=redactor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redactor.d.ts","sourceRoot":"","sources":["../../src/activity-profile/redactor.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAaH,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AAEnD,wBAAgB,4BAA4B,CAC1C,IAAI,GAAE,MAAM,CAAC,UAAwB,GACpC,cAAc,CAEhB;AAED,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,EAChC,OAAO,EAAE,cAAc,GACtB,MAAM,GAAG,IAAI,CAUf"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
const EMAIL = /[\w.!#$%&'*+/=?^`{|}~-]+@[\w-]+(?:\.[\w-]+)+/g;
|
|
2
|
+
const CC_LIKE = /(?:\d[ -]?){13,19}/g;
|
|
3
|
+
const PHONE = /(?<!\d)(?:\+\d{7,15}|(?:\+1[-.\s]?)?\(?\d{3}\)?[-.\s]?\d{3}[-.\s]?\d{4})(?!\d)/g;
|
|
4
|
+
function resolveRedactorConfigFromEnv(_env = process.env) {
|
|
5
|
+
return {};
|
|
6
|
+
}
|
|
7
|
+
function redactWindowTitle(title, _config) {
|
|
8
|
+
if (title === null || title === void 0) return null;
|
|
9
|
+
let out = title;
|
|
10
|
+
out = out.replace(CC_LIKE, (match) => {
|
|
11
|
+
const digitCount = (match.match(/\d/g) ?? []).length;
|
|
12
|
+
return digitCount >= 13 && digitCount <= 19 ? "[redacted-cc]" : match;
|
|
13
|
+
});
|
|
14
|
+
out = out.replace(EMAIL, "[redacted-email]");
|
|
15
|
+
out = out.replace(PHONE, "[redacted-phone]");
|
|
16
|
+
return out;
|
|
17
|
+
}
|
|
18
|
+
export {
|
|
19
|
+
redactWindowTitle,
|
|
20
|
+
resolveRedactorConfigFromEnv
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=redactor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/activity-profile/redactor.ts"],"sourcesContent":["/**\n * Window-title PII redactor for the T8d activity tracker.\n *\n * Always stripped before reporting:\n * - Email addresses → [redacted-email]\n * - Phone numbers (e.164 / 10-digit US) → [redacted-phone]\n * - Credit-card-like digit runs (13–19 contiguous digits, optional separators) → [redacted-cc]\n *\n * Redaction is applied in the reporting layer before results leave the\n * process.\n */\n\nconst EMAIL = /[\\w.!#$%&'*+/=?^`{|}~-]+@[\\w-]+(?:\\.[\\w-]+)+/g;\n\n// Credit-card-like digit runs. Checked BEFORE phone numbers because a 16-digit\n// PAN would otherwise be partially matched by the phone regex.\nconst CC_LIKE = /(?:\\d[ -]?){13,19}/g;\n\n// Phone: e.164 (+ followed by 7-15 digits), or 10-digit US formats with an\n// optional +1 country code and separators.\nconst PHONE =\n /(?<!\\d)(?:\\+\\d{7,15}|(?:\\+1[-.\\s]?)?\\(?\\d{3}\\)?[-.\\s]?\\d{3}[-.\\s]?\\d{4})(?!\\d)/g;\n\nexport type RedactorConfig = Record<string, never>;\n\nexport function resolveRedactorConfigFromEnv(\n _env: NodeJS.ProcessEnv = process.env,\n): RedactorConfig {\n return {};\n}\n\nexport function redactWindowTitle(\n title: string | null | undefined,\n _config: RedactorConfig,\n): string | null {\n if (title === null || title === undefined) return null;\n let out = title;\n out = out.replace(CC_LIKE, (match) => {\n const digitCount = (match.match(/\\d/g) ?? []).length;\n return digitCount >= 13 && digitCount <= 19 ? \"[redacted-cc]\" : match;\n });\n out = out.replace(EMAIL, \"[redacted-email]\");\n out = out.replace(PHONE, \"[redacted-phone]\");\n return out;\n}\n"],"mappings":"AAYA,MAAM,QAAQ;AAId,MAAM,UAAU;AAIhB,MAAM,QACJ;AAIK,SAAS,6BACd,OAA0B,QAAQ,KAClB;AAChB,SAAO,CAAC;AACV;AAEO,SAAS,kBACd,OACA,SACe;AACf,MAAI,UAAU,QAAQ,UAAU,OAAW,QAAO;AAClD,MAAI,MAAM;AACV,QAAM,IAAI,QAAQ,SAAS,CAAC,UAAU;AACpC,UAAM,cAAc,MAAM,MAAM,KAAK,KAAK,CAAC,GAAG;AAC9C,WAAO,cAAc,MAAM,cAAc,KAAK,kBAAkB;AAAA,EAClE,CAAC;AACD,QAAM,IAAI,QAAQ,OAAO,kBAAkB;AAC3C,QAAM,IAAI,QAAQ,OAAO,kBAAkB;AAC3C,SAAO;AACT;","names":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { IAgentRuntime } from "@elizaos/core";
|
|
2
|
+
import { LifeOpsScreenContextSampler } from "../lifeops/screen-context.js";
|
|
3
|
+
export { resolveOwnerEntityId } from "@elizaos/agent";
|
|
4
|
+
import type { ActivityProfile, FiredActionsLog } from "./types.js";
|
|
5
|
+
export declare function setScreenContextSamplerForTesting(sampler: LifeOpsScreenContextSampler | null): void;
|
|
6
|
+
export declare function buildActivityProfile(runtime: IAgentRuntime, ownerEntityId: string, timezone?: string, now?: Date): Promise<ActivityProfile>;
|
|
7
|
+
export declare function refreshCurrentState(runtime: IAgentRuntime, ownerEntityId: string, profile: ActivityProfile, now?: Date): Promise<ActivityProfile>;
|
|
8
|
+
export { readProfileFromMetadata } from "./profile-metadata.js";
|
|
9
|
+
export declare function readFiredLogFromMetadata(metadata: Record<string, unknown> | null, todayDateStr: string): FiredActionsLog | null;
|
|
10
|
+
export declare function profileNeedsRebuild(profile: ActivityProfile | null, now: Date): boolean;
|
|
11
|
+
//# sourceMappingURL=service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../src/activity-profile/service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAQ,MAAM,eAAe,CAAC;AAIzD,OAAO,EACL,2BAA2B,EAE5B,MAAM,8BAA8B,CAAC;AAGtC,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAUtD,OAAO,KAAK,EACV,eAAe,EAEf,eAAe,EAChB,MAAM,YAAY,CAAC;AAuBpB,wBAAgB,iCAAiC,CAC/C,OAAO,EAAE,2BAA2B,GAAG,IAAI,GAC1C,IAAI,CAEN;AAqFD,wBAAsB,oBAAoB,CACxC,OAAO,EAAE,aAAa,EACtB,aAAa,EAAE,MAAM,EACrB,QAAQ,CAAC,EAAE,MAAM,EACjB,GAAG,CAAC,EAAE,IAAI,GACT,OAAO,CAAC,eAAe,CAAC,CAsF1B;AAID,wBAAsB,mBAAmB,CACvC,OAAO,EAAE,aAAa,EACtB,aAAa,EAAE,MAAM,EACrB,OAAO,EAAE,eAAe,EACxB,GAAG,CAAC,EAAE,IAAI,GACT,OAAO,CAAC,eAAe,CAAC,CAgF1B;AAMD,OAAO,EAAE,uBAAuB,EAAE,MAAM,uBAAuB,CAAC;AAEhE,wBAAgB,wBAAwB,CACtC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,EACxC,YAAY,EAAE,MAAM,GACnB,eAAe,GAAG,IAAI,CA4CxB;AAED,wBAAgB,mBAAmB,CACjC,OAAO,EAAE,eAAe,GAAG,IAAI,EAC/B,GAAG,EAAE,IAAI,GACR,OAAO,CAGT"}
|
|
@@ -0,0 +1,272 @@
|
|
|
1
|
+
import { logger } from "@elizaos/core";
|
|
2
|
+
import { resolveDefaultTimeZone } from "../lifeops/defaults.js";
|
|
3
|
+
import {
|
|
4
|
+
LifeOpsScreenContextSampler
|
|
5
|
+
} from "../lifeops/screen-context.js";
|
|
6
|
+
import { LifeOpsService } from "../lifeops/service.js";
|
|
7
|
+
import { resolveOwnerEntityId } from "@elizaos/agent";
|
|
8
|
+
import {
|
|
9
|
+
analyzeMessages,
|
|
10
|
+
enrichWithCalendar,
|
|
11
|
+
resolveCurrentActivityState,
|
|
12
|
+
SUSTAINED_INACTIVITY_GAP_MS
|
|
13
|
+
} from "./analyzer.js";
|
|
14
|
+
function isRecord(value) {
|
|
15
|
+
return Boolean(value) && typeof value === "object" && !Array.isArray(value);
|
|
16
|
+
}
|
|
17
|
+
function isStringArray(value) {
|
|
18
|
+
return Array.isArray(value) && value.every((entry) => typeof entry === "string");
|
|
19
|
+
}
|
|
20
|
+
const PROFILE_MAX_AGE_MS = 60 * 60 * 1e3;
|
|
21
|
+
const MESSAGES_WINDOW_DAYS = 7;
|
|
22
|
+
const MESSAGES_LIMIT = 500;
|
|
23
|
+
const MAX_ROOMS = 50;
|
|
24
|
+
const ACTIVITY_SIGNALS_WINDOW_LIMIT = 500;
|
|
25
|
+
const CURRENT_ACTIVITY_SIGNAL_LIMIT = 32;
|
|
26
|
+
let screenContextSampler = null;
|
|
27
|
+
function setScreenContextSamplerForTesting(sampler) {
|
|
28
|
+
screenContextSampler = sampler;
|
|
29
|
+
}
|
|
30
|
+
function getScreenContextSampler() {
|
|
31
|
+
if (!screenContextSampler) {
|
|
32
|
+
screenContextSampler = new LifeOpsScreenContextSampler();
|
|
33
|
+
}
|
|
34
|
+
return screenContextSampler;
|
|
35
|
+
}
|
|
36
|
+
async function sampleScreenContext(currentTime) {
|
|
37
|
+
return await getScreenContextSampler().sample(currentTime.getTime());
|
|
38
|
+
}
|
|
39
|
+
function mapActivitySignalRecord(signal) {
|
|
40
|
+
return {
|
|
41
|
+
source: signal.source,
|
|
42
|
+
platform: signal.platform,
|
|
43
|
+
state: signal.state,
|
|
44
|
+
observedAt: Date.parse(signal.observedAt),
|
|
45
|
+
idleState: signal.idleState,
|
|
46
|
+
idleTimeSeconds: signal.idleTimeSeconds,
|
|
47
|
+
onBattery: signal.onBattery,
|
|
48
|
+
health: signal.health,
|
|
49
|
+
metadata: signal.metadata
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
async function loadWindowActivitySignals(runtime, currentTime) {
|
|
53
|
+
const lifeOpsService = new LifeOpsService(runtime);
|
|
54
|
+
const sinceAt = new Date(
|
|
55
|
+
currentTime.getTime() - MESSAGES_WINDOW_DAYS * 24 * 60 * 60 * 1e3
|
|
56
|
+
).toISOString();
|
|
57
|
+
const signals = await lifeOpsService.listActivitySignals({
|
|
58
|
+
sinceAt,
|
|
59
|
+
limit: ACTIVITY_SIGNALS_WINDOW_LIMIT
|
|
60
|
+
});
|
|
61
|
+
return signals.map(mapActivitySignalRecord).filter((signal) => Number.isFinite(signal.observedAt));
|
|
62
|
+
}
|
|
63
|
+
async function loadRecentActivitySignals(runtime) {
|
|
64
|
+
const lifeOpsService = new LifeOpsService(runtime);
|
|
65
|
+
const signals = await lifeOpsService.listActivitySignals({
|
|
66
|
+
limit: CURRENT_ACTIVITY_SIGNAL_LIMIT
|
|
67
|
+
});
|
|
68
|
+
return signals.map(mapActivitySignalRecord).filter((signal) => Number.isFinite(signal.observedAt));
|
|
69
|
+
}
|
|
70
|
+
function mergeScreenContext(profile, screenContext, now) {
|
|
71
|
+
const updatedProfile = {
|
|
72
|
+
...profile,
|
|
73
|
+
screenContextFocus: screenContext?.focus ?? null,
|
|
74
|
+
screenContextSource: screenContext?.source ?? null,
|
|
75
|
+
screenContextSampledAt: screenContext?.sampledAtMs ?? null,
|
|
76
|
+
screenContextConfidence: screenContext?.confidence ?? null,
|
|
77
|
+
screenContextBusy: screenContext?.busy ?? false,
|
|
78
|
+
screenContextAvailable: screenContext?.available ?? false,
|
|
79
|
+
screenContextStale: screenContext?.stale ?? false
|
|
80
|
+
};
|
|
81
|
+
const activityState = resolveCurrentActivityState(updatedProfile, now);
|
|
82
|
+
return {
|
|
83
|
+
...updatedProfile,
|
|
84
|
+
...activityState,
|
|
85
|
+
effectiveDayKey: activityState.effectiveDayKey
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
async function buildActivityProfile(runtime, ownerEntityId, timezone, now) {
|
|
89
|
+
const tz = timezone ?? resolveDefaultTimeZone();
|
|
90
|
+
const currentTime = now ?? /* @__PURE__ */ new Date();
|
|
91
|
+
const activitySignals = await loadWindowActivitySignals(runtime, currentTime);
|
|
92
|
+
const roomIds = await runtime.getRoomsForParticipant(ownerEntityId);
|
|
93
|
+
const limitedRoomIds = roomIds.slice(0, MAX_ROOMS);
|
|
94
|
+
const roomSourceMap = /* @__PURE__ */ new Map();
|
|
95
|
+
await Promise.all(
|
|
96
|
+
limitedRoomIds.map(async (roomId) => {
|
|
97
|
+
try {
|
|
98
|
+
const room = await runtime.getRoom(roomId);
|
|
99
|
+
if (room?.source) {
|
|
100
|
+
roomSourceMap.set(roomId, room.source);
|
|
101
|
+
}
|
|
102
|
+
} catch (cause) {
|
|
103
|
+
logger.debug(
|
|
104
|
+
{ err: cause, roomId },
|
|
105
|
+
"[ActivityProfile] room source lookup failed"
|
|
106
|
+
);
|
|
107
|
+
}
|
|
108
|
+
})
|
|
109
|
+
);
|
|
110
|
+
const messages = [];
|
|
111
|
+
if (limitedRoomIds.length > 0) {
|
|
112
|
+
const memories = await runtime.getMemoriesByRoomIds({
|
|
113
|
+
tableName: "messages",
|
|
114
|
+
roomIds: limitedRoomIds,
|
|
115
|
+
limit: MESSAGES_LIMIT
|
|
116
|
+
});
|
|
117
|
+
for (const mem of memories) {
|
|
118
|
+
messages.push({
|
|
119
|
+
entityId: mem.entityId,
|
|
120
|
+
roomId: mem.roomId,
|
|
121
|
+
createdAt: mem.createdAt ?? 0
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
const baseProfile = analyzeMessages(
|
|
126
|
+
messages,
|
|
127
|
+
roomSourceMap,
|
|
128
|
+
ownerEntityId,
|
|
129
|
+
tz,
|
|
130
|
+
MESSAGES_WINDOW_DAYS,
|
|
131
|
+
activitySignals,
|
|
132
|
+
currentTime
|
|
133
|
+
);
|
|
134
|
+
let calendarEvents = [];
|
|
135
|
+
try {
|
|
136
|
+
const lifeOpsService = new LifeOpsService(runtime);
|
|
137
|
+
const feed = await lifeOpsService.getCalendarFeed(
|
|
138
|
+
new URL("http://localhost/api/lifeops/calendar"),
|
|
139
|
+
{},
|
|
140
|
+
currentTime
|
|
141
|
+
);
|
|
142
|
+
calendarEvents = feed.events.map((e) => ({
|
|
143
|
+
startAt: e.startAt,
|
|
144
|
+
endAt: e.endAt,
|
|
145
|
+
isAllDay: e.isAllDay
|
|
146
|
+
}));
|
|
147
|
+
} catch (err) {
|
|
148
|
+
logger.debug(
|
|
149
|
+
{
|
|
150
|
+
boundary: "activity_profile",
|
|
151
|
+
operation: "calendar_enrichment",
|
|
152
|
+
err: err instanceof Error ? err : void 0
|
|
153
|
+
},
|
|
154
|
+
"[activity-profile] Calendar not available for profile enrichment; proceeding without calendar data."
|
|
155
|
+
);
|
|
156
|
+
}
|
|
157
|
+
const withCalendar = enrichWithCalendar(baseProfile, calendarEvents, tz);
|
|
158
|
+
const screenContext = await sampleScreenContext(currentTime);
|
|
159
|
+
return mergeScreenContext(withCalendar, screenContext, currentTime);
|
|
160
|
+
}
|
|
161
|
+
async function refreshCurrentState(runtime, ownerEntityId, profile, now) {
|
|
162
|
+
const currentTime = now ?? /* @__PURE__ */ new Date();
|
|
163
|
+
const roomIds = await runtime.getRoomsForParticipant(ownerEntityId);
|
|
164
|
+
const limitedRoomIds = roomIds.slice(0, MAX_ROOMS);
|
|
165
|
+
const screenContext = await sampleScreenContext(currentTime);
|
|
166
|
+
const activitySignals = await loadRecentActivitySignals(runtime);
|
|
167
|
+
const roomSourceMap = /* @__PURE__ */ new Map();
|
|
168
|
+
if (limitedRoomIds.length > 0) {
|
|
169
|
+
await Promise.all(
|
|
170
|
+
limitedRoomIds.map(async (roomId) => {
|
|
171
|
+
try {
|
|
172
|
+
const room = await runtime.getRoom(roomId);
|
|
173
|
+
if (room?.source) {
|
|
174
|
+
roomSourceMap.set(roomId, room.source);
|
|
175
|
+
}
|
|
176
|
+
} catch (cause) {
|
|
177
|
+
logger.debug(
|
|
178
|
+
{ err: cause, roomId },
|
|
179
|
+
"[ActivityProfile] room source lookup failed during refresh"
|
|
180
|
+
);
|
|
181
|
+
}
|
|
182
|
+
})
|
|
183
|
+
);
|
|
184
|
+
}
|
|
185
|
+
let lastSeenAt = profile.lastSeenAt;
|
|
186
|
+
let lastSeenPlatform = profile.lastSeenPlatform;
|
|
187
|
+
if (limitedRoomIds.length > 0) {
|
|
188
|
+
const memories = await runtime.getMemoriesByRoomIds({
|
|
189
|
+
tableName: "messages",
|
|
190
|
+
roomIds: limitedRoomIds,
|
|
191
|
+
limit: 10
|
|
192
|
+
});
|
|
193
|
+
for (const memory of memories) {
|
|
194
|
+
const createdAt = memory.createdAt ?? 0;
|
|
195
|
+
if (createdAt > currentTime.getTime()) {
|
|
196
|
+
continue;
|
|
197
|
+
}
|
|
198
|
+
const source = roomSourceMap.get(memory.roomId) ?? "unknown";
|
|
199
|
+
const isOwnerMessage = memory.entityId === ownerEntityId;
|
|
200
|
+
const isClientChatSignal = source === "client_chat";
|
|
201
|
+
if (!isOwnerMessage && !isClientChatSignal) {
|
|
202
|
+
continue;
|
|
203
|
+
}
|
|
204
|
+
if (createdAt >= lastSeenAt) {
|
|
205
|
+
lastSeenAt = createdAt;
|
|
206
|
+
lastSeenPlatform = isClientChatSignal ? "client_chat" : source;
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
for (const signal of activitySignals) {
|
|
211
|
+
if (signal.state !== "active" || signal.observedAt > currentTime.getTime()) {
|
|
212
|
+
continue;
|
|
213
|
+
}
|
|
214
|
+
if (signal.observedAt >= lastSeenAt) {
|
|
215
|
+
lastSeenAt = signal.observedAt;
|
|
216
|
+
lastSeenPlatform = signal.platform;
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
return mergeScreenContext(
|
|
220
|
+
{
|
|
221
|
+
...profile,
|
|
222
|
+
lastSeenAt,
|
|
223
|
+
lastSeenPlatform,
|
|
224
|
+
sustainedInactivityThresholdMinutes: profile.sustainedInactivityThresholdMinutes || SUSTAINED_INACTIVITY_GAP_MS / 6e4
|
|
225
|
+
},
|
|
226
|
+
screenContext,
|
|
227
|
+
currentTime
|
|
228
|
+
);
|
|
229
|
+
}
|
|
230
|
+
import { readProfileFromMetadata } from "./profile-metadata.js";
|
|
231
|
+
function readFiredLogFromMetadata(metadata, todayDateStr) {
|
|
232
|
+
if (!metadata?.firedActionsLog) return null;
|
|
233
|
+
const log = metadata.firedActionsLog;
|
|
234
|
+
if (!isRecord(log)) return null;
|
|
235
|
+
if (typeof log.date !== "string") return null;
|
|
236
|
+
if (!Array.isArray(log.nudgedOccurrenceIds)) return null;
|
|
237
|
+
if (log.date !== todayDateStr) {
|
|
238
|
+
return {
|
|
239
|
+
date: todayDateStr,
|
|
240
|
+
gmFiredAt: typeof log.gmFiredAt === "number" ? log.gmFiredAt : void 0,
|
|
241
|
+
gnFiredAt: typeof log.gnFiredAt === "number" ? log.gnFiredAt : void 0,
|
|
242
|
+
seedingOfferedAt: typeof log.seedingOfferedAt === "number" ? log.seedingOfferedAt : void 0,
|
|
243
|
+
nudgedOccurrenceIds: [],
|
|
244
|
+
nudgedCalendarEventIds: [],
|
|
245
|
+
checkedGoalIds: []
|
|
246
|
+
};
|
|
247
|
+
}
|
|
248
|
+
return {
|
|
249
|
+
date: log.date,
|
|
250
|
+
gmFiredAt: typeof log.gmFiredAt === "number" ? log.gmFiredAt : void 0,
|
|
251
|
+
gnFiredAt: typeof log.gnFiredAt === "number" ? log.gnFiredAt : void 0,
|
|
252
|
+
seedingOfferedAt: typeof log.seedingOfferedAt === "number" ? log.seedingOfferedAt : void 0,
|
|
253
|
+
socialOveruseCheckedAt: typeof log.socialOveruseCheckedAt === "number" ? log.socialOveruseCheckedAt : void 0,
|
|
254
|
+
nudgedOccurrenceIds: isStringArray(log.nudgedOccurrenceIds) ? log.nudgedOccurrenceIds : [],
|
|
255
|
+
nudgedCalendarEventIds: isStringArray(log.nudgedCalendarEventIds) ? log.nudgedCalendarEventIds : [],
|
|
256
|
+
checkedGoalIds: isStringArray(log.checkedGoalIds) ? log.checkedGoalIds : []
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
function profileNeedsRebuild(profile, now) {
|
|
260
|
+
if (!profile) return true;
|
|
261
|
+
return now.getTime() - profile.analyzedAt > PROFILE_MAX_AGE_MS;
|
|
262
|
+
}
|
|
263
|
+
export {
|
|
264
|
+
buildActivityProfile,
|
|
265
|
+
profileNeedsRebuild,
|
|
266
|
+
readFiredLogFromMetadata,
|
|
267
|
+
readProfileFromMetadata,
|
|
268
|
+
refreshCurrentState,
|
|
269
|
+
resolveOwnerEntityId,
|
|
270
|
+
setScreenContextSamplerForTesting
|
|
271
|
+
};
|
|
272
|
+
//# sourceMappingURL=service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/activity-profile/service.ts"],"sourcesContent":["import type { IAgentRuntime, UUID } from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport type { LifeOpsActivitySignal } from \"../contracts/index.js\";\nimport { resolveDefaultTimeZone } from \"../lifeops/defaults.js\";\nimport {\n LifeOpsScreenContextSampler,\n type LifeOpsScreenContextSummary,\n} from \"../lifeops/screen-context.js\";\nimport { LifeOpsService } from \"../lifeops/service.js\";\n\nexport { resolveOwnerEntityId } from \"@elizaos/agent\";\n\nimport {\n analyzeMessages,\n type CalendarEventRecord,\n enrichWithCalendar,\n type MessageRecord,\n resolveCurrentActivityState,\n SUSTAINED_INACTIVITY_GAP_MS,\n} from \"./analyzer.js\";\nimport type {\n ActivityProfile,\n ActivitySignalRecord,\n FiredActionsLog,\n} from \"./types.js\";\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value) && typeof value === \"object\" && !Array.isArray(value);\n}\n\nfunction isStringArray(value: unknown): value is string[] {\n return (\n Array.isArray(value) && value.every((entry) => typeof entry === \"string\")\n );\n}\n\n// ── Constants ─────────────────────────────────────────\n\nconst PROFILE_MAX_AGE_MS = 60 * 60 * 1000; // 60 min full rebuild threshold\nconst MESSAGES_WINDOW_DAYS = 7;\nconst MESSAGES_LIMIT = 500;\nconst MAX_ROOMS = 50;\nconst ACTIVITY_SIGNALS_WINDOW_LIMIT = 500;\nconst CURRENT_ACTIVITY_SIGNAL_LIMIT = 32;\n\nlet screenContextSampler: LifeOpsScreenContextSampler | null = null;\n\nexport function setScreenContextSamplerForTesting(\n sampler: LifeOpsScreenContextSampler | null,\n): void {\n screenContextSampler = sampler;\n}\n\nfunction getScreenContextSampler(): LifeOpsScreenContextSampler {\n if (!screenContextSampler) {\n screenContextSampler = new LifeOpsScreenContextSampler();\n }\n return screenContextSampler;\n}\n\nasync function sampleScreenContext(\n currentTime: Date,\n): Promise<LifeOpsScreenContextSummary> {\n return await getScreenContextSampler().sample(currentTime.getTime());\n}\n\nfunction mapActivitySignalRecord(\n signal: LifeOpsActivitySignal,\n): ActivitySignalRecord {\n return {\n source: signal.source,\n platform: signal.platform,\n state: signal.state,\n observedAt: Date.parse(signal.observedAt),\n idleState: signal.idleState,\n idleTimeSeconds: signal.idleTimeSeconds,\n onBattery: signal.onBattery,\n health: signal.health,\n metadata: signal.metadata,\n };\n}\n\nasync function loadWindowActivitySignals(\n runtime: IAgentRuntime,\n currentTime: Date,\n): Promise<ActivitySignalRecord[]> {\n const lifeOpsService = new LifeOpsService(runtime);\n const sinceAt = new Date(\n currentTime.getTime() - MESSAGES_WINDOW_DAYS * 24 * 60 * 60 * 1000,\n ).toISOString();\n const signals = await lifeOpsService.listActivitySignals({\n sinceAt,\n limit: ACTIVITY_SIGNALS_WINDOW_LIMIT,\n });\n return signals\n .map(mapActivitySignalRecord)\n .filter((signal) => Number.isFinite(signal.observedAt));\n}\n\nasync function loadRecentActivitySignals(\n runtime: IAgentRuntime,\n): Promise<ActivitySignalRecord[]> {\n const lifeOpsService = new LifeOpsService(runtime);\n const signals = await lifeOpsService.listActivitySignals({\n limit: CURRENT_ACTIVITY_SIGNAL_LIMIT,\n });\n return signals\n .map(mapActivitySignalRecord)\n .filter((signal) => Number.isFinite(signal.observedAt));\n}\n\nfunction mergeScreenContext(\n profile: ActivityProfile,\n screenContext: LifeOpsScreenContextSummary | null,\n now: Date,\n): ActivityProfile {\n const updatedProfile: ActivityProfile = {\n ...profile,\n screenContextFocus: screenContext?.focus ?? null,\n screenContextSource: screenContext?.source ?? null,\n screenContextSampledAt: screenContext?.sampledAtMs ?? null,\n screenContextConfidence: screenContext?.confidence ?? null,\n screenContextBusy: screenContext?.busy ?? false,\n screenContextAvailable: screenContext?.available ?? false,\n screenContextStale: screenContext?.stale ?? false,\n };\n const activityState = resolveCurrentActivityState(updatedProfile, now);\n return {\n ...updatedProfile,\n ...activityState,\n effectiveDayKey: activityState.effectiveDayKey,\n };\n}\n\n// ── Profile building ──────────────────────────────────\n\nexport async function buildActivityProfile(\n runtime: IAgentRuntime,\n ownerEntityId: string,\n timezone?: string,\n now?: Date,\n): Promise<ActivityProfile> {\n const tz = timezone ?? resolveDefaultTimeZone();\n const currentTime = now ?? new Date();\n const activitySignals = await loadWindowActivitySignals(runtime, currentTime);\n\n // 1. Get all rooms the owner participates in\n const roomIds = await runtime.getRoomsForParticipant(ownerEntityId as UUID);\n const limitedRoomIds = roomIds.slice(0, MAX_ROOMS);\n\n // 2. Build room → source map\n const roomSourceMap = new Map<string, string>();\n await Promise.all(\n limitedRoomIds.map(async (roomId) => {\n try {\n const room = await runtime.getRoom(roomId);\n if (room?.source) {\n roomSourceMap.set(roomId, room.source);\n }\n } catch (cause) {\n // Room read can fail for deleted/migrated rooms during batch fetch.\n // Missing source is non-fatal for the profile build; log so repeated\n // misses surface in telemetry.\n logger.debug(\n { err: cause, roomId },\n \"[ActivityProfile] room source lookup failed\",\n );\n }\n }),\n );\n\n // 3. Fetch messages\n const messages: MessageRecord[] = [];\n if (limitedRoomIds.length > 0) {\n const memories = await runtime.getMemoriesByRoomIds({\n tableName: \"messages\",\n roomIds: limitedRoomIds,\n limit: MESSAGES_LIMIT,\n });\n for (const mem of memories) {\n messages.push({\n entityId: mem.entityId,\n roomId: mem.roomId,\n createdAt: mem.createdAt ?? 0,\n });\n }\n }\n\n // 4. Analyze messages\n const baseProfile = analyzeMessages(\n messages,\n roomSourceMap,\n ownerEntityId,\n tz,\n MESSAGES_WINDOW_DAYS,\n activitySignals,\n currentTime,\n );\n\n // 5. Enrich with calendar if available\n let calendarEvents: CalendarEventRecord[] = [];\n try {\n const lifeOpsService = new LifeOpsService(runtime);\n const feed = await lifeOpsService.getCalendarFeed(\n new URL(\"http://localhost/api/lifeops/calendar\"),\n {},\n currentTime,\n );\n calendarEvents = feed.events.map((e) => ({\n startAt: e.startAt,\n endAt: e.endAt,\n isAllDay: e.isAllDay,\n }));\n } catch (err) {\n logger.debug(\n {\n boundary: \"activity_profile\",\n operation: \"calendar_enrichment\",\n err: err instanceof Error ? err : undefined,\n },\n \"[activity-profile] Calendar not available for profile enrichment; proceeding without calendar data.\",\n );\n }\n\n const withCalendar = enrichWithCalendar(baseProfile, calendarEvents, tz);\n const screenContext = await sampleScreenContext(currentTime);\n return mergeScreenContext(withCalendar, screenContext, currentTime);\n}\n\n// ── Lightweight current-state refresh ─────────────────\n\nexport async function refreshCurrentState(\n runtime: IAgentRuntime,\n ownerEntityId: string,\n profile: ActivityProfile,\n now?: Date,\n): Promise<ActivityProfile> {\n const currentTime = now ?? new Date();\n const roomIds = await runtime.getRoomsForParticipant(ownerEntityId as UUID);\n const limitedRoomIds = roomIds.slice(0, MAX_ROOMS);\n const screenContext = await sampleScreenContext(currentTime);\n const activitySignals = await loadRecentActivitySignals(runtime);\n\n const roomSourceMap = new Map<string, string>();\n if (limitedRoomIds.length > 0) {\n await Promise.all(\n limitedRoomIds.map(async (roomId) => {\n try {\n const room = await runtime.getRoom(roomId);\n if (room?.source) {\n roomSourceMap.set(roomId, room.source);\n }\n } catch (cause) {\n logger.debug(\n { err: cause, roomId },\n \"[ActivityProfile] room source lookup failed during refresh\",\n );\n }\n }),\n );\n }\n\n let lastSeenAt = profile.lastSeenAt;\n let lastSeenPlatform = profile.lastSeenPlatform;\n if (limitedRoomIds.length > 0) {\n const memories = await runtime.getMemoriesByRoomIds({\n tableName: \"messages\",\n roomIds: limitedRoomIds,\n limit: 10,\n });\n\n for (const memory of memories) {\n const createdAt = memory.createdAt ?? 0;\n if (createdAt > currentTime.getTime()) {\n continue;\n }\n\n const source = roomSourceMap.get(memory.roomId) ?? \"unknown\";\n const isOwnerMessage = memory.entityId === ownerEntityId;\n const isClientChatSignal = source === \"client_chat\";\n if (!isOwnerMessage && !isClientChatSignal) {\n continue;\n }\n\n if (createdAt >= lastSeenAt) {\n lastSeenAt = createdAt;\n lastSeenPlatform = isClientChatSignal ? \"client_chat\" : source;\n }\n }\n }\n\n for (const signal of activitySignals) {\n if (\n signal.state !== \"active\" ||\n signal.observedAt > currentTime.getTime()\n ) {\n continue;\n }\n if (signal.observedAt >= lastSeenAt) {\n lastSeenAt = signal.observedAt;\n lastSeenPlatform = signal.platform;\n }\n }\n\n return mergeScreenContext(\n {\n ...profile,\n lastSeenAt,\n lastSeenPlatform,\n sustainedInactivityThresholdMinutes:\n profile.sustainedInactivityThresholdMinutes ||\n SUSTAINED_INACTIVITY_GAP_MS / 60_000,\n },\n screenContext,\n currentTime,\n );\n}\n\n// ── Metadata persistence helpers ──────────────────────\n\n// Re-export from dedicated module to preserve public API while breaking the\n// circular dependency between activity-profile/service and lifeops/service.\nexport { readProfileFromMetadata } from \"./profile-metadata.js\";\n\nexport function readFiredLogFromMetadata(\n metadata: Record<string, unknown> | null,\n todayDateStr: string,\n): FiredActionsLog | null {\n if (!metadata?.firedActionsLog) return null;\n const log = metadata.firedActionsLog;\n if (!isRecord(log)) return null;\n if (typeof log.date !== \"string\") return null;\n if (!Array.isArray(log.nudgedOccurrenceIds)) return null;\n // If the log was written under a different effective day key, drop the\n // per-day arrays (nudges/goals) but preserve the timestamps so the\n // planner's timestamp-based once-per-day gate still sees the prior\n // GM/GN fires. See planner `firedRecently()` for the consumer side.\n if (log.date !== todayDateStr) {\n return {\n date: todayDateStr,\n gmFiredAt: typeof log.gmFiredAt === \"number\" ? log.gmFiredAt : undefined,\n gnFiredAt: typeof log.gnFiredAt === \"number\" ? log.gnFiredAt : undefined,\n seedingOfferedAt:\n typeof log.seedingOfferedAt === \"number\"\n ? log.seedingOfferedAt\n : undefined,\n nudgedOccurrenceIds: [],\n nudgedCalendarEventIds: [],\n checkedGoalIds: [],\n };\n }\n return {\n date: log.date,\n gmFiredAt: typeof log.gmFiredAt === \"number\" ? log.gmFiredAt : undefined,\n gnFiredAt: typeof log.gnFiredAt === \"number\" ? log.gnFiredAt : undefined,\n seedingOfferedAt:\n typeof log.seedingOfferedAt === \"number\"\n ? log.seedingOfferedAt\n : undefined,\n socialOveruseCheckedAt:\n typeof log.socialOveruseCheckedAt === \"number\"\n ? log.socialOveruseCheckedAt\n : undefined,\n nudgedOccurrenceIds: isStringArray(log.nudgedOccurrenceIds)\n ? log.nudgedOccurrenceIds\n : [],\n nudgedCalendarEventIds: isStringArray(log.nudgedCalendarEventIds)\n ? log.nudgedCalendarEventIds\n : [],\n checkedGoalIds: isStringArray(log.checkedGoalIds) ? log.checkedGoalIds : [],\n };\n}\n\nexport function profileNeedsRebuild(\n profile: ActivityProfile | null,\n now: Date,\n): boolean {\n if (!profile) return true;\n return now.getTime() - profile.analyzedAt > PROFILE_MAX_AGE_MS;\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import type { LifeOpsHealthSignal } from "../contracts/index.js";
|
|
2
|
+
export type TimeBucket = "EARLY_MORNING" | "MORNING" | "MIDDAY" | "AFTERNOON" | "EVENING" | "NIGHT" | "LATE_NIGHT";
|
|
3
|
+
export declare const TIME_BUCKET_RANGES: Record<TimeBucket, {
|
|
4
|
+
start: number;
|
|
5
|
+
end: number;
|
|
6
|
+
}>;
|
|
7
|
+
export declare const ALL_TIME_BUCKETS: TimeBucket[];
|
|
8
|
+
export declare function emptyBucketCounts(): Record<TimeBucket, number>;
|
|
9
|
+
export interface PlatformActivity {
|
|
10
|
+
source: string;
|
|
11
|
+
messageCount: number;
|
|
12
|
+
bucketCounts: Record<TimeBucket, number>;
|
|
13
|
+
lastMessageAt: number;
|
|
14
|
+
averageMessagesPerDay: number;
|
|
15
|
+
}
|
|
16
|
+
export interface ActivitySignalRecord {
|
|
17
|
+
source: "app_lifecycle" | "page_visibility" | "desktop_power" | "desktop_interaction" | "connector_activity" | "imessage_outbound" | "mobile_device" | "mobile_health";
|
|
18
|
+
platform: string;
|
|
19
|
+
state: "active" | "idle" | "background" | "locked" | "sleeping";
|
|
20
|
+
observedAt: number;
|
|
21
|
+
idleState: "active" | "idle" | "locked" | "unknown" | null;
|
|
22
|
+
idleTimeSeconds: number | null;
|
|
23
|
+
onBattery: boolean | null;
|
|
24
|
+
health: LifeOpsHealthSignal | null;
|
|
25
|
+
metadata: Record<string, unknown>;
|
|
26
|
+
}
|
|
27
|
+
export interface ActivityProfile {
|
|
28
|
+
ownerEntityId: string;
|
|
29
|
+
analyzedAt: number;
|
|
30
|
+
analysisWindowDays: number;
|
|
31
|
+
timezone: string;
|
|
32
|
+
totalMessages: number;
|
|
33
|
+
sustainedInactivityThresholdMinutes: number;
|
|
34
|
+
platforms: PlatformActivity[];
|
|
35
|
+
primaryPlatform: string | null;
|
|
36
|
+
secondaryPlatform: string | null;
|
|
37
|
+
bucketCounts: Record<TimeBucket, number>;
|
|
38
|
+
hasCalendarData: boolean;
|
|
39
|
+
typicalFirstEventHour: number | null;
|
|
40
|
+
typicalLastEventHour: number | null;
|
|
41
|
+
avgWeekdayMeetings: number | null;
|
|
42
|
+
typicalFirstActiveHour: number | null;
|
|
43
|
+
typicalLastActiveHour: number | null;
|
|
44
|
+
typicalWakeHour: number | null;
|
|
45
|
+
typicalSleepHour: number | null;
|
|
46
|
+
hasSleepData: boolean;
|
|
47
|
+
isCurrentlySleeping: boolean;
|
|
48
|
+
lastSleepSignalAt: number | null;
|
|
49
|
+
lastWakeSignalAt: number | null;
|
|
50
|
+
sleepSourcePlatform: string | null;
|
|
51
|
+
sleepSource: string | null;
|
|
52
|
+
typicalSleepDurationMinutes: number | null;
|
|
53
|
+
lastSeenAt: number;
|
|
54
|
+
lastSeenPlatform: string | null;
|
|
55
|
+
isCurrentlyActive: boolean;
|
|
56
|
+
hasOpenActivityCycle: boolean;
|
|
57
|
+
currentActivityCycleStartedAt: number | null;
|
|
58
|
+
currentActivityCycleLocalDate: string | null;
|
|
59
|
+
effectiveDayKey: string;
|
|
60
|
+
screenContextFocus: "work" | "leisure" | "transition" | "idle" | "unknown" | null;
|
|
61
|
+
screenContextSource: "disabled" | "browser-capture" | "vision" | null;
|
|
62
|
+
screenContextSampledAt: number | null;
|
|
63
|
+
screenContextConfidence: number | null;
|
|
64
|
+
screenContextBusy: boolean;
|
|
65
|
+
screenContextAvailable: boolean;
|
|
66
|
+
screenContextStale: boolean;
|
|
67
|
+
}
|
|
68
|
+
export interface ProactiveAction {
|
|
69
|
+
kind: "gm" | "gn" | "pre_activity_nudge" | "goal_check_in" | "social_overuse_check";
|
|
70
|
+
scheduledFor: number;
|
|
71
|
+
targetPlatform: string;
|
|
72
|
+
contextSummary: string;
|
|
73
|
+
messageText: string;
|
|
74
|
+
occurrenceId?: string;
|
|
75
|
+
calendarEventId?: string;
|
|
76
|
+
goalId?: string;
|
|
77
|
+
status: "pending" | "fired" | "skipped";
|
|
78
|
+
skipReason?: string;
|
|
79
|
+
}
|
|
80
|
+
export interface FiredActionsLog {
|
|
81
|
+
date: string;
|
|
82
|
+
gmFiredAt?: number;
|
|
83
|
+
gnFiredAt?: number;
|
|
84
|
+
nudgedOccurrenceIds: string[];
|
|
85
|
+
nudgedCalendarEventIds: string[];
|
|
86
|
+
checkedGoalIds?: string[];
|
|
87
|
+
/**
|
|
88
|
+
* Wave-2 W2-A: legacy `seedingOfferedAt` is preserved on the persisted
|
|
89
|
+
* record for backward compatibility with old logs but the proactive
|
|
90
|
+
* worker no longer writes or reads it. The legacy `onboarding_seed`
|
|
91
|
+
* action kind has been removed.
|
|
92
|
+
*/
|
|
93
|
+
seedingOfferedAt?: number;
|
|
94
|
+
/** Epoch ms of the most recent social_overuse_check delivery, if any. */
|
|
95
|
+
socialOveruseCheckedAt?: number;
|
|
96
|
+
}
|
|
97
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/activity-profile/types.ts"],"names":[],"mappings":"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"}
|