@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,61 @@
|
|
|
1
|
+
import crypto from "node:crypto";
|
|
2
|
+
import { executeRawSql, sqlQuote, sqlText, toText } from "../lifeops/sql.js";
|
|
3
|
+
function mapRow(row) {
|
|
4
|
+
const kindRaw = toText(row.event_kind, "");
|
|
5
|
+
if (kindRaw !== "activate" && kindRaw !== "deactivate") return null;
|
|
6
|
+
const id = toText(row.id, "");
|
|
7
|
+
const agentId = toText(row.agent_id, "");
|
|
8
|
+
const observedAt = toText(row.observed_at, "");
|
|
9
|
+
const bundleId = toText(row.bundle_id, "");
|
|
10
|
+
const appName = toText(row.app_name, "");
|
|
11
|
+
if (!id || !agentId || !observedAt || !bundleId) return null;
|
|
12
|
+
const windowTitleRaw = row.window_title;
|
|
13
|
+
const windowTitle = typeof windowTitleRaw === "string" ? windowTitleRaw : null;
|
|
14
|
+
return {
|
|
15
|
+
id,
|
|
16
|
+
agentId,
|
|
17
|
+
observedAt,
|
|
18
|
+
eventKind: kindRaw,
|
|
19
|
+
bundleId,
|
|
20
|
+
appName,
|
|
21
|
+
windowTitle
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
async function insertActivityEvent(runtime, event) {
|
|
25
|
+
const id = crypto.randomUUID();
|
|
26
|
+
const createdAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
27
|
+
await executeRawSql(
|
|
28
|
+
runtime,
|
|
29
|
+
`INSERT INTO app_lifeops.life_activity_events (
|
|
30
|
+
id, agent_id, observed_at, event_kind, bundle_id, app_name,
|
|
31
|
+
window_title, metadata_json, created_at
|
|
32
|
+
) VALUES (
|
|
33
|
+
${sqlQuote(id)},
|
|
34
|
+
${sqlQuote(event.agentId)},
|
|
35
|
+
${sqlQuote(event.observedAt)},
|
|
36
|
+
${sqlQuote(event.eventKind)},
|
|
37
|
+
${sqlQuote(event.bundleId)},
|
|
38
|
+
${sqlQuote(event.appName)},
|
|
39
|
+
${sqlText(null)},
|
|
40
|
+
${sqlQuote("{}")},
|
|
41
|
+
${sqlQuote(createdAt)}
|
|
42
|
+
)`
|
|
43
|
+
);
|
|
44
|
+
return id;
|
|
45
|
+
}
|
|
46
|
+
async function listActivityEvents(runtime, agentId, sinceIso) {
|
|
47
|
+
const rows = await executeRawSql(
|
|
48
|
+
runtime,
|
|
49
|
+
`SELECT id, agent_id, observed_at, event_kind, bundle_id, app_name, window_title
|
|
50
|
+
FROM app_lifeops.life_activity_events
|
|
51
|
+
WHERE agent_id = ${sqlQuote(agentId)}
|
|
52
|
+
AND observed_at >= ${sqlQuote(sinceIso)}
|
|
53
|
+
ORDER BY observed_at ASC`
|
|
54
|
+
);
|
|
55
|
+
return rows.map(mapRow).filter((row) => row !== null);
|
|
56
|
+
}
|
|
57
|
+
export {
|
|
58
|
+
insertActivityEvent,
|
|
59
|
+
listActivityEvents
|
|
60
|
+
};
|
|
61
|
+
//# sourceMappingURL=activity-tracker-repo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/activity-profile/activity-tracker-repo.ts"],"sourcesContent":["/**\n * Repository helpers for T8d `app_lifeops.life_activity_events`.\n *\n * Writes are append-only (one row per `activate` / `deactivate`). Reads\n * derive per-app dwell time by pairing consecutive `activate` events (the\n * collector always emits exactly one activate per focused app, and emits a\n * synthetic activate on startup so the first window has an anchor).\n */\n\nimport crypto from \"node:crypto\";\nimport type { IAgentRuntime } from \"@elizaos/core\";\nimport { executeRawSql, sqlQuote, sqlText, toText } from \"../lifeops/sql.js\";\n\nexport interface ActivityEventRow {\n id: string;\n agentId: string;\n observedAt: string;\n eventKind: \"activate\" | \"deactivate\";\n bundleId: string;\n appName: string;\n windowTitle: string | null;\n}\n\nfunction mapRow(row: Record<string, unknown>): ActivityEventRow | null {\n const kindRaw = toText(row.event_kind, \"\");\n if (kindRaw !== \"activate\" && kindRaw !== \"deactivate\") return null;\n const id = toText(row.id, \"\");\n const agentId = toText(row.agent_id, \"\");\n const observedAt = toText(row.observed_at, \"\");\n const bundleId = toText(row.bundle_id, \"\");\n const appName = toText(row.app_name, \"\");\n if (!id || !agentId || !observedAt || !bundleId) return null;\n const windowTitleRaw = row.window_title;\n const windowTitle =\n typeof windowTitleRaw === \"string\" ? windowTitleRaw : null;\n return {\n id,\n agentId,\n observedAt,\n eventKind: kindRaw,\n bundleId,\n appName,\n windowTitle,\n };\n}\n\nexport async function insertActivityEvent(\n runtime: IAgentRuntime,\n event: {\n agentId: string;\n observedAt: string;\n eventKind: \"activate\" | \"deactivate\";\n bundleId: string;\n appName: string;\n windowTitle: string | null;\n },\n): Promise<string> {\n const id = crypto.randomUUID();\n const createdAt = new Date().toISOString();\n await executeRawSql(\n runtime,\n `INSERT INTO app_lifeops.life_activity_events (\n id, agent_id, observed_at, event_kind, bundle_id, app_name,\n window_title, metadata_json, created_at\n ) VALUES (\n ${sqlQuote(id)},\n ${sqlQuote(event.agentId)},\n ${sqlQuote(event.observedAt)},\n ${sqlQuote(event.eventKind)},\n ${sqlQuote(event.bundleId)},\n ${sqlQuote(event.appName)},\n ${sqlText(null)},\n ${sqlQuote(\"{}\")},\n ${sqlQuote(createdAt)}\n )`,\n );\n return id;\n}\n\nexport async function listActivityEvents(\n runtime: IAgentRuntime,\n agentId: string,\n sinceIso: string,\n): Promise<ActivityEventRow[]> {\n const rows = await executeRawSql(\n runtime,\n `SELECT id, agent_id, observed_at, event_kind, bundle_id, app_name, window_title\n FROM app_lifeops.life_activity_events\n WHERE agent_id = ${sqlQuote(agentId)}\n AND observed_at >= ${sqlQuote(sinceIso)}\n ORDER BY observed_at ASC`,\n );\n return rows\n .map(mapRow)\n .filter((row): row is ActivityEventRow => row !== null);\n}\n"],"mappings":"AASA,OAAO,YAAY;AAEnB,SAAS,eAAe,UAAU,SAAS,cAAc;AAYzD,SAAS,OAAO,KAAuD;AACrE,QAAM,UAAU,OAAO,IAAI,YAAY,EAAE;AACzC,MAAI,YAAY,cAAc,YAAY,aAAc,QAAO;AAC/D,QAAM,KAAK,OAAO,IAAI,IAAI,EAAE;AAC5B,QAAM,UAAU,OAAO,IAAI,UAAU,EAAE;AACvC,QAAM,aAAa,OAAO,IAAI,aAAa,EAAE;AAC7C,QAAM,WAAW,OAAO,IAAI,WAAW,EAAE;AACzC,QAAM,UAAU,OAAO,IAAI,UAAU,EAAE;AACvC,MAAI,CAAC,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,SAAU,QAAO;AACxD,QAAM,iBAAiB,IAAI;AAC3B,QAAM,cACJ,OAAO,mBAAmB,WAAW,iBAAiB;AACxD,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA,WAAW;AAAA,IACX;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;AAEA,eAAsB,oBACpB,SACA,OAQiB;AACjB,QAAM,KAAK,OAAO,WAAW;AAC7B,QAAM,aAAY,oBAAI,KAAK,GAAE,YAAY;AACzC,QAAM;AAAA,IACJ;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,QAII,SAAS,EAAE,CAAC;AAAA,QACZ,SAAS,MAAM,OAAO,CAAC;AAAA,QACvB,SAAS,MAAM,UAAU,CAAC;AAAA,QAC1B,SAAS,MAAM,SAAS,CAAC;AAAA,QACzB,SAAS,MAAM,QAAQ,CAAC;AAAA,QACxB,SAAS,MAAM,OAAO,CAAC;AAAA,QACvB,QAAQ,IAAI,CAAC;AAAA,QACb,SAAS,IAAI,CAAC;AAAA,QACd,SAAS,SAAS,CAAC;AAAA;AAAA,EAEzB;AACA,SAAO;AACT;AAEA,eAAsB,mBACpB,SACA,SACA,UAC6B;AAC7B,QAAM,OAAO,MAAM;AAAA,IACjB;AAAA,IACA;AAAA;AAAA,wBAEoB,SAAS,OAAO,CAAC;AAAA,4BACb,SAAS,QAAQ,CAAC;AAAA;AAAA,EAE5C;AACA,SAAO,KACJ,IAAI,MAAM,EACV,OAAO,CAAC,QAAiC,QAAQ,IAAI;AAC1D;","names":[]}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Reporting layer for T8d activity tracker.
|
|
3
|
+
*
|
|
4
|
+
* Converts the append-only `life_activity_events` stream into per-app dwell
|
|
5
|
+
* summaries. New repository writes do not persist raw window titles; any
|
|
6
|
+
* legacy titles are passed through {@link redactWindowTitle} before reporting.
|
|
7
|
+
*
|
|
8
|
+
* Duration model:
|
|
9
|
+
* - Events are sorted ascending by observed_at.
|
|
10
|
+
* - Each `activate` anchors a dwell interval; the interval ends at the
|
|
11
|
+
* timestamp of the NEXT event (activate or deactivate), or at `now`
|
|
12
|
+
* if no following event exists.
|
|
13
|
+
* - `deactivate` events do not anchor a new interval.
|
|
14
|
+
* - Intervals are clipped to the report window [since, until].
|
|
15
|
+
*/
|
|
16
|
+
import type { IAgentRuntime } from "@elizaos/core";
|
|
17
|
+
import { type RedactorConfig } from "./redactor.js";
|
|
18
|
+
export interface ActivityAppBreakdown {
|
|
19
|
+
bundleId: string;
|
|
20
|
+
appName: string;
|
|
21
|
+
totalMs: number;
|
|
22
|
+
sessionCount: number;
|
|
23
|
+
sampleWindowTitles: string[];
|
|
24
|
+
}
|
|
25
|
+
export interface ActivityReport {
|
|
26
|
+
sinceMs: number;
|
|
27
|
+
untilMs: number;
|
|
28
|
+
totalMs: number;
|
|
29
|
+
apps: ActivityAppBreakdown[];
|
|
30
|
+
}
|
|
31
|
+
export interface ActivityReportOptions {
|
|
32
|
+
windowMs: number;
|
|
33
|
+
nowMs?: number;
|
|
34
|
+
limit?: number;
|
|
35
|
+
redactor?: RedactorConfig;
|
|
36
|
+
}
|
|
37
|
+
export declare function getActivityReportBetween(runtime: IAgentRuntime, agentId: string, options: {
|
|
38
|
+
sinceMs: number;
|
|
39
|
+
untilMs: number;
|
|
40
|
+
limit?: number;
|
|
41
|
+
redactor?: RedactorConfig;
|
|
42
|
+
}): Promise<ActivityReport>;
|
|
43
|
+
export declare function getActivityReport(runtime: IAgentRuntime, agentId: string, options: ActivityReportOptions): Promise<ActivityReport>;
|
|
44
|
+
export declare function getTimeOnApp(runtime: IAgentRuntime, agentId: string, appNameOrBundleId: string, options: {
|
|
45
|
+
windowMs: number;
|
|
46
|
+
nowMs?: number;
|
|
47
|
+
redactor?: RedactorConfig;
|
|
48
|
+
}): Promise<{
|
|
49
|
+
totalMs: number;
|
|
50
|
+
matchedBy: "bundleId" | "appName" | "none";
|
|
51
|
+
}>;
|
|
52
|
+
//# sourceMappingURL=activity-tracker-reporting.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity-tracker-reporting.d.ts","sourceRoot":"","sources":["../../src/activity-profile/activity-tracker-reporting.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAKnD,OAAO,EACL,KAAK,cAAc,EAGpB,MAAM,eAAe,CAAC;AAGvB,MAAM,WAAW,oBAAoB;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,kBAAkB,EAAE,MAAM,EAAE,CAAC;CAC9B;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,oBAAoB,EAAE,CAAC;CAC9B;AAED,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,cAAc,CAAC;CAC3B;AA+FD,wBAAsB,wBAAwB,CAC5C,OAAO,EAAE,aAAa,EACtB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE;IACP,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,cAAc,CAAC;CAC3B,GACA,OAAO,CAAC,cAAc,CAAC,CAYzB;AAED,wBAAsB,iBAAiB,CACrC,OAAO,EAAE,aAAa,EACtB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,qBAAqB,GAC7B,OAAO,CAAC,cAAc,CAAC,CAQzB;AAED,wBAAsB,YAAY,CAChC,OAAO,EAAE,aAAa,EACtB,OAAO,EAAE,MAAM,EACf,iBAAiB,EAAE,MAAM,EACzB,OAAO,EAAE;IAAE,QAAQ,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,cAAc,CAAA;CAAE,GACvE,OAAO,CAAC;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,UAAU,GAAG,SAAS,GAAG,MAAM,CAAA;CAAE,CAAC,CAoB1E"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import {
|
|
2
|
+
listActivityEvents
|
|
3
|
+
} from "./activity-tracker-repo.js";
|
|
4
|
+
import {
|
|
5
|
+
redactWindowTitle,
|
|
6
|
+
resolveRedactorConfigFromEnv
|
|
7
|
+
} from "./redactor.js";
|
|
8
|
+
import { isSystemInactivityApp } from "@elizaos/plugin-health";
|
|
9
|
+
function intervalsFromEvents(events, sinceMs, untilMs) {
|
|
10
|
+
const intervals = [];
|
|
11
|
+
const timestamps = events.map((e) => Date.parse(e.observedAt));
|
|
12
|
+
for (let i = 0; i < events.length; i++) {
|
|
13
|
+
const ev = events[i];
|
|
14
|
+
if (!ev) continue;
|
|
15
|
+
if (ev.eventKind !== "activate") continue;
|
|
16
|
+
if (isSystemInactivityApp(ev)) continue;
|
|
17
|
+
const startMs = timestamps[i];
|
|
18
|
+
if (typeof startMs !== "number" || !Number.isFinite(startMs)) continue;
|
|
19
|
+
const nextTs = i + 1 < events.length ? timestamps[i + 1] : untilMs;
|
|
20
|
+
const endMs = typeof nextTs === "number" && Number.isFinite(nextTs) ? nextTs : untilMs;
|
|
21
|
+
const clippedStart = Math.max(startMs, sinceMs);
|
|
22
|
+
const clippedEnd = Math.min(endMs, untilMs);
|
|
23
|
+
if (clippedEnd <= clippedStart) continue;
|
|
24
|
+
intervals.push({
|
|
25
|
+
bundleId: ev.bundleId,
|
|
26
|
+
appName: ev.appName,
|
|
27
|
+
startMs: clippedStart,
|
|
28
|
+
endMs: clippedEnd,
|
|
29
|
+
windowTitle: ev.windowTitle
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
return intervals;
|
|
33
|
+
}
|
|
34
|
+
function aggregateByApp(intervals, redactor, limit) {
|
|
35
|
+
const byKey = /* @__PURE__ */ new Map();
|
|
36
|
+
let totalMs = 0;
|
|
37
|
+
for (const it of intervals) {
|
|
38
|
+
const key = it.bundleId || it.appName;
|
|
39
|
+
const durationMs = it.endMs - it.startMs;
|
|
40
|
+
totalMs += durationMs;
|
|
41
|
+
let bucket = byKey.get(key);
|
|
42
|
+
if (!bucket) {
|
|
43
|
+
bucket = {
|
|
44
|
+
bundleId: it.bundleId,
|
|
45
|
+
appName: it.appName,
|
|
46
|
+
totalMs: 0,
|
|
47
|
+
sessionCount: 0,
|
|
48
|
+
titles: /* @__PURE__ */ new Set()
|
|
49
|
+
};
|
|
50
|
+
byKey.set(key, bucket);
|
|
51
|
+
}
|
|
52
|
+
bucket.totalMs += durationMs;
|
|
53
|
+
bucket.sessionCount += 1;
|
|
54
|
+
const redacted = redactWindowTitle(it.windowTitle, redactor);
|
|
55
|
+
if (redacted !== null && redacted.length > 0 && bucket.titles.size < 5) {
|
|
56
|
+
bucket.titles.add(redacted);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
const apps = [...byKey.values()].map((b) => ({
|
|
60
|
+
bundleId: b.bundleId,
|
|
61
|
+
appName: b.appName,
|
|
62
|
+
totalMs: b.totalMs,
|
|
63
|
+
sessionCount: b.sessionCount,
|
|
64
|
+
sampleWindowTitles: [...b.titles]
|
|
65
|
+
})).sort((a, b) => b.totalMs - a.totalMs);
|
|
66
|
+
return {
|
|
67
|
+
apps: limit ? apps.slice(0, limit) : apps,
|
|
68
|
+
totalMs
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
async function getActivityReportBetween(runtime, agentId, options) {
|
|
72
|
+
const sinceMs = Math.max(0, Math.trunc(options.sinceMs));
|
|
73
|
+
const untilMs = Math.max(sinceMs, Math.trunc(options.untilMs));
|
|
74
|
+
const redactor = options.redactor ?? resolveRedactorConfigFromEnv();
|
|
75
|
+
const events = await listActivityEvents(
|
|
76
|
+
runtime,
|
|
77
|
+
agentId,
|
|
78
|
+
new Date(sinceMs).toISOString()
|
|
79
|
+
);
|
|
80
|
+
const intervals = intervalsFromEvents(events, sinceMs, untilMs);
|
|
81
|
+
const { apps, totalMs } = aggregateByApp(intervals, redactor, options.limit);
|
|
82
|
+
return { sinceMs, untilMs, totalMs, apps };
|
|
83
|
+
}
|
|
84
|
+
async function getActivityReport(runtime, agentId, options) {
|
|
85
|
+
const nowMs = options.nowMs ?? Date.now();
|
|
86
|
+
return getActivityReportBetween(runtime, agentId, {
|
|
87
|
+
sinceMs: nowMs - options.windowMs,
|
|
88
|
+
untilMs: nowMs,
|
|
89
|
+
limit: options.limit,
|
|
90
|
+
redactor: options.redactor
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
async function getTimeOnApp(runtime, agentId, appNameOrBundleId, options) {
|
|
94
|
+
const needle = appNameOrBundleId.trim().toLowerCase();
|
|
95
|
+
if (!needle) return { totalMs: 0, matchedBy: "none" };
|
|
96
|
+
const report = await getActivityReport(runtime, agentId, {
|
|
97
|
+
windowMs: options.windowMs,
|
|
98
|
+
nowMs: options.nowMs,
|
|
99
|
+
redactor: options.redactor
|
|
100
|
+
});
|
|
101
|
+
let totalMs = 0;
|
|
102
|
+
let matchedBy = "none";
|
|
103
|
+
for (const app of report.apps) {
|
|
104
|
+
if (app.bundleId.toLowerCase() === needle) {
|
|
105
|
+
totalMs += app.totalMs;
|
|
106
|
+
matchedBy = "bundleId";
|
|
107
|
+
} else if (app.appName.toLowerCase() === needle) {
|
|
108
|
+
totalMs += app.totalMs;
|
|
109
|
+
if (matchedBy === "none") matchedBy = "appName";
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
return { totalMs, matchedBy };
|
|
113
|
+
}
|
|
114
|
+
export {
|
|
115
|
+
getActivityReport,
|
|
116
|
+
getActivityReportBetween,
|
|
117
|
+
getTimeOnApp
|
|
118
|
+
};
|
|
119
|
+
//# sourceMappingURL=activity-tracker-reporting.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/activity-profile/activity-tracker-reporting.ts"],"sourcesContent":["/**\n * Reporting layer for T8d activity tracker.\n *\n * Converts the append-only `life_activity_events` stream into per-app dwell\n * summaries. New repository writes do not persist raw window titles; any\n * legacy titles are passed through {@link redactWindowTitle} before reporting.\n *\n * Duration model:\n * - Events are sorted ascending by observed_at.\n * - Each `activate` anchors a dwell interval; the interval ends at the\n * timestamp of the NEXT event (activate or deactivate), or at `now`\n * if no following event exists.\n * - `deactivate` events do not anchor a new interval.\n * - Intervals are clipped to the report window [since, until].\n */\n\nimport type { IAgentRuntime } from \"@elizaos/core\";\nimport {\n type ActivityEventRow,\n listActivityEvents,\n} from \"./activity-tracker-repo.js\";\nimport {\n type RedactorConfig,\n redactWindowTitle,\n resolveRedactorConfigFromEnv,\n} from \"./redactor.js\";\nimport { isSystemInactivityApp } from \"@elizaos/plugin-health\";\n\nexport interface ActivityAppBreakdown {\n bundleId: string;\n appName: string;\n totalMs: number;\n sessionCount: number;\n sampleWindowTitles: string[];\n}\n\nexport interface ActivityReport {\n sinceMs: number;\n untilMs: number;\n totalMs: number;\n apps: ActivityAppBreakdown[];\n}\n\nexport interface ActivityReportOptions {\n windowMs: number;\n nowMs?: number;\n limit?: number;\n redactor?: RedactorConfig;\n}\n\ninterface DwellInterval {\n bundleId: string;\n appName: string;\n startMs: number;\n endMs: number;\n windowTitle: string | null;\n}\n\nfunction intervalsFromEvents(\n events: ActivityEventRow[],\n sinceMs: number,\n untilMs: number,\n): DwellInterval[] {\n const intervals: DwellInterval[] = [];\n const timestamps: number[] = events.map((e) => Date.parse(e.observedAt));\n\n for (let i = 0; i < events.length; i++) {\n const ev = events[i];\n if (!ev) continue;\n if (ev.eventKind !== \"activate\") continue;\n if (isSystemInactivityApp(ev)) continue;\n const startMs = timestamps[i];\n if (typeof startMs !== \"number\" || !Number.isFinite(startMs)) continue;\n const nextTs = i + 1 < events.length ? timestamps[i + 1] : untilMs;\n const endMs =\n typeof nextTs === \"number\" && Number.isFinite(nextTs) ? nextTs : untilMs;\n const clippedStart = Math.max(startMs, sinceMs);\n const clippedEnd = Math.min(endMs, untilMs);\n if (clippedEnd <= clippedStart) continue;\n intervals.push({\n bundleId: ev.bundleId,\n appName: ev.appName,\n startMs: clippedStart,\n endMs: clippedEnd,\n windowTitle: ev.windowTitle,\n });\n }\n return intervals;\n}\n\nfunction aggregateByApp(\n intervals: DwellInterval[],\n redactor: RedactorConfig,\n limit: number | undefined,\n): { apps: ActivityAppBreakdown[]; totalMs: number } {\n const byKey = new Map<\n string,\n {\n bundleId: string;\n appName: string;\n totalMs: number;\n sessionCount: number;\n titles: Set<string>;\n }\n >();\n let totalMs = 0;\n for (const it of intervals) {\n const key = it.bundleId || it.appName;\n const durationMs = it.endMs - it.startMs;\n totalMs += durationMs;\n let bucket = byKey.get(key);\n if (!bucket) {\n bucket = {\n bundleId: it.bundleId,\n appName: it.appName,\n totalMs: 0,\n sessionCount: 0,\n titles: new Set<string>(),\n };\n byKey.set(key, bucket);\n }\n bucket.totalMs += durationMs;\n bucket.sessionCount += 1;\n const redacted = redactWindowTitle(it.windowTitle, redactor);\n if (redacted !== null && redacted.length > 0 && bucket.titles.size < 5) {\n bucket.titles.add(redacted);\n }\n }\n const apps = [...byKey.values()]\n .map((b) => ({\n bundleId: b.bundleId,\n appName: b.appName,\n totalMs: b.totalMs,\n sessionCount: b.sessionCount,\n sampleWindowTitles: [...b.titles],\n }))\n .sort((a, b) => b.totalMs - a.totalMs);\n return {\n apps: limit ? apps.slice(0, limit) : apps,\n totalMs,\n };\n}\n\nexport async function getActivityReportBetween(\n runtime: IAgentRuntime,\n agentId: string,\n options: {\n sinceMs: number;\n untilMs: number;\n limit?: number;\n redactor?: RedactorConfig;\n },\n): Promise<ActivityReport> {\n const sinceMs = Math.max(0, Math.trunc(options.sinceMs));\n const untilMs = Math.max(sinceMs, Math.trunc(options.untilMs));\n const redactor = options.redactor ?? resolveRedactorConfigFromEnv();\n const events = await listActivityEvents(\n runtime,\n agentId,\n new Date(sinceMs).toISOString(),\n );\n const intervals = intervalsFromEvents(events, sinceMs, untilMs);\n const { apps, totalMs } = aggregateByApp(intervals, redactor, options.limit);\n return { sinceMs, untilMs, totalMs, apps };\n}\n\nexport async function getActivityReport(\n runtime: IAgentRuntime,\n agentId: string,\n options: ActivityReportOptions,\n): Promise<ActivityReport> {\n const nowMs = options.nowMs ?? Date.now();\n return getActivityReportBetween(runtime, agentId, {\n sinceMs: nowMs - options.windowMs,\n untilMs: nowMs,\n limit: options.limit,\n redactor: options.redactor,\n });\n}\n\nexport async function getTimeOnApp(\n runtime: IAgentRuntime,\n agentId: string,\n appNameOrBundleId: string,\n options: { windowMs: number; nowMs?: number; redactor?: RedactorConfig },\n): Promise<{ totalMs: number; matchedBy: \"bundleId\" | \"appName\" | \"none\" }> {\n const needle = appNameOrBundleId.trim().toLowerCase();\n if (!needle) return { totalMs: 0, matchedBy: \"none\" };\n const report = await getActivityReport(runtime, agentId, {\n windowMs: options.windowMs,\n nowMs: options.nowMs,\n redactor: options.redactor,\n });\n let totalMs = 0;\n let matchedBy: \"bundleId\" | \"appName\" | \"none\" = \"none\";\n for (const app of report.apps) {\n if (app.bundleId.toLowerCase() === needle) {\n totalMs += app.totalMs;\n matchedBy = \"bundleId\";\n } else if (app.appName.toLowerCase() === needle) {\n totalMs += app.totalMs;\n if (matchedBy === \"none\") matchedBy = \"appName\";\n }\n }\n return { totalMs, matchedBy };\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* T8d — Activity tracker service.
|
|
3
|
+
*
|
|
4
|
+
* Starts the macOS Swift collector (when available) and writes focus events
|
|
5
|
+
* to `life_activity_events`. On non-Darwin platforms the service is a no-op
|
|
6
|
+
* that logs "no events" once at startup and returns empty reports via the
|
|
7
|
+
* action layer.
|
|
8
|
+
*
|
|
9
|
+
* The service does not mutate any cached profile state; reporting runs on
|
|
10
|
+
* demand via {@link getActivityReport}.
|
|
11
|
+
*/
|
|
12
|
+
import { type IAgentRuntime, Service } from "@elizaos/core";
|
|
13
|
+
export type ActivityTrackerMode = "running" | "disabled-config" | "disabled-non-darwin" | "stopped" | "failed";
|
|
14
|
+
export declare class ActivityTrackerService extends Service {
|
|
15
|
+
static readonly serviceType = "activity_tracker";
|
|
16
|
+
capabilityDescription: string;
|
|
17
|
+
private handle;
|
|
18
|
+
private mode;
|
|
19
|
+
private writeFailures;
|
|
20
|
+
private writeQueue;
|
|
21
|
+
static start(runtime: IAgentRuntime): Promise<ActivityTrackerService>;
|
|
22
|
+
stop(): Promise<void>;
|
|
23
|
+
getMode(): ActivityTrackerMode;
|
|
24
|
+
private startCollector;
|
|
25
|
+
private enqueueEvent;
|
|
26
|
+
private persistEvent;
|
|
27
|
+
private enqueueIdleSample;
|
|
28
|
+
/**
|
|
29
|
+
* Persist a HID idle sample as a `desktop_interaction` activity signal.
|
|
30
|
+
* The scorer reads `idleTimeSeconds` from the latest signal to distinguish
|
|
31
|
+
* passive-media (high idle) from active-use (low idle) per the
|
|
32
|
+
* shared-device-safety rule in `awake-probability.ts`.
|
|
33
|
+
*/
|
|
34
|
+
private persistIdleSample;
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=activity-tracker-service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity-tracker-service.d.ts","sourceRoot":"","sources":["../../src/activity-profile/activity-tracker-service.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,KAAK,aAAa,EAAU,OAAO,EAAE,MAAM,eAAe,CAAC;AAQpE,MAAM,MAAM,mBAAmB,GAC3B,SAAS,GACT,iBAAiB,GACjB,qBAAqB,GACrB,SAAS,GACT,QAAQ,CAAC;AAwCb,qBAAa,sBAAuB,SAAQ,OAAO;IACjD,gBAAyB,WAAW,sBAAsB;IAEjD,qBAAqB,SAC0F;IAExH,OAAO,CAAC,MAAM,CAAwC;IACtD,OAAO,CAAC,IAAI,CAA8C;IAC1D,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,UAAU,CAAoC;WAEhC,KAAK,CACzB,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,sBAAsB,CAAC;IAMnB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAQpC,OAAO,IAAI,mBAAmB;YAIhB,cAAc;IAkE5B,OAAO,CAAC,YAAY;YAON,YAAY;IAmC1B,OAAO,CAAC,iBAAiB;IAOzB;;;;;OAKG;YACW,iBAAiB;CA+ChC"}
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
import { logger, Service } from "@elizaos/core";
|
|
2
|
+
import {
|
|
3
|
+
createLifeOpsActivitySignal,
|
|
4
|
+
LifeOpsRepository
|
|
5
|
+
} from "../lifeops/repository.js";
|
|
6
|
+
import { insertActivityEvent } from "./activity-tracker-repo.js";
|
|
7
|
+
import { isSystemInactivityApp } from "@elizaos/plugin-health";
|
|
8
|
+
async function loadActivityTrackerModule() {
|
|
9
|
+
try {
|
|
10
|
+
return await import("@elizaos/native-activity-tracker");
|
|
11
|
+
} catch {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
class ActivityTrackerService extends Service {
|
|
16
|
+
static serviceType = "activity_tracker";
|
|
17
|
+
capabilityDescription = "T8d \u2014 macOS activity tracker. Records per-app focus transitions to life_activity_events for WakaTime-style reports.";
|
|
18
|
+
handle = null;
|
|
19
|
+
mode = "disabled-non-darwin";
|
|
20
|
+
writeFailures = 0;
|
|
21
|
+
writeQueue = Promise.resolve();
|
|
22
|
+
static async start(runtime) {
|
|
23
|
+
const service = new ActivityTrackerService(runtime);
|
|
24
|
+
await service.startCollector();
|
|
25
|
+
return service;
|
|
26
|
+
}
|
|
27
|
+
async stop() {
|
|
28
|
+
if (this.handle) {
|
|
29
|
+
await this.handle.stop();
|
|
30
|
+
this.handle = null;
|
|
31
|
+
}
|
|
32
|
+
await this.writeQueue;
|
|
33
|
+
}
|
|
34
|
+
getMode() {
|
|
35
|
+
return this.mode;
|
|
36
|
+
}
|
|
37
|
+
async startCollector() {
|
|
38
|
+
if (process.env.ELIZA_DISABLE_ACTIVITY_TRACKER === "1") {
|
|
39
|
+
this.mode = "disabled-config";
|
|
40
|
+
logger.info(
|
|
41
|
+
"[activity-tracker] Collector disabled by configuration; reports will use seeded data only."
|
|
42
|
+
);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
const tracker = await loadActivityTrackerModule();
|
|
46
|
+
if (!tracker) {
|
|
47
|
+
this.mode = "disabled-config";
|
|
48
|
+
logger.info(
|
|
49
|
+
"[activity-tracker] Native collector package unavailable; reports will use seeded data only."
|
|
50
|
+
);
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
if (!tracker.isSupportedPlatform()) {
|
|
54
|
+
this.mode = "disabled-non-darwin";
|
|
55
|
+
logger.info(
|
|
56
|
+
{ platform: process.platform },
|
|
57
|
+
"[activity-tracker] Non-Darwin platform \u2014 collector disabled; reports will be empty."
|
|
58
|
+
);
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
try {
|
|
62
|
+
await LifeOpsRepository.bootstrapSchema(this.runtime);
|
|
63
|
+
this.handle = tracker.startActivityCollector({
|
|
64
|
+
onEvent: (event) => {
|
|
65
|
+
this.enqueueEvent(event);
|
|
66
|
+
},
|
|
67
|
+
onIdleSample: (sample) => {
|
|
68
|
+
this.enqueueIdleSample(sample);
|
|
69
|
+
},
|
|
70
|
+
onExit: (exit) => {
|
|
71
|
+
this.mode = "stopped";
|
|
72
|
+
logger.info(
|
|
73
|
+
{ reason: exit.reason },
|
|
74
|
+
"[activity-tracker] Collector exited cleanly; events will stop flowing."
|
|
75
|
+
);
|
|
76
|
+
},
|
|
77
|
+
onFatal: (reason) => {
|
|
78
|
+
this.mode = "failed";
|
|
79
|
+
logger.error(
|
|
80
|
+
{ reason },
|
|
81
|
+
"[activity-tracker] Collector terminated \u2014 events will stop flowing."
|
|
82
|
+
);
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
this.mode = "running";
|
|
86
|
+
logger.info(
|
|
87
|
+
{ pid: this.handle.pid },
|
|
88
|
+
"[activity-tracker] macOS collector running."
|
|
89
|
+
);
|
|
90
|
+
} catch (err) {
|
|
91
|
+
this.mode = "failed";
|
|
92
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
93
|
+
logger.warn(
|
|
94
|
+
{ err: message },
|
|
95
|
+
"[activity-tracker] Failed to initialize macOS collector; reports will be empty until resolved."
|
|
96
|
+
);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
enqueueEvent(event) {
|
|
100
|
+
this.writeQueue = this.writeQueue.then(
|
|
101
|
+
() => this.persistEvent(event),
|
|
102
|
+
() => this.persistEvent(event)
|
|
103
|
+
);
|
|
104
|
+
}
|
|
105
|
+
async persistEvent(event) {
|
|
106
|
+
const runtime = this.runtime;
|
|
107
|
+
if (!runtime) return;
|
|
108
|
+
const agentId = String(runtime.agentId);
|
|
109
|
+
const observedAt = new Date(event.ts).toISOString();
|
|
110
|
+
const rawEventKind = isSystemInactivityApp({
|
|
111
|
+
bundleId: event.bundleId,
|
|
112
|
+
appName: event.appName,
|
|
113
|
+
platform: process.platform
|
|
114
|
+
}) ? "deactivate" : event.event;
|
|
115
|
+
const eventKind = rawEventKind === "activate" ? "activate" : "deactivate";
|
|
116
|
+
try {
|
|
117
|
+
await insertActivityEvent(runtime, {
|
|
118
|
+
agentId,
|
|
119
|
+
observedAt,
|
|
120
|
+
eventKind,
|
|
121
|
+
bundleId: event.bundleId ?? "",
|
|
122
|
+
appName: event.appName ?? "",
|
|
123
|
+
windowTitle: event.windowTitle ?? null
|
|
124
|
+
});
|
|
125
|
+
this.writeFailures = 0;
|
|
126
|
+
} catch (err) {
|
|
127
|
+
this.writeFailures += 1;
|
|
128
|
+
if (this.writeFailures <= 3) {
|
|
129
|
+
logger.error(
|
|
130
|
+
{ err: err instanceof Error ? err.message : String(err) },
|
|
131
|
+
"[activity-tracker] Failed to persist activity event."
|
|
132
|
+
);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
enqueueIdleSample(sample) {
|
|
137
|
+
this.writeQueue = this.writeQueue.then(
|
|
138
|
+
() => this.persistIdleSample(sample),
|
|
139
|
+
() => this.persistIdleSample(sample)
|
|
140
|
+
);
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Persist a HID idle sample as a `desktop_interaction` activity signal.
|
|
144
|
+
* The scorer reads `idleTimeSeconds` from the latest signal to distinguish
|
|
145
|
+
* passive-media (high idle) from active-use (low idle) per the
|
|
146
|
+
* shared-device-safety rule in `awake-probability.ts`.
|
|
147
|
+
*/
|
|
148
|
+
async persistIdleSample(sample) {
|
|
149
|
+
const runtime = this.runtime;
|
|
150
|
+
if (!runtime) return;
|
|
151
|
+
const agentId = String(runtime.agentId);
|
|
152
|
+
const observedAt = new Date(sample.ts).toISOString();
|
|
153
|
+
const idleSeconds = Math.max(0, Math.round(sample.idleSeconds));
|
|
154
|
+
try {
|
|
155
|
+
const repository = new LifeOpsRepository(runtime);
|
|
156
|
+
await repository.createActivitySignal(
|
|
157
|
+
createLifeOpsActivitySignal({
|
|
158
|
+
agentId,
|
|
159
|
+
source: "desktop_interaction",
|
|
160
|
+
platform: "macos_activity_collector",
|
|
161
|
+
state: idleSeconds <= 60 ? "active" : idleSeconds <= 300 ? "idle" : "background",
|
|
162
|
+
observedAt,
|
|
163
|
+
idleState: idleSeconds <= 60 ? "active" : idleSeconds <= 300 ? "idle" : "unknown",
|
|
164
|
+
idleTimeSeconds: idleSeconds,
|
|
165
|
+
onBattery: null,
|
|
166
|
+
health: null,
|
|
167
|
+
metadata: {
|
|
168
|
+
source: "activity_collector_hid_idle"
|
|
169
|
+
}
|
|
170
|
+
})
|
|
171
|
+
);
|
|
172
|
+
this.writeFailures = 0;
|
|
173
|
+
} catch (err) {
|
|
174
|
+
this.writeFailures += 1;
|
|
175
|
+
if (this.writeFailures <= 3) {
|
|
176
|
+
logger.error(
|
|
177
|
+
{ err: err instanceof Error ? err.message : String(err) },
|
|
178
|
+
"[activity-tracker] Failed to persist idle sample."
|
|
179
|
+
);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
export {
|
|
185
|
+
ActivityTrackerService
|
|
186
|
+
};
|
|
187
|
+
//# sourceMappingURL=activity-tracker-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/activity-profile/activity-tracker-service.ts"],"sourcesContent":["/**\n * T8d — Activity tracker service.\n *\n * Starts the macOS Swift collector (when available) and writes focus events\n * to `life_activity_events`. On non-Darwin platforms the service is a no-op\n * that logs \"no events\" once at startup and returns empty reports via the\n * action layer.\n *\n * The service does not mutate any cached profile state; reporting runs on\n * demand via {@link getActivityReport}.\n */\n\nimport { type IAgentRuntime, logger, Service } from \"@elizaos/core\";\nimport {\n createLifeOpsActivitySignal,\n LifeOpsRepository,\n} from \"../lifeops/repository.js\";\nimport { insertActivityEvent } from \"./activity-tracker-repo.js\";\nimport { isSystemInactivityApp } from \"@elizaos/plugin-health\";\n\nexport type ActivityTrackerMode =\n | \"running\"\n | \"disabled-config\"\n | \"disabled-non-darwin\"\n | \"stopped\"\n | \"failed\";\n\ninterface ActivityCollectorEvent {\n ts: number;\n bundleId?: string;\n appName?: string;\n windowTitle?: string | null;\n event: \"activate\" | \"deactivate\" | string;\n}\n\ninterface ActivityCollectorIdleSample {\n ts: number;\n idleSeconds: number;\n}\n\ninterface ActivityCollectorHandle {\n pid?: number;\n stop: () => Promise<void> | void;\n}\n\ntype ActivityTrackerModule = {\n isSupportedPlatform: () => boolean;\n startActivityCollector: (opts: {\n onEvent: (event: ActivityCollectorEvent) => void;\n onIdleSample: (sample: ActivityCollectorIdleSample) => void;\n onExit: (exit: { reason?: string }) => void;\n onFatal: (reason: string) => void;\n }) => ActivityCollectorHandle;\n};\n\nasync function loadActivityTrackerModule(): Promise<ActivityTrackerModule | null> {\n try {\n return (await import(\n \"@elizaos/native-activity-tracker\"\n )) as ActivityTrackerModule;\n } catch {\n return null;\n }\n}\n\nexport class ActivityTrackerService extends Service {\n static override readonly serviceType = \"activity_tracker\";\n\n override capabilityDescription =\n \"T8d — macOS activity tracker. Records per-app focus transitions to life_activity_events for WakaTime-style reports.\";\n\n private handle: ActivityCollectorHandle | null = null;\n private mode: ActivityTrackerMode = \"disabled-non-darwin\";\n private writeFailures = 0;\n private writeQueue: Promise<void> = Promise.resolve();\n\n static override async start(\n runtime: IAgentRuntime,\n ): Promise<ActivityTrackerService> {\n const service = new ActivityTrackerService(runtime);\n await service.startCollector();\n return service;\n }\n\n override async stop(): Promise<void> {\n if (this.handle) {\n await this.handle.stop();\n this.handle = null;\n }\n await this.writeQueue;\n }\n\n getMode(): ActivityTrackerMode {\n return this.mode;\n }\n\n private async startCollector(): Promise<void> {\n if (process.env.ELIZA_DISABLE_ACTIVITY_TRACKER === \"1\") {\n this.mode = \"disabled-config\";\n logger.info(\n \"[activity-tracker] Collector disabled by configuration; reports will use seeded data only.\",\n );\n return;\n }\n\n const tracker = await loadActivityTrackerModule();\n if (!tracker) {\n this.mode = \"disabled-config\";\n logger.info(\n \"[activity-tracker] Native collector package unavailable; reports will use seeded data only.\",\n );\n return;\n }\n\n if (!tracker.isSupportedPlatform()) {\n this.mode = \"disabled-non-darwin\";\n logger.info(\n { platform: process.platform },\n \"[activity-tracker] Non-Darwin platform — collector disabled; reports will be empty.\",\n );\n return;\n }\n\n try {\n await LifeOpsRepository.bootstrapSchema(this.runtime);\n this.handle = tracker.startActivityCollector({\n onEvent: (event) => {\n this.enqueueEvent(event);\n },\n onIdleSample: (sample) => {\n this.enqueueIdleSample(sample);\n },\n onExit: (exit) => {\n this.mode = \"stopped\";\n logger.info(\n { reason: exit.reason },\n \"[activity-tracker] Collector exited cleanly; events will stop flowing.\",\n );\n },\n onFatal: (reason) => {\n this.mode = \"failed\";\n logger.error(\n { reason },\n \"[activity-tracker] Collector terminated — events will stop flowing.\",\n );\n },\n });\n this.mode = \"running\";\n logger.info(\n { pid: this.handle.pid },\n \"[activity-tracker] macOS collector running.\",\n );\n } catch (err) {\n this.mode = \"failed\";\n const message = err instanceof Error ? err.message : String(err);\n logger.warn(\n { err: message },\n \"[activity-tracker] Failed to initialize macOS collector; reports will be empty until resolved.\",\n );\n }\n }\n\n private enqueueEvent(event: ActivityCollectorEvent): void {\n this.writeQueue = this.writeQueue.then(\n () => this.persistEvent(event),\n () => this.persistEvent(event),\n );\n }\n\n private async persistEvent(event: ActivityCollectorEvent): Promise<void> {\n const runtime = this.runtime;\n if (!runtime) return;\n const agentId = String(runtime.agentId);\n const observedAt = new Date(event.ts).toISOString();\n const rawEventKind = isSystemInactivityApp({\n bundleId: event.bundleId,\n appName: event.appName,\n platform: process.platform,\n })\n ? \"deactivate\"\n : event.event;\n const eventKind: \"activate\" | \"deactivate\" =\n rawEventKind === \"activate\" ? \"activate\" : \"deactivate\";\n try {\n await insertActivityEvent(runtime, {\n agentId,\n observedAt,\n eventKind,\n bundleId: event.bundleId ?? \"\",\n appName: event.appName ?? \"\",\n windowTitle: event.windowTitle ?? null,\n });\n this.writeFailures = 0;\n } catch (err) {\n this.writeFailures += 1;\n if (this.writeFailures <= 3) {\n logger.error(\n { err: err instanceof Error ? err.message : String(err) },\n \"[activity-tracker] Failed to persist activity event.\",\n );\n }\n }\n }\n\n private enqueueIdleSample(sample: ActivityCollectorIdleSample): void {\n this.writeQueue = this.writeQueue.then(\n () => this.persistIdleSample(sample),\n () => this.persistIdleSample(sample),\n );\n }\n\n /**\n * Persist a HID idle sample as a `desktop_interaction` activity signal.\n * The scorer reads `idleTimeSeconds` from the latest signal to distinguish\n * passive-media (high idle) from active-use (low idle) per the\n * shared-device-safety rule in `awake-probability.ts`.\n */\n private async persistIdleSample(\n sample: ActivityCollectorIdleSample,\n ): Promise<void> {\n const runtime = this.runtime;\n if (!runtime) return;\n const agentId = String(runtime.agentId);\n const observedAt = new Date(sample.ts).toISOString();\n const idleSeconds = Math.max(0, Math.round(sample.idleSeconds));\n try {\n const repository = new LifeOpsRepository(runtime);\n await repository.createActivitySignal(\n createLifeOpsActivitySignal({\n agentId,\n source: \"desktop_interaction\",\n platform: \"macos_activity_collector\",\n state:\n idleSeconds <= 60\n ? \"active\"\n : idleSeconds <= 300\n ? \"idle\"\n : \"background\",\n observedAt,\n idleState:\n idleSeconds <= 60\n ? \"active\"\n : idleSeconds <= 300\n ? \"idle\"\n : \"unknown\",\n idleTimeSeconds: idleSeconds,\n onBattery: null,\n health: null,\n metadata: {\n source: \"activity_collector_hid_idle\",\n },\n }),\n );\n this.writeFailures = 0;\n } catch (err) {\n this.writeFailures += 1;\n if (this.writeFailures <= 3) {\n logger.error(\n { err: err instanceof Error ? err.message : String(err) },\n \"[activity-tracker] Failed to persist idle sample.\",\n );\n }\n }\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { type ActivityProfile, type ActivitySignalRecord, type TimeBucket } from "./types.js";
|
|
2
|
+
export declare function classifyTimeBucket(hour: number): TimeBucket;
|
|
3
|
+
export declare function resolveCurrentBucket(timezone: string, now?: Date): TimeBucket;
|
|
4
|
+
export interface MessageRecord {
|
|
5
|
+
entityId: string;
|
|
6
|
+
roomId: string;
|
|
7
|
+
createdAt: number;
|
|
8
|
+
}
|
|
9
|
+
export interface CalendarEventRecord {
|
|
10
|
+
startAt: string;
|
|
11
|
+
endAt: string;
|
|
12
|
+
isAllDay: boolean;
|
|
13
|
+
}
|
|
14
|
+
export declare const SUSTAINED_INACTIVITY_GAP_MS: number;
|
|
15
|
+
export type CurrentActivityState = Pick<ActivityProfile, "lastSeenAt" | "lastSeenPlatform" | "isCurrentlyActive" | "hasOpenActivityCycle" | "currentActivityCycleStartedAt" | "currentActivityCycleLocalDate" | "effectiveDayKey">;
|
|
16
|
+
export declare function resolveCurrentActivityState(profile: Pick<ActivityProfile, "timezone" | "lastSeenAt" | "lastSeenPlatform" | "isCurrentlySleeping" | "lastSleepSignalAt" | "lastWakeSignalAt" | "hasOpenActivityCycle" | "sustainedInactivityThresholdMinutes" | "currentActivityCycleStartedAt" | "currentActivityCycleLocalDate" | "screenContextAvailable" | "screenContextStale" | "screenContextFocus" | "screenContextSampledAt" | "screenContextConfidence">, now: Date): CurrentActivityState;
|
|
17
|
+
export declare function resolveEffectiveDayKey(profile: Pick<ActivityProfile, "hasOpenActivityCycle" | "currentActivityCycleStartedAt" | "currentActivityCycleLocalDate" | "lastSeenAt" | "lastSeenPlatform" | "isCurrentlySleeping" | "lastSleepSignalAt" | "lastWakeSignalAt" | "sustainedInactivityThresholdMinutes" | "screenContextAvailable" | "screenContextStale" | "screenContextFocus" | "screenContextSampledAt" | "screenContextConfidence">, timezone: string, now: Date): string;
|
|
18
|
+
export declare function analyzeMessages(messages: MessageRecord[], roomSourceMap: Map<string, string>, ownerEntityId: string, timezone: string, windowDays: number, now?: Date): Omit<ActivityProfile, "hasCalendarData" | "typicalFirstEventHour" | "typicalLastEventHour" | "avgWeekdayMeetings">;
|
|
19
|
+
export declare function analyzeMessages(messages: MessageRecord[], roomSourceMap: Map<string, string>, ownerEntityId: string, timezone: string, windowDays: number, now: Date, activitySignals: ActivitySignalRecord[]): Omit<ActivityProfile, "hasCalendarData" | "typicalFirstEventHour" | "typicalLastEventHour" | "avgWeekdayMeetings">;
|
|
20
|
+
export declare function analyzeMessages(messages: MessageRecord[], roomSourceMap: Map<string, string>, ownerEntityId: string, timezone: string, windowDays: number, activitySignals?: ActivitySignalRecord[], now?: Date): Omit<ActivityProfile, "hasCalendarData" | "typicalFirstEventHour" | "typicalLastEventHour" | "avgWeekdayMeetings">;
|
|
21
|
+
export declare function enrichWithCalendar(profile: Omit<ActivityProfile, "hasCalendarData" | "typicalFirstEventHour" | "typicalLastEventHour" | "avgWeekdayMeetings">, calendarEvents: CalendarEventRecord[], timezone: string): ActivityProfile;
|
|
22
|
+
export declare function wasActiveToday(profile: Pick<ActivityProfile, "hasOpenActivityCycle" | "currentActivityCycleStartedAt" | "currentActivityCycleLocalDate" | "lastSeenAt" | "lastSeenPlatform" | "sustainedInactivityThresholdMinutes" | "isCurrentlySleeping" | "lastSleepSignalAt" | "lastWakeSignalAt" | "screenContextAvailable" | "screenContextStale" | "screenContextFocus" | "screenContextSampledAt" | "screenContextConfidence">, timezone: string, now: Date): boolean;
|
|
23
|
+
//# sourceMappingURL=analyzer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"analyzer.d.ts","sourceRoot":"","sources":["../../src/activity-profile/analyzer.ts"],"names":[],"mappings":"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"}
|