@elizaos/plugin-personal-assistant 2.0.3-beta.6 → 2.0.3-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/app-block.d.ts +15 -0
- package/dist/actions/app-block.d.ts.map +1 -0
- package/dist/actions/app-block.js +349 -0
- package/dist/actions/app-block.js.map +1 -0
- package/dist/actions/autofill.d.ts +20 -0
- package/dist/actions/autofill.d.ts.map +1 -0
- package/dist/actions/autofill.js +370 -0
- package/dist/actions/autofill.js.map +1 -0
- package/dist/actions/block.d.ts +30 -0
- package/dist/actions/block.d.ts.map +1 -0
- package/dist/actions/block.js +326 -0
- package/dist/actions/block.js.map +1 -0
- package/dist/actions/book-travel.d.ts +10 -0
- package/dist/actions/book-travel.d.ts.map +1 -0
- package/dist/actions/book-travel.js +467 -0
- package/dist/actions/book-travel.js.map +1 -0
- package/dist/actions/brief.d.ts +60 -0
- package/dist/actions/brief.d.ts.map +1 -0
- package/dist/actions/brief.js +485 -0
- package/dist/actions/brief.js.map +1 -0
- package/dist/actions/calendar.d.ts +22 -0
- package/dist/actions/calendar.d.ts.map +1 -0
- package/dist/actions/calendar.js +832 -0
- package/dist/actions/calendar.js.map +1 -0
- package/dist/actions/conflict-detect.d.ts +67 -0
- package/dist/actions/conflict-detect.d.ts.map +1 -0
- package/dist/actions/conflict-detect.js +310 -0
- package/dist/actions/conflict-detect.js.map +1 -0
- package/dist/actions/connector.d.ts +5 -0
- package/dist/actions/connector.d.ts.map +1 -0
- package/dist/actions/connector.js +1354 -0
- package/dist/actions/connector.js.map +1 -0
- package/dist/actions/credentials.d.ts +14 -0
- package/dist/actions/credentials.d.ts.map +1 -0
- package/dist/actions/credentials.js +191 -0
- package/dist/actions/credentials.js.map +1 -0
- package/dist/actions/document.d.ts +36 -0
- package/dist/actions/document.d.ts.map +1 -0
- package/dist/actions/document.js +613 -0
- package/dist/actions/document.js.map +1 -0
- package/dist/actions/entity.d.ts +20 -0
- package/dist/actions/entity.d.ts.map +1 -0
- package/dist/actions/entity.js +785 -0
- package/dist/actions/entity.js.map +1 -0
- package/dist/actions/health.d.ts +4 -0
- package/dist/actions/health.d.ts.map +1 -0
- package/dist/actions/health.js +37 -0
- package/dist/actions/health.js.map +1 -0
- package/dist/actions/inbox.d.ts +12 -0
- package/dist/actions/inbox.d.ts.map +1 -0
- package/dist/actions/inbox.js +13 -0
- package/dist/actions/inbox.js.map +1 -0
- package/dist/actions/lib/calendly-handler.d.ts +3 -0
- package/dist/actions/lib/calendly-handler.d.ts.map +1 -0
- package/dist/actions/lib/calendly-handler.js +506 -0
- package/dist/actions/lib/calendly-handler.js.map +1 -0
- package/dist/actions/lib/extract-goal-plan.d.ts +69 -0
- package/dist/actions/lib/extract-goal-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-goal-plan.js +488 -0
- package/dist/actions/lib/extract-goal-plan.js.map +1 -0
- package/dist/actions/lib/extract-life-operation.d.ts +18 -0
- package/dist/actions/lib/extract-life-operation.d.ts.map +1 -0
- package/dist/actions/lib/extract-life-operation.js +318 -0
- package/dist/actions/lib/extract-life-operation.js.map +1 -0
- package/dist/actions/lib/extract-task-plan.d.ts +78 -0
- package/dist/actions/lib/extract-task-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-task-plan.js +355 -0
- package/dist/actions/lib/extract-task-plan.js.map +1 -0
- package/dist/actions/lib/extract-update-fields.d.ts +27 -0
- package/dist/actions/lib/extract-update-fields.d.ts.map +1 -0
- package/dist/actions/lib/extract-update-fields.js +172 -0
- package/dist/actions/lib/extract-update-fields.js.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts +68 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.js +315 -0
- package/dist/actions/lib/lifeops-deferred-draft.js.map +1 -0
- package/dist/actions/lib/messaging-helpers.d.ts +20 -0
- package/dist/actions/lib/messaging-helpers.d.ts.map +1 -0
- package/dist/actions/lib/messaging-helpers.js +103 -0
- package/dist/actions/lib/messaging-helpers.js.map +1 -0
- package/dist/actions/lib/owner-policy-writes.d.ts +49 -0
- package/dist/actions/lib/owner-policy-writes.d.ts.map +1 -0
- package/dist/actions/lib/owner-policy-writes.js +157 -0
- package/dist/actions/lib/owner-policy-writes.js.map +1 -0
- package/dist/actions/lib/prompt-format.d.ts +3 -0
- package/dist/actions/lib/prompt-format.d.ts.map +1 -0
- package/dist/actions/lib/prompt-format.js +42 -0
- package/dist/actions/lib/prompt-format.js.map +1 -0
- package/dist/actions/lib/scheduling-handler.d.ts +93 -0
- package/dist/actions/lib/scheduling-handler.d.ts.map +1 -0
- package/dist/actions/lib/scheduling-handler.js +868 -0
- package/dist/actions/lib/scheduling-handler.js.map +1 -0
- package/dist/actions/life.d.ts +13 -0
- package/dist/actions/life.d.ts.map +1 -0
- package/dist/actions/life.js +2524 -0
- package/dist/actions/life.js.map +1 -0
- package/dist/actions/money.d.ts +24 -0
- package/dist/actions/money.d.ts.map +1 -0
- package/dist/actions/money.js +41 -0
- package/dist/actions/money.js.map +1 -0
- package/dist/actions/owner-surfaces.d.ts +11 -0
- package/dist/actions/owner-surfaces.d.ts.map +1 -0
- package/dist/actions/owner-surfaces.js +493 -0
- package/dist/actions/owner-surfaces.js.map +1 -0
- package/dist/actions/password-manager.d.ts +10 -0
- package/dist/actions/password-manager.d.ts.map +1 -0
- package/dist/actions/password-manager.js +195 -0
- package/dist/actions/password-manager.js.map +1 -0
- package/dist/actions/payments.d.ts +10 -0
- package/dist/actions/payments.d.ts.map +1 -0
- package/dist/actions/payments.js +5 -0
- package/dist/actions/payments.js.map +1 -0
- package/dist/actions/prioritize.d.ts +49 -0
- package/dist/actions/prioritize.d.ts.map +1 -0
- package/dist/actions/prioritize.js +313 -0
- package/dist/actions/prioritize.js.map +1 -0
- package/dist/actions/remote-desktop.d.ts +13 -0
- package/dist/actions/remote-desktop.d.ts.map +1 -0
- package/dist/actions/remote-desktop.js +11 -0
- package/dist/actions/remote-desktop.js.map +1 -0
- package/dist/actions/resolve-request.d.ts +12 -0
- package/dist/actions/resolve-request.d.ts.map +1 -0
- package/dist/actions/resolve-request.js +427 -0
- package/dist/actions/resolve-request.js.map +1 -0
- package/dist/actions/schedule.d.ts +10 -0
- package/dist/actions/schedule.d.ts.map +1 -0
- package/dist/actions/schedule.js +113 -0
- package/dist/actions/schedule.js.map +1 -0
- package/dist/actions/scheduled-task.d.ts +32 -0
- package/dist/actions/scheduled-task.d.ts.map +1 -0
- package/dist/actions/scheduled-task.js +661 -0
- package/dist/actions/scheduled-task.js.map +1 -0
- package/dist/actions/screen-time.d.ts +4 -0
- package/dist/actions/screen-time.d.ts.map +1 -0
- package/dist/actions/screen-time.js +47 -0
- package/dist/actions/screen-time.js.map +1 -0
- package/dist/actions/subscriptions.d.ts +8 -0
- package/dist/actions/subscriptions.d.ts.map +1 -0
- package/dist/actions/subscriptions.js +327 -0
- package/dist/actions/subscriptions.js.map +1 -0
- package/dist/actions/voice-call.d.ts +16 -0
- package/dist/actions/voice-call.d.ts.map +1 -0
- package/dist/actions/voice-call.js +756 -0
- package/dist/actions/voice-call.js.map +1 -0
- package/dist/actions/website-block.d.ts +15 -0
- package/dist/actions/website-block.d.ts.map +1 -0
- package/dist/actions/website-block.js +719 -0
- package/dist/actions/website-block.js.map +1 -0
- package/dist/actions/work-thread.d.ts +5 -0
- package/dist/actions/work-thread.d.ts.map +1 -0
- package/dist/actions/work-thread.js +556 -0
- package/dist/actions/work-thread.js.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts +28 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.js +61 -0
- package/dist/activity-profile/activity-tracker-repo.js.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts +52 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.js +119 -0
- package/dist/activity-profile/activity-tracker-reporting.js.map +1 -0
- package/dist/activity-profile/activity-tracker-service.d.ts +36 -0
- package/dist/activity-profile/activity-tracker-service.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-service.js +187 -0
- package/dist/activity-profile/activity-tracker-service.js.map +1 -0
- package/dist/activity-profile/analyzer.d.ts +23 -0
- package/dist/activity-profile/analyzer.d.ts.map +1 -0
- package/dist/activity-profile/analyzer.js +485 -0
- package/dist/activity-profile/analyzer.js.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts +14 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.js +159 -0
- package/dist/activity-profile/presence-signal-bridge-service.js.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts +3 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.js +21 -0
- package/dist/activity-profile/proactive-inbox-digest.js.map +1 -0
- package/dist/activity-profile/proactive-planner.d.ts +150 -0
- package/dist/activity-profile/proactive-planner.d.ts.map +1 -0
- package/dist/activity-profile/proactive-planner.js +529 -0
- package/dist/activity-profile/proactive-planner.js.map +1 -0
- package/dist/activity-profile/proactive-worker.d.ts +33 -0
- package/dist/activity-profile/proactive-worker.d.ts.map +1 -0
- package/dist/activity-profile/proactive-worker.js +779 -0
- package/dist/activity-profile/proactive-worker.js.map +1 -0
- package/dist/activity-profile/profile-metadata.d.ts +10 -0
- package/dist/activity-profile/profile-metadata.d.ts.map +1 -0
- package/dist/activity-profile/profile-metadata.js +16 -0
- package/dist/activity-profile/profile-metadata.js.map +1 -0
- package/dist/activity-profile/redactor.d.ts +15 -0
- package/dist/activity-profile/redactor.d.ts.map +1 -0
- package/dist/activity-profile/redactor.js +22 -0
- package/dist/activity-profile/redactor.js.map +1 -0
- package/dist/activity-profile/service.d.ts +11 -0
- package/dist/activity-profile/service.d.ts.map +1 -0
- package/dist/activity-profile/service.js +272 -0
- package/dist/activity-profile/service.js.map +1 -0
- package/dist/activity-profile/types.d.ts +97 -0
- package/dist/activity-profile/types.d.ts.map +1 -0
- package/dist/activity-profile/types.js +36 -0
- package/dist/activity-profile/types.js.map +1 -0
- package/dist/agent-lifeops.d.ts +2 -0
- package/dist/agent-lifeops.d.ts.map +1 -0
- package/dist/agent-lifeops.js +2 -0
- package/dist/agent-lifeops.js.map +1 -0
- package/dist/api/client-lifeops.d.ts +319 -0
- package/dist/api/client-lifeops.d.ts.map +1 -0
- package/dist/api/client-lifeops.js +794 -0
- package/dist/api/client-lifeops.js.map +1 -0
- package/dist/automation-node-contributor.d.ts +2 -0
- package/dist/automation-node-contributor.d.ts.map +1 -0
- package/dist/automation-node-contributor.js +184 -0
- package/dist/automation-node-contributor.js.map +1 -0
- package/dist/client.d.ts +16 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +18 -0
- package/dist/client.js.map +1 -0
- package/dist/components/AppBlockerSettingsCard.d.ts +3 -0
- package/dist/components/AppBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/AppBlockerSettingsCard.js +538 -0
- package/dist/components/AppBlockerSettingsCard.js.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts +3 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.js +148 -0
- package/dist/components/WebsiteBlockerSettingsCard.js.map +1 -0
- package/dist/contracts/index.d.ts +2 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/index.js +2 -0
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/lifeops.d.ts +2 -0
- package/dist/contracts/lifeops.d.ts.map +1 -0
- package/dist/contracts/lifeops.js +2 -0
- package/dist/contracts/lifeops.js.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts +17 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.js +56 -0
- package/dist/default-packs/autofill-whitelist-pack.js.map +1 -0
- package/dist/default-packs/consolidation-policies.d.ts +14 -0
- package/dist/default-packs/consolidation-policies.d.ts.map +1 -0
- package/dist/default-packs/consolidation-policies.js +17 -0
- package/dist/default-packs/consolidation-policies.js.map +1 -0
- package/dist/default-packs/contract-types.d.ts +200 -0
- package/dist/default-packs/contract-types.d.ts.map +1 -0
- package/dist/default-packs/contract-types.js +1 -0
- package/dist/default-packs/contract-types.js.map +1 -0
- package/dist/default-packs/daily-rhythm.d.ts +28 -0
- package/dist/default-packs/daily-rhythm.d.ts.map +1 -0
- package/dist/default-packs/daily-rhythm.js +136 -0
- package/dist/default-packs/daily-rhythm.js.map +1 -0
- package/dist/default-packs/escalation-ladders.d.ts +18 -0
- package/dist/default-packs/escalation-ladders.d.ts.map +1 -0
- package/dist/default-packs/escalation-ladders.js +17 -0
- package/dist/default-packs/escalation-ladders.js.map +1 -0
- package/dist/default-packs/executive-assistant.d.ts +50 -0
- package/dist/default-packs/executive-assistant.d.ts.map +1 -0
- package/dist/default-packs/executive-assistant.js +745 -0
- package/dist/default-packs/executive-assistant.js.map +1 -0
- package/dist/default-packs/followup-starter.d.ts +49 -0
- package/dist/default-packs/followup-starter.d.ts.map +1 -0
- package/dist/default-packs/followup-starter.js +104 -0
- package/dist/default-packs/followup-starter.js.map +1 -0
- package/dist/default-packs/habit-starters.d.ts +37 -0
- package/dist/default-packs/habit-starters.d.ts.map +1 -0
- package/dist/default-packs/habit-starters.js +255 -0
- package/dist/default-packs/habit-starters.js.map +1 -0
- package/dist/default-packs/inbox-triage-starter.d.ts +23 -0
- package/dist/default-packs/inbox-triage-starter.d.ts.map +1 -0
- package/dist/default-packs/inbox-triage-starter.js +61 -0
- package/dist/default-packs/inbox-triage-starter.js.map +1 -0
- package/dist/default-packs/index.d.ts +54 -0
- package/dist/default-packs/index.d.ts.map +1 -0
- package/dist/default-packs/index.js +150 -0
- package/dist/default-packs/index.js.map +1 -0
- package/dist/default-packs/lint.d.ts +62 -0
- package/dist/default-packs/lint.d.ts.map +1 -0
- package/dist/default-packs/lint.js +161 -0
- package/dist/default-packs/lint.js.map +1 -0
- package/dist/default-packs/morning-brief.d.ts +44 -0
- package/dist/default-packs/morning-brief.d.ts.map +1 -0
- package/dist/default-packs/morning-brief.js +69 -0
- package/dist/default-packs/morning-brief.js.map +1 -0
- package/dist/default-packs/quiet-user-watcher.d.ts +49 -0
- package/dist/default-packs/quiet-user-watcher.d.ts.map +1 -0
- package/dist/default-packs/quiet-user-watcher.js +92 -0
- package/dist/default-packs/quiet-user-watcher.js.map +1 -0
- package/dist/default-packs/registry-types.d.ts +51 -0
- package/dist/default-packs/registry-types.d.ts.map +1 -0
- package/dist/default-packs/registry-types.js +1 -0
- package/dist/default-packs/registry-types.js.map +1 -0
- package/dist/default-packs/task-definitions.d.ts +88 -0
- package/dist/default-packs/task-definitions.d.ts.map +1 -0
- package/dist/default-packs/task-definitions.js +87 -0
- package/dist/default-packs/task-definitions.js.map +1 -0
- package/dist/events/index.d.ts +34 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +30 -0
- package/dist/events/index.js.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts +3 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.js +90 -0
- package/dist/followup/actions/listOverdueFollowups.js.map +1 -0
- package/dist/followup/actions/markFollowupDone.d.ts +3 -0
- package/dist/followup/actions/markFollowupDone.d.ts.map +1 -0
- package/dist/followup/actions/markFollowupDone.js +171 -0
- package/dist/followup/actions/markFollowupDone.js.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts +3 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.js +171 -0
- package/dist/followup/actions/setFollowupThreshold.js.map +1 -0
- package/dist/followup/followup-tracker.d.ts +83 -0
- package/dist/followup/followup-tracker.d.ts.map +1 -0
- package/dist/followup/followup-tracker.js +311 -0
- package/dist/followup/followup-tracker.js.map +1 -0
- package/dist/followup/index.d.ts +5 -0
- package/dist/followup/index.d.ts.map +1 -0
- package/dist/followup/index.js +39 -0
- package/dist/followup/index.js.map +1 -0
- package/dist/hooks/connector-error.d.ts +2 -0
- package/dist/hooks/connector-error.d.ts.map +1 -0
- package/dist/hooks/connector-error.js +13 -0
- package/dist/hooks/connector-error.js.map +1 -0
- package/dist/hooks/useDiscordConnector.d.ts +11 -0
- package/dist/hooks/useDiscordConnector.d.ts.map +1 -0
- package/dist/hooks/useDiscordConnector.js +95 -0
- package/dist/hooks/useDiscordConnector.js.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts +23 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js +630 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js.map +1 -0
- package/dist/hooks/useIMessageConnector.d.ts +10 -0
- package/dist/hooks/useIMessageConnector.d.ts.map +1 -0
- package/dist/hooks/useIMessageConnector.js +57 -0
- package/dist/hooks/useIMessageConnector.js.map +1 -0
- package/dist/hooks/useInbox.d.ts +36 -0
- package/dist/hooks/useInbox.d.ts.map +1 -0
- package/dist/hooks/useInbox.js +96 -0
- package/dist/hooks/useInbox.js.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts +2 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.js +358 -0
- package/dist/hooks/useLifeOpsActivitySignals.js.map +1 -0
- package/dist/hooks/useLifeOpsAppState.d.ts +9 -0
- package/dist/hooks/useLifeOpsAppState.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsAppState.js +79 -0
- package/dist/hooks/useLifeOpsAppState.js.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts +8 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js +60 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts +11 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.js +92 -0
- package/dist/hooks/useLifeOpsXConnector.js.map +1 -0
- package/dist/hooks/useSignalConnector.d.ts +14 -0
- package/dist/hooks/useSignalConnector.d.ts.map +1 -0
- package/dist/hooks/useSignalConnector.js +89 -0
- package/dist/hooks/useSignalConnector.js.map +1 -0
- package/dist/hooks/useTelegramConnector.d.ts +14 -0
- package/dist/hooks/useTelegramConnector.d.ts.map +1 -0
- package/dist/hooks/useTelegramConnector.js +97 -0
- package/dist/hooks/useTelegramConnector.js.map +1 -0
- package/dist/hooks/useWhatsAppConnector.d.ts +8 -0
- package/dist/hooks/useWhatsAppConnector.d.ts.map +1 -0
- package/dist/hooks/useWhatsAppConnector.js +62 -0
- package/dist/hooks/useWhatsAppConnector.js.map +1 -0
- package/dist/inbox/message-fetcher.d.ts +11 -0
- package/dist/inbox/message-fetcher.d.ts.map +1 -0
- package/dist/inbox/message-fetcher.js +13 -0
- package/dist/inbox/message-fetcher.js.map +1 -0
- package/dist/inbox/repository.d.ts +11 -0
- package/dist/inbox/repository.d.ts.map +1 -0
- package/dist/inbox/repository.js +5 -0
- package/dist/inbox/repository.js.map +1 -0
- package/dist/inbox/types.d.ts +10 -0
- package/dist/inbox/types.d.ts.map +1 -0
- package/dist/inbox/types.js +2 -0
- package/dist/inbox/types.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +188 -0
- package/dist/index.js.map +1 -0
- package/dist/lifeops/access.d.ts +29 -0
- package/dist/lifeops/access.d.ts.map +1 -0
- package/dist/lifeops/access.js +56 -0
- package/dist/lifeops/access.js.map +1 -0
- package/dist/lifeops/app-state.d.ts +22 -0
- package/dist/lifeops/app-state.d.ts.map +1 -0
- package/dist/lifeops/app-state.js +67 -0
- package/dist/lifeops/app-state.js.map +1 -0
- package/dist/lifeops/apple-reminders.d.ts +67 -0
- package/dist/lifeops/apple-reminders.d.ts.map +1 -0
- package/dist/lifeops/apple-reminders.js +396 -0
- package/dist/lifeops/apple-reminders.js.map +1 -0
- package/dist/lifeops/approval-queue.d.ts +38 -0
- package/dist/lifeops/approval-queue.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.js +575 -0
- package/dist/lifeops/approval-queue.js.map +1 -0
- package/dist/lifeops/approval-queue.types.d.ts +172 -0
- package/dist/lifeops/approval-queue.types.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.types.js +27 -0
- package/dist/lifeops/approval-queue.types.js.map +1 -0
- package/dist/lifeops/autofill-whitelist.d.ts +20 -0
- package/dist/lifeops/autofill-whitelist.d.ts.map +1 -0
- package/dist/lifeops/autofill-whitelist.js +59 -0
- package/dist/lifeops/autofill-whitelist.js.map +1 -0
- package/dist/lifeops/background-planner-dispatch.d.ts +60 -0
- package/dist/lifeops/background-planner-dispatch.d.ts.map +1 -0
- package/dist/lifeops/background-planner-dispatch.js +113 -0
- package/dist/lifeops/background-planner-dispatch.js.map +1 -0
- package/dist/lifeops/background-planner.d.ts +140 -0
- package/dist/lifeops/background-planner.d.ts.map +1 -0
- package/dist/lifeops/background-planner.js +359 -0
- package/dist/lifeops/background-planner.js.map +1 -0
- package/dist/lifeops/bill-extraction.d.ts +46 -0
- package/dist/lifeops/bill-extraction.d.ts.map +1 -0
- package/dist/lifeops/bill-extraction.js +325 -0
- package/dist/lifeops/bill-extraction.js.map +1 -0
- package/dist/lifeops/browser-constants.d.ts +4 -0
- package/dist/lifeops/browser-constants.d.ts.map +1 -0
- package/dist/lifeops/browser-constants.js +27 -0
- package/dist/lifeops/browser-constants.js.map +1 -0
- package/dist/lifeops/browser-extension-store.d.ts +61 -0
- package/dist/lifeops/browser-extension-store.d.ts.map +1 -0
- package/dist/lifeops/browser-extension-store.js +176 -0
- package/dist/lifeops/browser-extension-store.js.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts +57 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.js +308 -0
- package/dist/lifeops/browser-session-lifecycle.js.map +1 -0
- package/dist/lifeops/bulk-review.d.ts +333 -0
- package/dist/lifeops/bulk-review.d.ts.map +1 -0
- package/dist/lifeops/bulk-review.js +1120 -0
- package/dist/lifeops/bulk-review.js.map +1 -0
- package/dist/lifeops/calendar-gate.d.ts +20 -0
- package/dist/lifeops/calendar-gate.d.ts.map +1 -0
- package/dist/lifeops/calendar-gate.js +30 -0
- package/dist/lifeops/calendar-gate.js.map +1 -0
- package/dist/lifeops/channels/contract.d.ts +47 -0
- package/dist/lifeops/channels/contract.d.ts.map +1 -0
- package/dist/lifeops/channels/contract.js +1 -0
- package/dist/lifeops/channels/contract.js.map +1 -0
- package/dist/lifeops/channels/default-pack.d.ts +26 -0
- package/dist/lifeops/channels/default-pack.d.ts.map +1 -0
- package/dist/lifeops/channels/default-pack.js +243 -0
- package/dist/lifeops/channels/default-pack.js.map +1 -0
- package/dist/lifeops/channels/index.d.ts +5 -0
- package/dist/lifeops/channels/index.d.ts.map +1 -0
- package/dist/lifeops/channels/index.js +23 -0
- package/dist/lifeops/channels/index.js.map +1 -0
- package/dist/lifeops/channels/priority-posture.d.ts +36 -0
- package/dist/lifeops/channels/priority-posture.d.ts.map +1 -0
- package/dist/lifeops/channels/priority-posture.js +27 -0
- package/dist/lifeops/channels/priority-posture.js.map +1 -0
- package/dist/lifeops/channels/registry.d.ts +7 -0
- package/dist/lifeops/channels/registry.d.ts.map +1 -0
- package/dist/lifeops/channels/registry.js +49 -0
- package/dist/lifeops/channels/registry.js.map +1 -0
- package/dist/lifeops/checkin/checkin-service.d.ts +66 -0
- package/dist/lifeops/checkin/checkin-service.d.ts.map +1 -0
- package/dist/lifeops/checkin/checkin-service.js +1084 -0
- package/dist/lifeops/checkin/checkin-service.js.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts +17 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.js +26 -0
- package/dist/lifeops/checkin/schedule-resolver.js.map +1 -0
- package/dist/lifeops/checkin/types.d.ts +106 -0
- package/dist/lifeops/checkin/types.d.ts.map +1 -0
- package/dist/lifeops/checkin/types.js +1 -0
- package/dist/lifeops/checkin/types.js.map +1 -0
- package/dist/lifeops/connectors/_helpers.d.ts +51 -0
- package/dist/lifeops/connectors/_helpers.d.ts.map +1 -0
- package/dist/lifeops/connectors/_helpers.js +104 -0
- package/dist/lifeops/connectors/_helpers.js.map +1 -0
- package/dist/lifeops/connectors/calendly.d.ts +11 -0
- package/dist/lifeops/connectors/calendly.d.ts.map +1 -0
- package/dist/lifeops/connectors/calendly.js +61 -0
- package/dist/lifeops/connectors/calendly.js.map +1 -0
- package/dist/lifeops/connectors/contract.d.ts +88 -0
- package/dist/lifeops/connectors/contract.d.ts.map +1 -0
- package/dist/lifeops/connectors/contract.js +1 -0
- package/dist/lifeops/connectors/contract.js.map +1 -0
- package/dist/lifeops/connectors/default-pack.d.ts +35 -0
- package/dist/lifeops/connectors/default-pack.d.ts.map +1 -0
- package/dist/lifeops/connectors/default-pack.js +37 -0
- package/dist/lifeops/connectors/default-pack.js.map +1 -0
- package/dist/lifeops/connectors/discord.d.ts +8 -0
- package/dist/lifeops/connectors/discord.d.ts.map +1 -0
- package/dist/lifeops/connectors/discord.js +53 -0
- package/dist/lifeops/connectors/discord.js.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts +75 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.js +35 -0
- package/dist/lifeops/connectors/dispatch-policy.js.map +1 -0
- package/dist/lifeops/connectors/duffel.d.ts +11 -0
- package/dist/lifeops/connectors/duffel.d.ts.map +1 -0
- package/dist/lifeops/connectors/duffel.js +74 -0
- package/dist/lifeops/connectors/duffel.js.map +1 -0
- package/dist/lifeops/connectors/google.d.ts +27 -0
- package/dist/lifeops/connectors/google.d.ts.map +1 -0
- package/dist/lifeops/connectors/google.js +80 -0
- package/dist/lifeops/connectors/google.js.map +1 -0
- package/dist/lifeops/connectors/imessage.d.ts +11 -0
- package/dist/lifeops/connectors/imessage.d.ts.map +1 -0
- package/dist/lifeops/connectors/imessage.js +55 -0
- package/dist/lifeops/connectors/imessage.js.map +1 -0
- package/dist/lifeops/connectors/index.d.ts +5 -0
- package/dist/lifeops/connectors/index.d.ts.map +1 -0
- package/dist/lifeops/connectors/index.js +23 -0
- package/dist/lifeops/connectors/index.js.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts +54 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.js +71 -0
- package/dist/lifeops/connectors/mockoon-redirect.js.map +1 -0
- package/dist/lifeops/connectors/registry.d.ts +7 -0
- package/dist/lifeops/connectors/registry.d.ts.map +1 -0
- package/dist/lifeops/connectors/registry.js +55 -0
- package/dist/lifeops/connectors/registry.js.map +1 -0
- package/dist/lifeops/connectors/signal.d.ts +8 -0
- package/dist/lifeops/connectors/signal.d.ts.map +1 -0
- package/dist/lifeops/connectors/signal.js +60 -0
- package/dist/lifeops/connectors/signal.js.map +1 -0
- package/dist/lifeops/connectors/telegram.d.ts +12 -0
- package/dist/lifeops/connectors/telegram.d.ts.map +1 -0
- package/dist/lifeops/connectors/telegram.js +65 -0
- package/dist/lifeops/connectors/telegram.js.map +1 -0
- package/dist/lifeops/connectors/twilio.d.ts +15 -0
- package/dist/lifeops/connectors/twilio.d.ts.map +1 -0
- package/dist/lifeops/connectors/twilio.js +126 -0
- package/dist/lifeops/connectors/twilio.js.map +1 -0
- package/dist/lifeops/connectors/whatsapp.d.ts +10 -0
- package/dist/lifeops/connectors/whatsapp.d.ts.map +1 -0
- package/dist/lifeops/connectors/whatsapp.js +56 -0
- package/dist/lifeops/connectors/whatsapp.js.map +1 -0
- package/dist/lifeops/connectors/x.d.ts +8 -0
- package/dist/lifeops/connectors/x.d.ts.map +1 -0
- package/dist/lifeops/connectors/x.js +62 -0
- package/dist/lifeops/connectors/x.js.map +1 -0
- package/dist/lifeops/contact-route-policy.d.ts +27 -0
- package/dist/lifeops/contact-route-policy.d.ts.map +1 -0
- package/dist/lifeops/contact-route-policy.js +153 -0
- package/dist/lifeops/contact-route-policy.js.map +1 -0
- package/dist/lifeops/continuity-probe.d.ts +49 -0
- package/dist/lifeops/continuity-probe.d.ts.map +1 -0
- package/dist/lifeops/continuity-probe.js +161 -0
- package/dist/lifeops/continuity-probe.js.map +1 -0
- package/dist/lifeops/cross-channel-search.d.ts +108 -0
- package/dist/lifeops/cross-channel-search.d.ts.map +1 -0
- package/dist/lifeops/cross-channel-search.js +888 -0
- package/dist/lifeops/cross-channel-search.js.map +1 -0
- package/dist/lifeops/defaults.d.ts +30 -0
- package/dist/lifeops/defaults.d.ts.map +1 -0
- package/dist/lifeops/defaults.js +206 -0
- package/dist/lifeops/defaults.js.map +1 -0
- package/dist/lifeops/device-bus-service.d.ts +16 -0
- package/dist/lifeops/device-bus-service.d.ts.map +1 -0
- package/dist/lifeops/device-bus-service.js +20 -0
- package/dist/lifeops/device-bus-service.js.map +1 -0
- package/dist/lifeops/device-identity.d.ts +31 -0
- package/dist/lifeops/device-identity.d.ts.map +1 -0
- package/dist/lifeops/device-identity.js +94 -0
- package/dist/lifeops/device-identity.js.map +1 -0
- package/dist/lifeops/document-review.d.ts +264 -0
- package/dist/lifeops/document-review.d.ts.map +1 -0
- package/dist/lifeops/document-review.js +925 -0
- package/dist/lifeops/document-review.js.map +1 -0
- package/dist/lifeops/email-classifier.d.ts +9 -0
- package/dist/lifeops/email-classifier.d.ts.map +1 -0
- package/dist/lifeops/email-classifier.js +15 -0
- package/dist/lifeops/email-classifier.js.map +1 -0
- package/dist/lifeops/email-curation.d.ts +13 -0
- package/dist/lifeops/email-curation.d.ts.map +1 -0
- package/dist/lifeops/email-curation.js +2 -0
- package/dist/lifeops/email-curation.js.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts +7 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.js +1 -0
- package/dist/lifeops/email-unsubscribe-types.js.map +1 -0
- package/dist/lifeops/enforcement-windows.d.ts +34 -0
- package/dist/lifeops/enforcement-windows.d.ts.map +1 -0
- package/dist/lifeops/enforcement-windows.js +80 -0
- package/dist/lifeops/enforcement-windows.js.map +1 -0
- package/dist/lifeops/engine.d.ts +8 -0
- package/dist/lifeops/engine.d.ts.map +1 -0
- package/dist/lifeops/engine.js +540 -0
- package/dist/lifeops/engine.js.map +1 -0
- package/dist/lifeops/entities/index.d.ts +4 -0
- package/dist/lifeops/entities/index.d.ts.map +1 -0
- package/dist/lifeops/entities/index.js +29 -0
- package/dist/lifeops/entities/index.js.map +1 -0
- package/dist/lifeops/entities/merge.d.ts +9 -0
- package/dist/lifeops/entities/merge.d.ts.map +1 -0
- package/dist/lifeops/entities/merge.js +17 -0
- package/dist/lifeops/entities/merge.js.map +1 -0
- package/dist/lifeops/entities/store.d.ts +13 -0
- package/dist/lifeops/entities/store.d.ts.map +1 -0
- package/dist/lifeops/entities/store.js +7 -0
- package/dist/lifeops/entities/store.js.map +1 -0
- package/dist/lifeops/entities/types.d.ts +9 -0
- package/dist/lifeops/entities/types.d.ts.map +1 -0
- package/dist/lifeops/entities/types.js +13 -0
- package/dist/lifeops/entities/types.js.map +1 -0
- package/dist/lifeops/entities/voice-attribution.d.ts +70 -0
- package/dist/lifeops/entities/voice-attribution.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-attribution.js +121 -0
- package/dist/lifeops/entities/voice-attribution.js.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts +32 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.js +68 -0
- package/dist/lifeops/entities/voice-observer-bridge.js.map +1 -0
- package/dist/lifeops/entities/voice-observer.d.ts +72 -0
- package/dist/lifeops/entities/voice-observer.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer.js +97 -0
- package/dist/lifeops/entities/voice-observer.js.map +1 -0
- package/dist/lifeops/escalation-ladders.d.ts +28 -0
- package/dist/lifeops/escalation-ladders.d.ts.map +1 -0
- package/dist/lifeops/escalation-ladders.js +17 -0
- package/dist/lifeops/escalation-ladders.js.map +1 -0
- package/dist/lifeops/fda-probe.d.ts +23 -0
- package/dist/lifeops/fda-probe.d.ts.map +1 -0
- package/dist/lifeops/fda-probe.js +59 -0
- package/dist/lifeops/fda-probe.js.map +1 -0
- package/dist/lifeops/feature-flags.d.ts +24 -0
- package/dist/lifeops/feature-flags.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.js +261 -0
- package/dist/lifeops/feature-flags.js.map +1 -0
- package/dist/lifeops/feature-flags.types.d.ts +156 -0
- package/dist/lifeops/feature-flags.types.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.types.js +129 -0
- package/dist/lifeops/feature-flags.types.js.map +1 -0
- package/dist/lifeops/first-run/defaults.d.ts +57 -0
- package/dist/lifeops/first-run/defaults.d.ts.map +1 -0
- package/dist/lifeops/first-run/defaults.js +159 -0
- package/dist/lifeops/first-run/defaults.js.map +1 -0
- package/dist/lifeops/first-run/questions.d.ts +74 -0
- package/dist/lifeops/first-run/questions.d.ts.map +1 -0
- package/dist/lifeops/first-run/questions.js +184 -0
- package/dist/lifeops/first-run/questions.js.map +1 -0
- package/dist/lifeops/first-run/replay.d.ts +41 -0
- package/dist/lifeops/first-run/replay.d.ts.map +1 -0
- package/dist/lifeops/first-run/replay.js +34 -0
- package/dist/lifeops/first-run/replay.js.map +1 -0
- package/dist/lifeops/first-run/service.d.ts +147 -0
- package/dist/lifeops/first-run/service.d.ts.map +1 -0
- package/dist/lifeops/first-run/service.js +455 -0
- package/dist/lifeops/first-run/service.js.map +1 -0
- package/dist/lifeops/first-run/state.d.ts +36 -0
- package/dist/lifeops/first-run/state.d.ts.map +1 -0
- package/dist/lifeops/first-run/state.js +128 -0
- package/dist/lifeops/first-run/state.js.map +1 -0
- package/dist/lifeops/global-pause/store.d.ts +22 -0
- package/dist/lifeops/global-pause/store.d.ts.map +1 -0
- package/dist/lifeops/global-pause/store.js +18 -0
- package/dist/lifeops/global-pause/store.js.map +1 -0
- package/dist/lifeops/goal-grounding.d.ts +9 -0
- package/dist/lifeops/goal-grounding.d.ts.map +1 -0
- package/dist/lifeops/goal-grounding.js +19 -0
- package/dist/lifeops/goal-grounding.js.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts +8 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.js +7 -0
- package/dist/lifeops/goal-semantic-evaluator.js.map +1 -0
- package/dist/lifeops/google/format-helpers.d.ts +63 -0
- package/dist/lifeops/google/format-helpers.d.ts.map +1 -0
- package/dist/lifeops/google/format-helpers.js +597 -0
- package/dist/lifeops/google/format-helpers.js.map +1 -0
- package/dist/lifeops/google-plugin-delegates.d.ts +59 -0
- package/dist/lifeops/google-plugin-delegates.d.ts.map +1 -0
- package/dist/lifeops/google-plugin-delegates.js +408 -0
- package/dist/lifeops/google-plugin-delegates.js.map +1 -0
- package/dist/lifeops/google-scopes.d.ts +15 -0
- package/dist/lifeops/google-scopes.d.ts.map +1 -0
- package/dist/lifeops/google-scopes.js +118 -0
- package/dist/lifeops/google-scopes.js.map +1 -0
- package/dist/lifeops/handoff/store.d.ts +23 -0
- package/dist/lifeops/handoff/store.d.ts.map +1 -0
- package/dist/lifeops/handoff/store.js +20 -0
- package/dist/lifeops/handoff/store.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts +16 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.js +33 -0
- package/dist/lifeops/i18n/localized-examples-provider.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts +32 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js +28 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts +64 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.js +283 -0
- package/dist/lifeops/i18n/prompt-registry.js.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts +7 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.js +81 -0
- package/dist/lifeops/imessage-outbound-probe.js.map +1 -0
- package/dist/lifeops/index.d.ts +24 -0
- package/dist/lifeops/index.d.ts.map +1 -0
- package/dist/lifeops/index.js +24 -0
- package/dist/lifeops/index.js.map +1 -0
- package/dist/lifeops/intent-sync.d.ts +64 -0
- package/dist/lifeops/intent-sync.d.ts.map +1 -0
- package/dist/lifeops/intent-sync.js +321 -0
- package/dist/lifeops/intent-sync.js.map +1 -0
- package/dist/lifeops/messaging/index.d.ts +2 -0
- package/dist/lifeops/messaging/index.d.ts.map +1 -0
- package/dist/lifeops/messaging/index.js +5 -0
- package/dist/lifeops/messaging/index.js.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts +3 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.js +83 -0
- package/dist/lifeops/messaging/owner-send-policy.js.map +1 -0
- package/dist/lifeops/notifications-push.d.ts +37 -0
- package/dist/lifeops/notifications-push.d.ts.map +1 -0
- package/dist/lifeops/notifications-push.js +95 -0
- package/dist/lifeops/notifications-push.js.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts +5 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.js +48 -0
- package/dist/lifeops/optimized-prompt-instructions.js.map +1 -0
- package/dist/lifeops/owner/fact-store.d.ts +143 -0
- package/dist/lifeops/owner/fact-store.d.ts.map +1 -0
- package/dist/lifeops/owner/fact-store.js +446 -0
- package/dist/lifeops/owner/fact-store.js.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts +3 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js +241 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js.map +1 -0
- package/dist/lifeops/owner-profile.d.ts +61 -0
- package/dist/lifeops/owner-profile.d.ts.map +1 -0
- package/dist/lifeops/owner-profile.js +407 -0
- package/dist/lifeops/owner-profile.js.map +1 -0
- package/dist/lifeops/pending-prompts/store.d.ts +23 -0
- package/dist/lifeops/pending-prompts/store.d.ts.map +1 -0
- package/dist/lifeops/pending-prompts/store.js +16 -0
- package/dist/lifeops/pending-prompts/store.js.map +1 -0
- package/dist/lifeops/policy-memory.d.ts +190 -0
- package/dist/lifeops/policy-memory.d.ts.map +1 -0
- package/dist/lifeops/policy-memory.js +1026 -0
- package/dist/lifeops/policy-memory.js.map +1 -0
- package/dist/lifeops/priority-scoring.d.ts +51 -0
- package/dist/lifeops/priority-scoring.d.ts.map +1 -0
- package/dist/lifeops/priority-scoring.js +305 -0
- package/dist/lifeops/priority-scoring.js.map +1 -0
- package/dist/lifeops/privacy-egress.d.ts +92 -0
- package/dist/lifeops/privacy-egress.d.ts.map +1 -0
- package/dist/lifeops/privacy-egress.js +230 -0
- package/dist/lifeops/privacy-egress.js.map +1 -0
- package/dist/lifeops/privacy.d.ts +49 -0
- package/dist/lifeops/privacy.d.ts.map +1 -0
- package/dist/lifeops/privacy.js +66 -0
- package/dist/lifeops/privacy.js.map +1 -0
- package/dist/lifeops/redact-sensitive-data.d.ts +32 -0
- package/dist/lifeops/redact-sensitive-data.d.ts.map +1 -0
- package/dist/lifeops/redact-sensitive-data.js +98 -0
- package/dist/lifeops/redact-sensitive-data.js.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts +13 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.js +73 -0
- package/dist/lifeops/registries/app-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/blocker-registry.d.ts +76 -0
- package/dist/lifeops/registries/blocker-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/blocker-registry.js +40 -0
- package/dist/lifeops/registries/blocker-registry.js.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts +57 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.js +82 -0
- package/dist/lifeops/registries/event-kind-registry.js.map +1 -0
- package/dist/lifeops/registries/family-registry.d.ts +72 -0
- package/dist/lifeops/registries/family-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/family-registry.js +98 -0
- package/dist/lifeops/registries/family-registry.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts +32 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js +36 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts +76 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.js +68 -0
- package/dist/lifeops/registries/feature-flag-registry.js.map +1 -0
- package/dist/lifeops/registries/index.d.ts +24 -0
- package/dist/lifeops/registries/index.d.ts.map +1 -0
- package/dist/lifeops/registries/index.js +115 -0
- package/dist/lifeops/registries/index.js.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts +21 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.js +76 -0
- package/dist/lifeops/registries/website-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts +30 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js +315 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts +101 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.js +56 -0
- package/dist/lifeops/registries/workflow-step-registry.js.map +1 -0
- package/dist/lifeops/relationships/extraction.d.ts +77 -0
- package/dist/lifeops/relationships/extraction.d.ts.map +1 -0
- package/dist/lifeops/relationships/extraction.js +146 -0
- package/dist/lifeops/relationships/extraction.js.map +1 -0
- package/dist/lifeops/relationships/index.d.ts +4 -0
- package/dist/lifeops/relationships/index.d.ts.map +1 -0
- package/dist/lifeops/relationships/index.js +19 -0
- package/dist/lifeops/relationships/index.js.map +1 -0
- package/dist/lifeops/relationships/mapping.d.ts +34 -0
- package/dist/lifeops/relationships/mapping.d.ts.map +1 -0
- package/dist/lifeops/relationships/mapping.js +87 -0
- package/dist/lifeops/relationships/mapping.js.map +1 -0
- package/dist/lifeops/relationships/store.d.ts +12 -0
- package/dist/lifeops/relationships/store.d.ts.map +1 -0
- package/dist/lifeops/relationships/store.js +5 -0
- package/dist/lifeops/relationships/store.js.map +1 -0
- package/dist/lifeops/relationships/types.d.ts +9 -0
- package/dist/lifeops/relationships/types.d.ts.map +1 -0
- package/dist/lifeops/relationships/types.js +11 -0
- package/dist/lifeops/relationships/types.js.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts +13 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.js +107 -0
- package/dist/lifeops/relative-schedule-resolver.js.map +1 -0
- package/dist/lifeops/relative-time.d.ts +15 -0
- package/dist/lifeops/relative-time.d.ts.map +1 -0
- package/dist/lifeops/relative-time.js +191 -0
- package/dist/lifeops/relative-time.js.map +1 -0
- package/dist/lifeops/repository.d.ts +638 -0
- package/dist/lifeops/repository.d.ts.map +1 -0
- package/dist/lifeops/repository.js +6289 -0
- package/dist/lifeops/repository.js.map +1 -0
- package/dist/lifeops/runtime-cache.d.ts +4 -0
- package/dist/lifeops/runtime-cache.d.ts.map +1 -0
- package/dist/lifeops/runtime-cache.js +7 -0
- package/dist/lifeops/runtime-cache.js.map +1 -0
- package/dist/lifeops/runtime-service-delegates.d.ts +236 -0
- package/dist/lifeops/runtime-service-delegates.d.ts.map +1 -0
- package/dist/lifeops/runtime-service-delegates.js +839 -0
- package/dist/lifeops/runtime-service-delegates.js.map +1 -0
- package/dist/lifeops/runtime.d.ts +13 -0
- package/dist/lifeops/runtime.d.ts.map +1 -0
- package/dist/lifeops/runtime.js +104 -0
- package/dist/lifeops/runtime.js.map +1 -0
- package/dist/lifeops/schedule-insight.d.ts +133 -0
- package/dist/lifeops/schedule-insight.d.ts.map +1 -0
- package/dist/lifeops/schedule-insight.js +726 -0
- package/dist/lifeops/schedule-insight.js.map +1 -0
- package/dist/lifeops/schedule-state.d.ts +39 -0
- package/dist/lifeops/schedule-state.d.ts.map +1 -0
- package/dist/lifeops/schedule-state.js +671 -0
- package/dist/lifeops/schedule-state.js.map +1 -0
- package/dist/lifeops/schedule-sync-config.d.ts +3 -0
- package/dist/lifeops/schedule-sync-config.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-config.js +23 -0
- package/dist/lifeops/schedule-sync-config.js.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts +2 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.js +2 -0
- package/dist/lifeops/schedule-sync-contracts.js.map +1 -0
- package/dist/lifeops/scheduled-task/index.d.ts +13 -0
- package/dist/lifeops/scheduled-task/index.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/index.js +14 -0
- package/dist/lifeops/scheduled-task/index.js.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts +33 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js +334 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts +28 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.js +202 -0
- package/dist/lifeops/scheduled-task/scheduler.js.map +1 -0
- package/dist/lifeops/scheduled-task/service.d.ts +61 -0
- package/dist/lifeops/scheduled-task/service.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/service.js +64 -0
- package/dist/lifeops/scheduled-task/service.js.map +1 -0
- package/dist/lifeops/scheduler-task.d.ts +19 -0
- package/dist/lifeops/scheduler-task.d.ts.map +1 -0
- package/dist/lifeops/scheduler-task.js +201 -0
- package/dist/lifeops/scheduler-task.js.map +1 -0
- package/dist/lifeops/schema.d.ts +28068 -0
- package/dist/lifeops/schema.d.ts.map +1 -0
- package/dist/lifeops/schema.js +1689 -0
- package/dist/lifeops/schema.js.map +1 -0
- package/dist/lifeops/screen-context.d.ts +66 -0
- package/dist/lifeops/screen-context.d.ts.map +1 -0
- package/dist/lifeops/screen-context.js +347 -0
- package/dist/lifeops/screen-context.js.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts +113 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.js +142 -0
- package/dist/lifeops/seed-routine-migration/migrator.js.map +1 -0
- package/dist/lifeops/seed-routines.d.ts +24 -0
- package/dist/lifeops/seed-routines.d.ts.map +1 -0
- package/dist/lifeops/seed-routines.js +140 -0
- package/dist/lifeops/seed-routines.js.map +1 -0
- package/dist/lifeops/send-policy/contract.d.ts +81 -0
- package/dist/lifeops/send-policy/contract.d.ts.map +1 -0
- package/dist/lifeops/send-policy/contract.js +1 -0
- package/dist/lifeops/send-policy/contract.js.map +1 -0
- package/dist/lifeops/send-policy/index.d.ts +3 -0
- package/dist/lifeops/send-policy/index.d.ts.map +1 -0
- package/dist/lifeops/send-policy/index.js +13 -0
- package/dist/lifeops/send-policy/index.js.map +1 -0
- package/dist/lifeops/send-policy/registry.d.ts +7 -0
- package/dist/lifeops/send-policy/registry.d.ts.map +1 -0
- package/dist/lifeops/send-policy/registry.js +62 -0
- package/dist/lifeops/send-policy/registry.js.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts +46 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.js +103 -0
- package/dist/lifeops/sensitive-request-delivery.js.map +1 -0
- package/dist/lifeops/service-constants.d.ts +10 -0
- package/dist/lifeops/service-constants.d.ts.map +1 -0
- package/dist/lifeops/service-constants.js +129 -0
- package/dist/lifeops/service-constants.js.map +1 -0
- package/dist/lifeops/service-helpers-browser.d.ts +41 -0
- package/dist/lifeops/service-helpers-browser.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-browser.js +290 -0
- package/dist/lifeops/service-helpers-browser.js.map +1 -0
- package/dist/lifeops/service-helpers-misc.d.ts +68 -0
- package/dist/lifeops/service-helpers-misc.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-misc.js +531 -0
- package/dist/lifeops/service-helpers-misc.js.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts +23 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.js +257 -0
- package/dist/lifeops/service-helpers-occurrence.js.map +1 -0
- package/dist/lifeops/service-helpers-reminder.d.ts +260 -0
- package/dist/lifeops/service-helpers-reminder.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-reminder.js +1186 -0
- package/dist/lifeops/service-helpers-reminder.js.map +1 -0
- package/dist/lifeops/service-mixin-browser.d.ts +31 -0
- package/dist/lifeops/service-mixin-browser.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-browser.js +975 -0
- package/dist/lifeops/service-mixin-browser.js.map +1 -0
- package/dist/lifeops/service-mixin-calendar.d.ts +53 -0
- package/dist/lifeops/service-mixin-calendar.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-calendar.js +68 -0
- package/dist/lifeops/service-mixin-calendar.js.map +1 -0
- package/dist/lifeops/service-mixin-core.d.ts +51 -0
- package/dist/lifeops/service-mixin-core.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-core.js +500 -0
- package/dist/lifeops/service-mixin-core.js.map +1 -0
- package/dist/lifeops/service-mixin-definitions.d.ts +14 -0
- package/dist/lifeops/service-mixin-definitions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-definitions.js +470 -0
- package/dist/lifeops/service-mixin-definitions.js.map +1 -0
- package/dist/lifeops/service-mixin-discord.d.ts +49 -0
- package/dist/lifeops/service-mixin-discord.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-discord.js +1253 -0
- package/dist/lifeops/service-mixin-discord.js.map +1 -0
- package/dist/lifeops/service-mixin-drive.d.ts +96 -0
- package/dist/lifeops/service-mixin-drive.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-drive.js +213 -0
- package/dist/lifeops/service-mixin-drive.js.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts +23 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js +27 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js.map +1 -0
- package/dist/lifeops/service-mixin-gmail.d.ts +43 -0
- package/dist/lifeops/service-mixin-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-gmail.js +727 -0
- package/dist/lifeops/service-mixin-gmail.js.map +1 -0
- package/dist/lifeops/service-mixin-goals.d.ts +22 -0
- package/dist/lifeops/service-mixin-goals.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-goals.js +884 -0
- package/dist/lifeops/service-mixin-goals.js.map +1 -0
- package/dist/lifeops/service-mixin-google.d.ts +13 -0
- package/dist/lifeops/service-mixin-google.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-google.js +398 -0
- package/dist/lifeops/service-mixin-google.js.map +1 -0
- package/dist/lifeops/service-mixin-health.d.ts +27 -0
- package/dist/lifeops/service-mixin-health.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-health.js +670 -0
- package/dist/lifeops/service-mixin-health.js.map +1 -0
- package/dist/lifeops/service-mixin-imessage.d.ts +106 -0
- package/dist/lifeops/service-mixin-imessage.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-imessage.js +303 -0
- package/dist/lifeops/service-mixin-imessage.js.map +1 -0
- package/dist/lifeops/service-mixin-inbox.d.ts +55 -0
- package/dist/lifeops/service-mixin-inbox.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-inbox.js +597 -0
- package/dist/lifeops/service-mixin-inbox.js.map +1 -0
- package/dist/lifeops/service-mixin-relationships.d.ts +65 -0
- package/dist/lifeops/service-mixin-relationships.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-relationships.js +150 -0
- package/dist/lifeops/service-mixin-relationships.js.map +1 -0
- package/dist/lifeops/service-mixin-reminders.d.ts +62 -0
- package/dist/lifeops/service-mixin-reminders.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-reminders.js +4003 -0
- package/dist/lifeops/service-mixin-reminders.js.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts +53 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.js +405 -0
- package/dist/lifeops/service-mixin-scheduling.js.map +1 -0
- package/dist/lifeops/service-mixin-screentime.d.ts +71 -0
- package/dist/lifeops/service-mixin-screentime.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-screentime.js +530 -0
- package/dist/lifeops/service-mixin-screentime.js.map +1 -0
- package/dist/lifeops/service-mixin-signal.d.ts +74 -0
- package/dist/lifeops/service-mixin-signal.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-signal.js +214 -0
- package/dist/lifeops/service-mixin-signal.js.map +1 -0
- package/dist/lifeops/service-mixin-sleep.d.ts +68 -0
- package/dist/lifeops/service-mixin-sleep.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-sleep.js +43 -0
- package/dist/lifeops/service-mixin-sleep.js.map +1 -0
- package/dist/lifeops/service-mixin-status.d.ts +31 -0
- package/dist/lifeops/service-mixin-status.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-status.js +373 -0
- package/dist/lifeops/service-mixin-status.js.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts +101 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.js +50 -0
- package/dist/lifeops/service-mixin-subscriptions.js.map +1 -0
- package/dist/lifeops/service-mixin-telegram.d.ts +104 -0
- package/dist/lifeops/service-mixin-telegram.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-telegram.js +280 -0
- package/dist/lifeops/service-mixin-telegram.js.map +1 -0
- package/dist/lifeops/service-mixin-travel.d.ts +66 -0
- package/dist/lifeops/service-mixin-travel.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-travel.js +275 -0
- package/dist/lifeops/service-mixin-travel.js.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts +96 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.js +186 -0
- package/dist/lifeops/service-mixin-whatsapp.js.map +1 -0
- package/dist/lifeops/service-mixin-workflows.d.ts +15 -0
- package/dist/lifeops/service-mixin-workflows.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-workflows.js +710 -0
- package/dist/lifeops/service-mixin-workflows.js.map +1 -0
- package/dist/lifeops/service-mixin-x-read.d.ts +31 -0
- package/dist/lifeops/service-mixin-x-read.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x-read.js +267 -0
- package/dist/lifeops/service-mixin-x-read.js.map +1 -0
- package/dist/lifeops/service-mixin-x.d.ts +66 -0
- package/dist/lifeops/service-mixin-x.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x.js +501 -0
- package/dist/lifeops/service-mixin-x.js.map +1 -0
- package/dist/lifeops/service-normalize-connector.d.ts +19 -0
- package/dist/lifeops/service-normalize-connector.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-connector.js +816 -0
- package/dist/lifeops/service-normalize-connector.js.map +1 -0
- package/dist/lifeops/service-normalize-gmail.d.ts +11 -0
- package/dist/lifeops/service-normalize-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-gmail.js +85 -0
- package/dist/lifeops/service-normalize-gmail.js.map +1 -0
- package/dist/lifeops/service-normalize-task.d.ts +9 -0
- package/dist/lifeops/service-normalize-task.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-task.js +567 -0
- package/dist/lifeops/service-normalize-task.js.map +1 -0
- package/dist/lifeops/service-normalize.d.ts +9 -0
- package/dist/lifeops/service-normalize.d.ts.map +1 -0
- package/dist/lifeops/service-normalize.js +53 -0
- package/dist/lifeops/service-normalize.js.map +1 -0
- package/dist/lifeops/service-types.d.ts +75 -0
- package/dist/lifeops/service-types.d.ts.map +1 -0
- package/dist/lifeops/service-types.js +5 -0
- package/dist/lifeops/service-types.js.map +1 -0
- package/dist/lifeops/service.d.ts +482 -0
- package/dist/lifeops/service.d.ts.map +1 -0
- package/dist/lifeops/service.js +62 -0
- package/dist/lifeops/service.js.map +1 -0
- package/dist/lifeops/signal-runtime-config.d.ts +13 -0
- package/dist/lifeops/signal-runtime-config.d.ts.map +1 -0
- package/dist/lifeops/signal-runtime-config.js +44 -0
- package/dist/lifeops/signal-runtime-config.js.map +1 -0
- package/dist/lifeops/signals/bus.d.ts +78 -0
- package/dist/lifeops/signals/bus.d.ts.map +1 -0
- package/dist/lifeops/signals/bus.js +117 -0
- package/dist/lifeops/signals/bus.js.map +1 -0
- package/dist/lifeops/sql.d.ts +65 -0
- package/dist/lifeops/sql.d.ts.map +1 -0
- package/dist/lifeops/sql.js +182 -0
- package/dist/lifeops/sql.js.map +1 -0
- package/dist/lifeops/stretch-decider.d.ts +73 -0
- package/dist/lifeops/stretch-decider.d.ts.map +1 -0
- package/dist/lifeops/stretch-decider.js +49 -0
- package/dist/lifeops/stretch-decider.js.map +1 -0
- package/dist/lifeops/telemetry-mapping.d.ts +14 -0
- package/dist/lifeops/telemetry-mapping.d.ts.map +1 -0
- package/dist/lifeops/telemetry-mapping.js +115 -0
- package/dist/lifeops/telemetry-mapping.js.map +1 -0
- package/dist/lifeops/telemetry-retention.d.ts +21 -0
- package/dist/lifeops/telemetry-retention.d.ts.map +1 -0
- package/dist/lifeops/telemetry-retention.js +13 -0
- package/dist/lifeops/telemetry-retention.js.map +1 -0
- package/dist/lifeops/time/timezone.d.ts +4 -0
- package/dist/lifeops/time/timezone.d.ts.map +1 -0
- package/dist/lifeops/time/timezone.js +154 -0
- package/dist/lifeops/time/timezone.js.map +1 -0
- package/dist/lifeops/time-util.d.ts +10 -0
- package/dist/lifeops/time-util.d.ts.map +1 -0
- package/dist/lifeops/time-util.js +14 -0
- package/dist/lifeops/time-util.js.map +1 -0
- package/dist/lifeops/time.d.ts +17 -0
- package/dist/lifeops/time.d.ts.map +1 -0
- package/dist/lifeops/time.js +152 -0
- package/dist/lifeops/time.js.map +1 -0
- package/dist/lifeops/travel-booking.types.d.ts +46 -0
- package/dist/lifeops/travel-booking.types.d.ts.map +1 -0
- package/dist/lifeops/travel-booking.types.js +1 -0
- package/dist/lifeops/travel-booking.types.js.map +1 -0
- package/dist/lifeops/triggers/schedule-once.d.ts +19 -0
- package/dist/lifeops/triggers/schedule-once.d.ts.map +1 -0
- package/dist/lifeops/triggers/schedule-once.js +99 -0
- package/dist/lifeops/triggers/schedule-once.js.map +1 -0
- package/dist/lifeops/validate/coding-task-request.d.ts +18 -0
- package/dist/lifeops/validate/coding-task-request.d.ts.map +1 -0
- package/dist/lifeops/validate/coding-task-request.js +16 -0
- package/dist/lifeops/validate/coding-task-request.js.map +1 -0
- package/dist/lifeops/voice/grounded-reply.d.ts +41 -0
- package/dist/lifeops/voice/grounded-reply.d.ts.map +1 -0
- package/dist/lifeops/voice/grounded-reply.js +24 -0
- package/dist/lifeops/voice/grounded-reply.js.map +1 -0
- package/dist/lifeops/voice-affect.d.ts +79 -0
- package/dist/lifeops/voice-affect.d.ts.map +1 -0
- package/dist/lifeops/voice-affect.js +253 -0
- package/dist/lifeops/voice-affect.js.map +1 -0
- package/dist/lifeops/wave1-types.d.ts +125 -0
- package/dist/lifeops/wave1-types.d.ts.map +1 -0
- package/dist/lifeops/wave1-types.js +1 -0
- package/dist/lifeops/wave1-types.js.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts +33 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js +226 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js.map +1 -0
- package/dist/lifeops/work-threads/index.d.ts +3 -0
- package/dist/lifeops/work-threads/index.d.ts.map +1 -0
- package/dist/lifeops/work-threads/index.js +7 -0
- package/dist/lifeops/work-threads/index.js.map +1 -0
- package/dist/lifeops/work-threads/store.d.ts +91 -0
- package/dist/lifeops/work-threads/store.d.ts.map +1 -0
- package/dist/lifeops/work-threads/store.js +245 -0
- package/dist/lifeops/work-threads/store.js.map +1 -0
- package/dist/lifeops/work-threads/types.d.ts +58 -0
- package/dist/lifeops/work-threads/types.d.ts.map +1 -0
- package/dist/lifeops/work-threads/types.js +1 -0
- package/dist/lifeops/work-threads/types.js.map +1 -0
- package/dist/platform/host.d.ts +16 -0
- package/dist/platform/host.d.ts.map +1 -0
- package/dist/platform/host.js +22 -0
- package/dist/platform/host.js.map +1 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.d.ts.map +1 -0
- package/dist/platform/index.js +3 -0
- package/dist/platform/index.js.map +1 -0
- package/dist/platform/lifeops-github.d.ts +15 -0
- package/dist/platform/lifeops-github.d.ts.map +1 -0
- package/dist/platform/lifeops-github.js +146 -0
- package/dist/platform/lifeops-github.js.map +1 -0
- package/dist/plugin.d.ts +106 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +989 -0
- package/dist/plugin.js.map +1 -0
- package/dist/provider.d.ts +4 -0
- package/dist/provider.d.ts.map +1 -0
- package/dist/provider.js +108 -0
- package/dist/provider.js.map +1 -0
- package/dist/providers/activity-profile.d.ts +3 -0
- package/dist/providers/activity-profile.d.ts.map +1 -0
- package/dist/providers/activity-profile.js +140 -0
- package/dist/providers/activity-profile.js.map +1 -0
- package/dist/providers/cross-channel-context.d.ts +29 -0
- package/dist/providers/cross-channel-context.d.ts.map +1 -0
- package/dist/providers/cross-channel-context.js +206 -0
- package/dist/providers/cross-channel-context.js.map +1 -0
- package/dist/providers/first-run.d.ts +22 -0
- package/dist/providers/first-run.d.ts.map +1 -0
- package/dist/providers/first-run.js +93 -0
- package/dist/providers/first-run.js.map +1 -0
- package/dist/providers/health.d.ts +2 -0
- package/dist/providers/health.d.ts.map +1 -0
- package/dist/providers/health.js +14 -0
- package/dist/providers/health.js.map +1 -0
- package/dist/providers/inbox-triage.d.ts +3 -0
- package/dist/providers/inbox-triage.d.ts.map +1 -0
- package/dist/providers/inbox-triage.js +134 -0
- package/dist/providers/inbox-triage.js.map +1 -0
- package/dist/providers/lifeops.d.ts +3 -0
- package/dist/providers/lifeops.d.ts.map +1 -0
- package/dist/providers/lifeops.js +548 -0
- package/dist/providers/lifeops.js.map +1 -0
- package/dist/providers/pending-prompts.d.ts +38 -0
- package/dist/providers/pending-prompts.d.ts.map +1 -0
- package/dist/providers/pending-prompts.js +81 -0
- package/dist/providers/pending-prompts.js.map +1 -0
- package/dist/providers/recent-task-states.d.ts +52 -0
- package/dist/providers/recent-task-states.d.ts.map +1 -0
- package/dist/providers/recent-task-states.js +166 -0
- package/dist/providers/recent-task-states.js.map +1 -0
- package/dist/providers/room-policy.d.ts +16 -0
- package/dist/providers/room-policy.d.ts.map +1 -0
- package/dist/providers/room-policy.js +71 -0
- package/dist/providers/room-policy.js.map +1 -0
- package/dist/providers/work-threads.d.ts +3 -0
- package/dist/providers/work-threads.d.ts.map +1 -0
- package/dist/providers/work-threads.js +97 -0
- package/dist/providers/work-threads.js.map +1 -0
- package/dist/public.d.ts +3 -0
- package/dist/public.d.ts.map +1 -0
- package/dist/public.js +17 -0
- package/dist/public.js.map +1 -0
- package/dist/routes/cloud-features-routes.d.ts +9 -0
- package/dist/routes/cloud-features-routes.d.ts.map +1 -0
- package/dist/routes/cloud-features-routes.js +164 -0
- package/dist/routes/cloud-features-routes.js.map +1 -0
- package/dist/routes/entities.d.ts +14 -0
- package/dist/routes/entities.d.ts.map +1 -0
- package/dist/routes/entities.js +203 -0
- package/dist/routes/entities.js.map +1 -0
- package/dist/routes/lifeops-routes.d.ts +20 -0
- package/dist/routes/lifeops-routes.d.ts.map +1 -0
- package/dist/routes/lifeops-routes.js +2337 -0
- package/dist/routes/lifeops-routes.js.map +1 -0
- package/dist/routes/plugin.d.ts +9 -0
- package/dist/routes/plugin.d.ts.map +1 -0
- package/dist/routes/plugin.js +568 -0
- package/dist/routes/plugin.js.map +1 -0
- package/dist/routes/relationships.d.ts +13 -0
- package/dist/routes/relationships.d.ts.map +1 -0
- package/dist/routes/relationships.js +195 -0
- package/dist/routes/relationships.js.map +1 -0
- package/dist/routes/scheduled-tasks.d.ts +102 -0
- package/dist/routes/scheduled-tasks.d.ts.map +1 -0
- package/dist/routes/scheduled-tasks.js +322 -0
- package/dist/routes/scheduled-tasks.js.map +1 -0
- package/dist/routes/sleep-routes.d.ts +3 -0
- package/dist/routes/sleep-routes.d.ts.map +1 -0
- package/dist/routes/sleep-routes.js +33 -0
- package/dist/routes/sleep-routes.js.map +1 -0
- package/dist/routes/travel-provider-relay-routes.d.ts +2 -0
- package/dist/routes/travel-provider-relay-routes.d.ts.map +1 -0
- package/dist/routes/travel-provider-relay-routes.js +7 -0
- package/dist/routes/travel-provider-relay-routes.js.map +1 -0
- package/dist/routes/website-blocker-routes.d.ts +6 -0
- package/dist/routes/website-blocker-routes.d.ts.map +1 -0
- package/dist/routes/website-blocker-routes.js +218 -0
- package/dist/routes/website-blocker-routes.js.map +1 -0
- package/dist/security/action-confirmation.d.ts +12 -0
- package/dist/security/action-confirmation.d.ts.map +1 -0
- package/dist/security/action-confirmation.js +36 -0
- package/dist/security/action-confirmation.js.map +1 -0
- package/dist/service.d.ts +34 -0
- package/dist/service.d.ts.map +1 -0
- package/dist/service.js +111 -0
- package/dist/service.js.map +1 -0
- package/dist/travel-time/calendar-create.d.ts +17 -0
- package/dist/travel-time/calendar-create.d.ts.map +1 -0
- package/dist/travel-time/calendar-create.js +28 -0
- package/dist/travel-time/calendar-create.js.map +1 -0
- package/dist/travel-time/service.d.ts +114 -0
- package/dist/travel-time/service.d.ts.map +1 -0
- package/dist/travel-time/service.js +209 -0
- package/dist/travel-time/service.js.map +1 -0
- package/dist/types/app-blocker-settings-card.d.ts +2 -0
- package/dist/types/app-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/app-blocker-settings-card.js +1 -0
- package/dist/types/app-blocker-settings-card.js.map +1 -0
- package/dist/types/briefing.d.ts +59 -0
- package/dist/types/briefing.d.ts.map +1 -0
- package/dist/types/briefing.js +1 -0
- package/dist/types/briefing.js.map +1 -0
- package/dist/types/document-request.d.ts +41 -0
- package/dist/types/document-request.d.ts.map +1 -0
- package/dist/types/document-request.js +1 -0
- package/dist/types/document-request.js.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/website-blocker-settings-card.d.ts +2 -0
- package/dist/types/website-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/website-blocker-settings-card.js +1 -0
- package/dist/types/website-blocker-settings-card.js.map +1 -0
- package/dist/ui.d.ts +13 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +25 -0
- package/dist/ui.js.map +1 -0
- package/dist/utils/format-duration.d.ts +2 -0
- package/dist/utils/format-duration.d.ts.map +1 -0
- package/dist/utils/format-duration.js +13 -0
- package/dist/utils/format-duration.js.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +3 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/lifeops-url.d.ts +3 -0
- package/dist/utils/lifeops-url.d.ts.map +1 -0
- package/dist/utils/lifeops-url.js +28 -0
- package/dist/utils/lifeops-url.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts +32 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.js +30 -0
- package/dist/website-blocker/chat-integration/block-activator.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts +7 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js +115 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts +39 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js +133 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts +21 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js +230 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts +13 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js +22 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js.map +1 -0
- package/dist/website-blocker/chat-integration/index.d.ts +5 -0
- package/dist/website-blocker/chat-integration/index.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/index.js +26 -0
- package/dist/website-blocker/chat-integration/index.js.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts +75 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.js +154 -0
- package/dist/website-blocker/proactive-block-bridge.js.map +1 -0
- package/dist/website-blocker/public.d.ts +12 -0
- package/dist/website-blocker/public.d.ts.map +1 -0
- package/dist/website-blocker/public.js +51 -0
- package/dist/website-blocker/public.js.map +1 -0
- package/package.json +28 -28
|
@@ -0,0 +1,347 @@
|
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { fileURLToPath, pathToFileURL } from "node:url";
|
|
4
|
+
import { logger } from "@elizaos/core";
|
|
5
|
+
import { FRAME_FILE } from "@elizaos/plugin-browser";
|
|
6
|
+
const DEFAULT_MIN_SAMPLE_INTERVAL_MS = 5 * 6e4;
|
|
7
|
+
const DEFAULT_MAX_FRAME_AGE_MS = 30 * 6e4;
|
|
8
|
+
const HEURISTIC_TEXT_LIMIT = 1024;
|
|
9
|
+
const WORK_KEYWORDS = [
|
|
10
|
+
"inbox",
|
|
11
|
+
"email",
|
|
12
|
+
"calendar",
|
|
13
|
+
"meeting",
|
|
14
|
+
"docs",
|
|
15
|
+
"document",
|
|
16
|
+
"spreadsheet",
|
|
17
|
+
"sheet",
|
|
18
|
+
"slack",
|
|
19
|
+
"discord",
|
|
20
|
+
"github",
|
|
21
|
+
"pull request",
|
|
22
|
+
"jira",
|
|
23
|
+
"terminal",
|
|
24
|
+
"code",
|
|
25
|
+
"editor",
|
|
26
|
+
"notion",
|
|
27
|
+
"figma"
|
|
28
|
+
];
|
|
29
|
+
const LEISURE_KEYWORDS = [
|
|
30
|
+
"youtube",
|
|
31
|
+
"netflix",
|
|
32
|
+
"twitch",
|
|
33
|
+
"instagram",
|
|
34
|
+
"twitter",
|
|
35
|
+
"x.com",
|
|
36
|
+
"reddit",
|
|
37
|
+
"game",
|
|
38
|
+
"gaming",
|
|
39
|
+
"spotify"
|
|
40
|
+
];
|
|
41
|
+
function errorMessage(error) {
|
|
42
|
+
return error instanceof Error && error.message.trim().length > 0 ? error.message.trim() : String(error);
|
|
43
|
+
}
|
|
44
|
+
function isMissingOptionalVisionImport(error) {
|
|
45
|
+
return error !== null && typeof error === "object" && "code" in error && (error.code === "ERR_MODULE_NOT_FOUND" || error.code === "MODULE_NOT_FOUND");
|
|
46
|
+
}
|
|
47
|
+
const TRANSITION_KEYWORDS = [
|
|
48
|
+
"lock screen",
|
|
49
|
+
"login",
|
|
50
|
+
"sign in",
|
|
51
|
+
"password",
|
|
52
|
+
"desktop",
|
|
53
|
+
"wallpaper",
|
|
54
|
+
"home screen",
|
|
55
|
+
"launchpad"
|
|
56
|
+
];
|
|
57
|
+
let sharpImportPromise = null;
|
|
58
|
+
function hasDefaultSharpFactory(mod) {
|
|
59
|
+
return typeof mod.default === "function";
|
|
60
|
+
}
|
|
61
|
+
function normalizeText(value) {
|
|
62
|
+
return (value ?? "").replace(/\s+/g, " ").trim().slice(0, HEURISTIC_TEXT_LIMIT);
|
|
63
|
+
}
|
|
64
|
+
function keywordMatches(text, keywords) {
|
|
65
|
+
const lower = text.toLowerCase();
|
|
66
|
+
return keywords.filter((keyword) => lower.includes(keyword));
|
|
67
|
+
}
|
|
68
|
+
async function loadSharp() {
|
|
69
|
+
sharpImportPromise ??= import("sharp").then(
|
|
70
|
+
(mod) => hasDefaultSharpFactory(mod) ? mod.default : mod
|
|
71
|
+
);
|
|
72
|
+
return await sharpImportPromise;
|
|
73
|
+
}
|
|
74
|
+
async function analyzeImageWithSharp(buffer) {
|
|
75
|
+
const sharp = await loadSharp();
|
|
76
|
+
const image = sharp(buffer).rotate().greyscale().resize({
|
|
77
|
+
width: 160,
|
|
78
|
+
withoutEnlargement: true,
|
|
79
|
+
fit: "inside"
|
|
80
|
+
});
|
|
81
|
+
const { data, info } = await image.raw().toBuffer({ resolveWithObject: true });
|
|
82
|
+
const pixels = data;
|
|
83
|
+
let sum = 0;
|
|
84
|
+
let sumSquares = 0;
|
|
85
|
+
let dark = 0;
|
|
86
|
+
let bright = 0;
|
|
87
|
+
let edges = 0;
|
|
88
|
+
let comparisons = 0;
|
|
89
|
+
for (let index = 0; index < pixels.length; index += 1) {
|
|
90
|
+
const value = pixels[index] ?? 0;
|
|
91
|
+
sum += value;
|
|
92
|
+
sumSquares += value * value;
|
|
93
|
+
if (value < 32) dark += 1;
|
|
94
|
+
if (value > 224) bright += 1;
|
|
95
|
+
const left = pixels[index - 1];
|
|
96
|
+
if (left !== void 0) {
|
|
97
|
+
const diff = Math.abs(value - left);
|
|
98
|
+
if (diff > 28) edges += 1;
|
|
99
|
+
comparisons += 1;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
const count = Math.max(1, pixels.length);
|
|
103
|
+
const averageLuma = sum / count / 255;
|
|
104
|
+
const variance = sumSquares / count - (sum / count) ** 2;
|
|
105
|
+
const lumaStdDev = Math.sqrt(Math.max(0, variance)) / 255;
|
|
106
|
+
return {
|
|
107
|
+
width: info.width,
|
|
108
|
+
height: info.height,
|
|
109
|
+
averageLuma,
|
|
110
|
+
lumaStdDev,
|
|
111
|
+
darkRatio: dark / count,
|
|
112
|
+
brightRatio: bright / count,
|
|
113
|
+
edgeRatio: comparisons > 0 ? edges / comparisons : 0
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
async function analyzeImage(buffer, analyzer) {
|
|
117
|
+
return analyzer ? await analyzer.analyze(buffer) : await analyzeImageWithSharp(buffer);
|
|
118
|
+
}
|
|
119
|
+
function inferFocusFromSignals(args) {
|
|
120
|
+
const normalizedText = normalizeText(args.text);
|
|
121
|
+
const workCues = keywordMatches(normalizedText, WORK_KEYWORDS);
|
|
122
|
+
const leisureCues = keywordMatches(normalizedText, LEISURE_KEYWORDS);
|
|
123
|
+
const transitionCues = keywordMatches(normalizedText, TRANSITION_KEYWORDS);
|
|
124
|
+
const cues = [...workCues, ...leisureCues, ...transitionCues];
|
|
125
|
+
const tags = /* @__PURE__ */ new Set();
|
|
126
|
+
let focus = "unknown";
|
|
127
|
+
let confidence = 0.28;
|
|
128
|
+
if (workCues.length > 0) {
|
|
129
|
+
focus = "work";
|
|
130
|
+
confidence = 0.86;
|
|
131
|
+
tags.add("work");
|
|
132
|
+
tags.add("text-heavy");
|
|
133
|
+
} else if (leisureCues.length > 0) {
|
|
134
|
+
focus = "leisure";
|
|
135
|
+
confidence = 0.84;
|
|
136
|
+
tags.add("leisure");
|
|
137
|
+
tags.add("screen-entertainment");
|
|
138
|
+
} else if (transitionCues.length > 0) {
|
|
139
|
+
focus = "transition";
|
|
140
|
+
confidence = 0.78;
|
|
141
|
+
tags.add("transition");
|
|
142
|
+
}
|
|
143
|
+
if (focus === "unknown") {
|
|
144
|
+
if (args.stats.darkRatio > 0.92 && args.stats.lumaStdDev < 0.025) {
|
|
145
|
+
focus = "idle";
|
|
146
|
+
confidence = 0.72;
|
|
147
|
+
tags.add("idle");
|
|
148
|
+
} else if (args.stats.brightRatio > 0.92 && args.stats.lumaStdDev < 0.025) {
|
|
149
|
+
focus = "transition";
|
|
150
|
+
confidence = 0.66;
|
|
151
|
+
tags.add("transition");
|
|
152
|
+
} else if (args.stats.edgeRatio > 0.08 && args.stats.averageLuma > 0.18 && args.stats.averageLuma < 0.88) {
|
|
153
|
+
focus = "work";
|
|
154
|
+
confidence = 0.52;
|
|
155
|
+
tags.add("busy");
|
|
156
|
+
tags.add("text-or-ui-dense");
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
if (focus === "idle") {
|
|
160
|
+
tags.add("idle");
|
|
161
|
+
} else if (focus === "unknown") {
|
|
162
|
+
tags.add("uncertain");
|
|
163
|
+
} else {
|
|
164
|
+
tags.add("screen-active");
|
|
165
|
+
}
|
|
166
|
+
return {
|
|
167
|
+
focus,
|
|
168
|
+
contextTags: [...tags],
|
|
169
|
+
cues,
|
|
170
|
+
confidence,
|
|
171
|
+
busy: focus === "work" || focus === "transition"
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
async function readOcrText(ocr, frameBytes) {
|
|
175
|
+
if (!ocr) {
|
|
176
|
+
return null;
|
|
177
|
+
}
|
|
178
|
+
try {
|
|
179
|
+
const text = await ocr.extractText(frameBytes);
|
|
180
|
+
return normalizeText(text) || null;
|
|
181
|
+
} catch {
|
|
182
|
+
return null;
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
function buildDisabledSummary(args) {
|
|
186
|
+
return {
|
|
187
|
+
sampledAtMs: args.sampledAtMs,
|
|
188
|
+
source: "disabled",
|
|
189
|
+
available: false,
|
|
190
|
+
throttled: false,
|
|
191
|
+
stale: false,
|
|
192
|
+
busy: false,
|
|
193
|
+
framePath: args.framePath,
|
|
194
|
+
capturedAtMs: null,
|
|
195
|
+
width: null,
|
|
196
|
+
height: null,
|
|
197
|
+
byteLength: 0,
|
|
198
|
+
averageLuma: null,
|
|
199
|
+
lumaStdDev: null,
|
|
200
|
+
ocrAvailable: false,
|
|
201
|
+
ocrText: null,
|
|
202
|
+
focus: "unknown",
|
|
203
|
+
contextTags: ["disabled"],
|
|
204
|
+
cues: [],
|
|
205
|
+
confidence: 0,
|
|
206
|
+
disabledReason: args.disabledReason
|
|
207
|
+
};
|
|
208
|
+
}
|
|
209
|
+
async function analyzeLifeOpsScreenBuffer(args) {
|
|
210
|
+
const stats = await analyzeImage(args.frameBytes, args.imageAnalyzer);
|
|
211
|
+
const inference = inferFocusFromSignals({
|
|
212
|
+
text: args.ocrText,
|
|
213
|
+
stats
|
|
214
|
+
});
|
|
215
|
+
return {
|
|
216
|
+
sampledAtMs: args.sampledAtMs,
|
|
217
|
+
source: args.ocrText ? "vision" : "browser-capture",
|
|
218
|
+
available: !args.stale,
|
|
219
|
+
throttled: false,
|
|
220
|
+
stale: args.stale,
|
|
221
|
+
busy: !args.stale && inference.busy,
|
|
222
|
+
framePath: args.framePath,
|
|
223
|
+
capturedAtMs: args.capturedAtMs,
|
|
224
|
+
width: stats.width,
|
|
225
|
+
height: stats.height,
|
|
226
|
+
byteLength: args.frameBytes.byteLength,
|
|
227
|
+
averageLuma: stats.averageLuma,
|
|
228
|
+
lumaStdDev: stats.lumaStdDev,
|
|
229
|
+
ocrAvailable: Boolean(args.ocrText && args.ocrText.length > 0),
|
|
230
|
+
ocrText: normalizeText(args.ocrText) || null,
|
|
231
|
+
focus: args.stale ? "unknown" : inference.focus,
|
|
232
|
+
contextTags: args.stale ? ["stale-frame"] : inference.contextTags,
|
|
233
|
+
cues: args.stale ? [] : inference.cues,
|
|
234
|
+
confidence: args.stale ? 0.2 : inference.confidence,
|
|
235
|
+
disabledReason: args.stale ? "The latest browser-capture frame is stale." : null
|
|
236
|
+
};
|
|
237
|
+
}
|
|
238
|
+
class LifeOpsScreenContextSampler {
|
|
239
|
+
constructor(options = {}) {
|
|
240
|
+
this.options = options;
|
|
241
|
+
}
|
|
242
|
+
options;
|
|
243
|
+
lastSampleAtMs = 0;
|
|
244
|
+
lastSummary = null;
|
|
245
|
+
shouldSample(nowMs = Date.now()) {
|
|
246
|
+
const minIntervalMs = this.options.minSampleIntervalMs ?? DEFAULT_MIN_SAMPLE_INTERVAL_MS;
|
|
247
|
+
return this.lastSampleAtMs === 0 || nowMs - this.lastSampleAtMs >= minIntervalMs;
|
|
248
|
+
}
|
|
249
|
+
getLastSummary() {
|
|
250
|
+
return this.lastSummary;
|
|
251
|
+
}
|
|
252
|
+
async sample(nowMs = Date.now()) {
|
|
253
|
+
if (!this.shouldSample(nowMs) && this.lastSummary) {
|
|
254
|
+
return {
|
|
255
|
+
...this.lastSummary,
|
|
256
|
+
throttled: true,
|
|
257
|
+
sampledAtMs: nowMs
|
|
258
|
+
};
|
|
259
|
+
}
|
|
260
|
+
const framePath = this.options.framePath ?? FRAME_FILE;
|
|
261
|
+
const maxFrameAgeMs = this.options.maxFrameAgeMs ?? DEFAULT_MAX_FRAME_AGE_MS;
|
|
262
|
+
if (!fs.existsSync(framePath)) {
|
|
263
|
+
const summary = buildDisabledSummary({
|
|
264
|
+
sampledAtMs: nowMs,
|
|
265
|
+
framePath,
|
|
266
|
+
disabledReason: "No browser-capture frame is available."
|
|
267
|
+
});
|
|
268
|
+
this.lastSampleAtMs = nowMs;
|
|
269
|
+
this.lastSummary = summary;
|
|
270
|
+
return summary;
|
|
271
|
+
}
|
|
272
|
+
try {
|
|
273
|
+
const stat = fs.statSync(framePath);
|
|
274
|
+
const stale = nowMs - stat.mtimeMs > maxFrameAgeMs;
|
|
275
|
+
const frameBytes = fs.readFileSync(framePath);
|
|
276
|
+
const ocrText = await readOcrText(this.options.ocr, frameBytes);
|
|
277
|
+
const summary = await analyzeLifeOpsScreenBuffer({
|
|
278
|
+
framePath,
|
|
279
|
+
frameBytes,
|
|
280
|
+
ocrText,
|
|
281
|
+
capturedAtMs: stat.mtimeMs,
|
|
282
|
+
sampledAtMs: nowMs,
|
|
283
|
+
stale,
|
|
284
|
+
imageAnalyzer: this.options.imageAnalyzer
|
|
285
|
+
});
|
|
286
|
+
this.lastSampleAtMs = nowMs;
|
|
287
|
+
this.lastSummary = summary;
|
|
288
|
+
return summary;
|
|
289
|
+
} catch {
|
|
290
|
+
const summary = buildDisabledSummary({
|
|
291
|
+
sampledAtMs: nowMs,
|
|
292
|
+
framePath,
|
|
293
|
+
disabledReason: "Unable to read or analyze the browser-capture frame."
|
|
294
|
+
});
|
|
295
|
+
this.lastSampleAtMs = nowMs;
|
|
296
|
+
this.lastSummary = summary;
|
|
297
|
+
return summary;
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
async function tryCreateVisionOcrAdapter() {
|
|
302
|
+
const localVisionOcrServiceUrl = pathToFileURL(
|
|
303
|
+
path.resolve(
|
|
304
|
+
path.dirname(fileURLToPath(import.meta.url)),
|
|
305
|
+
"../../../../plugins/plugin-vision/src/ocr-service.ts"
|
|
306
|
+
)
|
|
307
|
+
).href;
|
|
308
|
+
const visionImportCandidates = [
|
|
309
|
+
"@elizaos/plugin-vision",
|
|
310
|
+
localVisionOcrServiceUrl
|
|
311
|
+
];
|
|
312
|
+
for (const specifier of visionImportCandidates) {
|
|
313
|
+
try {
|
|
314
|
+
const mod = await import(
|
|
315
|
+
/* @vite-ignore */
|
|
316
|
+
specifier
|
|
317
|
+
);
|
|
318
|
+
const OCRService = mod.OCRService;
|
|
319
|
+
if (!OCRService) {
|
|
320
|
+
continue;
|
|
321
|
+
}
|
|
322
|
+
const service = new OCRService();
|
|
323
|
+
if (typeof service.initialize === "function") {
|
|
324
|
+
await service.initialize();
|
|
325
|
+
}
|
|
326
|
+
return {
|
|
327
|
+
async extractText(imageBuffer) {
|
|
328
|
+
const result = await service.extractText(imageBuffer);
|
|
329
|
+
return normalizeText(result.fullText ?? result.text ?? null) || null;
|
|
330
|
+
}
|
|
331
|
+
};
|
|
332
|
+
} catch (error) {
|
|
333
|
+
if (!isMissingOptionalVisionImport(error)) {
|
|
334
|
+
logger.warn(
|
|
335
|
+
`[LifeOpsScreenContext] vision OCR adapter unavailable for ${specifier}: ${errorMessage(error)}`
|
|
336
|
+
);
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
return null;
|
|
341
|
+
}
|
|
342
|
+
export {
|
|
343
|
+
LifeOpsScreenContextSampler,
|
|
344
|
+
analyzeLifeOpsScreenBuffer,
|
|
345
|
+
tryCreateVisionOcrAdapter
|
|
346
|
+
};
|
|
347
|
+
//# sourceMappingURL=screen-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/screen-context.ts"],"sourcesContent":["import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { fileURLToPath, pathToFileURL } from \"node:url\";\nimport { logger } from \"@elizaos/core\";\nimport { FRAME_FILE } from \"@elizaos/plugin-browser\";\n\nexport type LifeOpsScreenFocus =\n | \"work\"\n | \"leisure\"\n | \"transition\"\n | \"idle\"\n | \"unknown\";\n\nexport type LifeOpsScreenSource = \"disabled\" | \"browser-capture\" | \"vision\";\n\nexport interface LifeOpsScreenContextSummary {\n sampledAtMs: number;\n source: LifeOpsScreenSource;\n available: boolean;\n throttled: boolean;\n stale: boolean;\n busy: boolean;\n framePath: string;\n capturedAtMs: number | null;\n width: number | null;\n height: number | null;\n byteLength: number;\n averageLuma: number | null;\n lumaStdDev: number | null;\n ocrAvailable: boolean;\n ocrText: string | null;\n focus: LifeOpsScreenFocus;\n contextTags: string[];\n cues: string[];\n confidence: number;\n disabledReason: string | null;\n}\n\nexport interface LifeOpsScreenOcrAdapter {\n extractText(imageBuffer: Buffer): Promise<string | null>;\n}\n\nexport type LifeOpsScreenImageStats = {\n width: number;\n height: number;\n averageLuma: number;\n lumaStdDev: number;\n darkRatio: number;\n brightRatio: number;\n edgeRatio: number;\n};\n\nexport interface LifeOpsScreenImageAnalyzer {\n analyze(imageBuffer: Buffer): Promise<LifeOpsScreenImageStats>;\n}\n\nexport interface LifeOpsScreenContextSamplerOptions {\n framePath?: string;\n minSampleIntervalMs?: number;\n maxFrameAgeMs?: number;\n ocr?: LifeOpsScreenOcrAdapter | null;\n imageAnalyzer?: LifeOpsScreenImageAnalyzer | null;\n}\n\nconst DEFAULT_MIN_SAMPLE_INTERVAL_MS = 5 * 60_000;\nconst DEFAULT_MAX_FRAME_AGE_MS = 30 * 60_000;\nconst HEURISTIC_TEXT_LIMIT = 1_024;\nconst WORK_KEYWORDS = [\n \"inbox\",\n \"email\",\n \"calendar\",\n \"meeting\",\n \"docs\",\n \"document\",\n \"spreadsheet\",\n \"sheet\",\n \"slack\",\n \"discord\",\n \"github\",\n \"pull request\",\n \"jira\",\n \"terminal\",\n \"code\",\n \"editor\",\n \"notion\",\n \"figma\",\n];\nconst LEISURE_KEYWORDS = [\n \"youtube\",\n \"netflix\",\n \"twitch\",\n \"instagram\",\n \"twitter\",\n \"x.com\",\n \"reddit\",\n \"game\",\n \"gaming\",\n \"spotify\",\n];\n\nfunction errorMessage(error: unknown): string {\n return error instanceof Error && error.message.trim().length > 0\n ? error.message.trim()\n : String(error);\n}\n\nfunction isMissingOptionalVisionImport(error: unknown): boolean {\n return (\n error !== null &&\n typeof error === \"object\" &&\n \"code\" in error &&\n ((error as { code?: unknown }).code === \"ERR_MODULE_NOT_FOUND\" ||\n (error as { code?: unknown }).code === \"MODULE_NOT_FOUND\")\n );\n}\nconst TRANSITION_KEYWORDS = [\n \"lock screen\",\n \"login\",\n \"sign in\",\n \"password\",\n \"desktop\",\n \"wallpaper\",\n \"home screen\",\n \"launchpad\",\n];\n\ntype SharpFactory = typeof import(\"sharp\");\ntype SharpModuleWithDefault = { default: SharpFactory };\n\nlet sharpImportPromise: Promise<SharpFactory> | null = null;\n\nfunction hasDefaultSharpFactory(\n mod: SharpFactory | SharpModuleWithDefault,\n): mod is SharpModuleWithDefault {\n return typeof (mod as SharpModuleWithDefault).default === \"function\";\n}\n\nfunction normalizeText(value: string | null | undefined): string {\n return (value ?? \"\")\n .replace(/\\s+/g, \" \")\n .trim()\n .slice(0, HEURISTIC_TEXT_LIMIT);\n}\n\nfunction keywordMatches(text: string, keywords: readonly string[]): string[] {\n const lower = text.toLowerCase();\n return keywords.filter((keyword) => lower.includes(keyword));\n}\n\nasync function loadSharp(): Promise<SharpFactory> {\n sharpImportPromise ??= import(\"sharp\").then((mod) =>\n hasDefaultSharpFactory(mod) ? mod.default : mod,\n );\n return await sharpImportPromise;\n}\n\nasync function analyzeImageWithSharp(\n buffer: Buffer,\n): Promise<LifeOpsScreenImageStats> {\n const sharp = await loadSharp();\n const image = sharp(buffer).rotate().greyscale().resize({\n width: 160,\n withoutEnlargement: true,\n fit: \"inside\",\n });\n const { data, info } = await image\n .raw()\n .toBuffer({ resolveWithObject: true });\n const pixels = data;\n let sum = 0;\n let sumSquares = 0;\n let dark = 0;\n let bright = 0;\n let edges = 0;\n let comparisons = 0;\n\n for (let index = 0; index < pixels.length; index += 1) {\n const value = pixels[index] ?? 0;\n sum += value;\n sumSquares += value * value;\n if (value < 32) dark += 1;\n if (value > 224) bright += 1;\n const left = pixels[index - 1];\n if (left !== undefined) {\n const diff = Math.abs(value - left);\n if (diff > 28) edges += 1;\n comparisons += 1;\n }\n }\n\n const count = Math.max(1, pixels.length);\n const averageLuma = sum / count / 255;\n const variance = sumSquares / count - (sum / count) ** 2;\n const lumaStdDev = Math.sqrt(Math.max(0, variance)) / 255;\n\n return {\n width: info.width,\n height: info.height,\n averageLuma,\n lumaStdDev,\n darkRatio: dark / count,\n brightRatio: bright / count,\n edgeRatio: comparisons > 0 ? edges / comparisons : 0,\n };\n}\n\nasync function analyzeImage(\n buffer: Buffer,\n analyzer: LifeOpsScreenImageAnalyzer | null | undefined,\n): Promise<LifeOpsScreenImageStats> {\n return analyzer\n ? await analyzer.analyze(buffer)\n : await analyzeImageWithSharp(buffer);\n}\n\nfunction inferFocusFromSignals(args: {\n text: string | null;\n stats: LifeOpsScreenImageStats;\n}): {\n focus: LifeOpsScreenFocus;\n contextTags: string[];\n cues: string[];\n confidence: number;\n busy: boolean;\n} {\n const normalizedText = normalizeText(args.text);\n const workCues = keywordMatches(normalizedText, WORK_KEYWORDS);\n const leisureCues = keywordMatches(normalizedText, LEISURE_KEYWORDS);\n const transitionCues = keywordMatches(normalizedText, TRANSITION_KEYWORDS);\n const cues = [...workCues, ...leisureCues, ...transitionCues];\n const tags = new Set<string>();\n let focus: LifeOpsScreenFocus = \"unknown\";\n let confidence = 0.28;\n\n if (workCues.length > 0) {\n focus = \"work\";\n confidence = 0.86;\n tags.add(\"work\");\n tags.add(\"text-heavy\");\n } else if (leisureCues.length > 0) {\n focus = \"leisure\";\n confidence = 0.84;\n tags.add(\"leisure\");\n tags.add(\"screen-entertainment\");\n } else if (transitionCues.length > 0) {\n focus = \"transition\";\n confidence = 0.78;\n tags.add(\"transition\");\n }\n\n if (focus === \"unknown\") {\n if (args.stats.darkRatio > 0.92 && args.stats.lumaStdDev < 0.025) {\n focus = \"idle\";\n confidence = 0.72;\n tags.add(\"idle\");\n } else if (args.stats.brightRatio > 0.92 && args.stats.lumaStdDev < 0.025) {\n focus = \"transition\";\n confidence = 0.66;\n tags.add(\"transition\");\n } else if (\n args.stats.edgeRatio > 0.08 &&\n args.stats.averageLuma > 0.18 &&\n args.stats.averageLuma < 0.88\n ) {\n focus = \"work\";\n confidence = 0.52;\n tags.add(\"busy\");\n tags.add(\"text-or-ui-dense\");\n }\n }\n\n if (focus === \"idle\") {\n tags.add(\"idle\");\n } else if (focus === \"unknown\") {\n tags.add(\"uncertain\");\n } else {\n tags.add(\"screen-active\");\n }\n\n return {\n focus,\n contextTags: [...tags],\n cues,\n confidence,\n busy: focus === \"work\" || focus === \"transition\",\n };\n}\n\nasync function readOcrText(\n ocr: LifeOpsScreenOcrAdapter | null | undefined,\n frameBytes: Buffer,\n): Promise<string | null> {\n if (!ocr) {\n return null;\n }\n try {\n const text = await ocr.extractText(frameBytes);\n return normalizeText(text) || null;\n } catch {\n return null;\n }\n}\n\nfunction buildDisabledSummary(args: {\n sampledAtMs: number;\n framePath: string;\n disabledReason: string;\n}): LifeOpsScreenContextSummary {\n return {\n sampledAtMs: args.sampledAtMs,\n source: \"disabled\",\n available: false,\n throttled: false,\n stale: false,\n busy: false,\n framePath: args.framePath,\n capturedAtMs: null,\n width: null,\n height: null,\n byteLength: 0,\n averageLuma: null,\n lumaStdDev: null,\n ocrAvailable: false,\n ocrText: null,\n focus: \"unknown\",\n contextTags: [\"disabled\"],\n cues: [],\n confidence: 0,\n disabledReason: args.disabledReason,\n };\n}\n\nexport async function analyzeLifeOpsScreenBuffer(args: {\n framePath: string;\n frameBytes: Buffer;\n ocrText: string | null;\n capturedAtMs: number;\n sampledAtMs: number;\n stale: boolean;\n imageAnalyzer?: LifeOpsScreenImageAnalyzer | null;\n}): Promise<LifeOpsScreenContextSummary> {\n const stats = await analyzeImage(args.frameBytes, args.imageAnalyzer);\n const inference = inferFocusFromSignals({\n text: args.ocrText,\n stats,\n });\n return {\n sampledAtMs: args.sampledAtMs,\n source: args.ocrText ? \"vision\" : \"browser-capture\",\n available: !args.stale,\n throttled: false,\n stale: args.stale,\n busy: !args.stale && inference.busy,\n framePath: args.framePath,\n capturedAtMs: args.capturedAtMs,\n width: stats.width,\n height: stats.height,\n byteLength: args.frameBytes.byteLength,\n averageLuma: stats.averageLuma,\n lumaStdDev: stats.lumaStdDev,\n ocrAvailable: Boolean(args.ocrText && args.ocrText.length > 0),\n ocrText: normalizeText(args.ocrText) || null,\n focus: args.stale ? \"unknown\" : inference.focus,\n contextTags: args.stale ? [\"stale-frame\"] : inference.contextTags,\n cues: args.stale ? [] : inference.cues,\n confidence: args.stale ? 0.2 : inference.confidence,\n disabledReason: args.stale\n ? \"The latest browser-capture frame is stale.\"\n : null,\n };\n}\n\nexport class LifeOpsScreenContextSampler {\n private lastSampleAtMs = 0;\n private lastSummary: LifeOpsScreenContextSummary | null = null;\n\n constructor(\n private readonly options: LifeOpsScreenContextSamplerOptions = {},\n ) {}\n\n shouldSample(nowMs = Date.now()): boolean {\n const minIntervalMs =\n this.options.minSampleIntervalMs ?? DEFAULT_MIN_SAMPLE_INTERVAL_MS;\n return (\n this.lastSampleAtMs === 0 || nowMs - this.lastSampleAtMs >= minIntervalMs\n );\n }\n\n getLastSummary(): LifeOpsScreenContextSummary | null {\n return this.lastSummary;\n }\n\n async sample(nowMs = Date.now()): Promise<LifeOpsScreenContextSummary> {\n if (!this.shouldSample(nowMs) && this.lastSummary) {\n return {\n ...this.lastSummary,\n throttled: true,\n sampledAtMs: nowMs,\n };\n }\n\n const framePath = this.options.framePath ?? FRAME_FILE;\n const maxFrameAgeMs =\n this.options.maxFrameAgeMs ?? DEFAULT_MAX_FRAME_AGE_MS;\n\n if (!fs.existsSync(framePath)) {\n const summary = buildDisabledSummary({\n sampledAtMs: nowMs,\n framePath,\n disabledReason: \"No browser-capture frame is available.\",\n });\n this.lastSampleAtMs = nowMs;\n this.lastSummary = summary;\n return summary;\n }\n\n try {\n const stat = fs.statSync(framePath);\n const stale = nowMs - stat.mtimeMs > maxFrameAgeMs;\n const frameBytes = fs.readFileSync(framePath);\n const ocrText = await readOcrText(this.options.ocr, frameBytes);\n const summary = await analyzeLifeOpsScreenBuffer({\n framePath,\n frameBytes,\n ocrText,\n capturedAtMs: stat.mtimeMs,\n sampledAtMs: nowMs,\n stale,\n imageAnalyzer: this.options.imageAnalyzer,\n });\n\n this.lastSampleAtMs = nowMs;\n this.lastSummary = summary;\n return summary;\n } catch {\n const summary = buildDisabledSummary({\n sampledAtMs: nowMs,\n framePath,\n disabledReason: \"Unable to read or analyze the browser-capture frame.\",\n });\n this.lastSampleAtMs = nowMs;\n this.lastSummary = summary;\n return summary;\n }\n }\n}\n\nexport async function tryCreateVisionOcrAdapter(): Promise<LifeOpsScreenOcrAdapter | null> {\n const localVisionOcrServiceUrl = pathToFileURL(\n path.resolve(\n path.dirname(fileURLToPath(import.meta.url)),\n \"../../../../plugins/plugin-vision/src/ocr-service.ts\",\n ),\n ).href;\n const visionImportCandidates = [\n \"@elizaos/plugin-vision\",\n localVisionOcrServiceUrl,\n ];\n\n for (const specifier of visionImportCandidates) {\n try {\n const mod = await import(/* @vite-ignore */ specifier);\n const OCRService = mod.OCRService as\n | (new () => {\n initialize(): Promise<void>;\n extractText(\n imageBuffer: Buffer,\n ): Promise<{ fullText?: string; text?: string }>;\n })\n | undefined;\n if (!OCRService) {\n continue;\n }\n\n const service = new OCRService();\n if (typeof service.initialize === \"function\") {\n await service.initialize();\n }\n\n return {\n async extractText(imageBuffer: Buffer): Promise<string | null> {\n const result = await service.extractText(imageBuffer);\n return normalizeText(result.fullText ?? result.text ?? null) || null;\n },\n };\n } catch (error) {\n if (!isMissingOptionalVisionImport(error)) {\n logger.warn(\n `[LifeOpsScreenContext] vision OCR adapter unavailable for ${specifier}: ${errorMessage(error)}`,\n );\n }\n }\n }\n\n return null;\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* One-shot migrator from legacy `LifeOpsDefinition` rows
|
|
3
|
+
* (carrying the `metadata.seedKey === "load-test-user-profile:<key>"`
|
|
4
|
+
* marker that the deleted `applySeedRoutines` API used to write) to the
|
|
5
|
+
* new `default-packs/habit-starters.ts` `ScheduledTask` records.
|
|
6
|
+
*
|
|
7
|
+
* Behaviour:
|
|
8
|
+
*
|
|
9
|
+
* - **Dry-run by default.** Reads the legacy definitions for the
|
|
10
|
+
* supplied agent id, resolves the corresponding habit-starter
|
|
11
|
+
* `ScheduledTaskSeed` for each row, and emits a structured JSON
|
|
12
|
+
* manual-review report. **No writes are issued.**
|
|
13
|
+
*
|
|
14
|
+
* - **`--apply` writes.** When `apply: true` is passed (CLI:
|
|
15
|
+
* `--apply`), the migrator schedules the matching
|
|
16
|
+
* `ScheduledTaskSeed` records via the supplied
|
|
17
|
+
* `ScheduledTaskRunner` (using the legacy seed key as
|
|
18
|
+
* `idempotencyKey`) and marks the legacy `LifeOpsDefinition` row's
|
|
19
|
+
* `metadata.migratedToScheduledTaskId` so a subsequent dry-run
|
|
20
|
+
* reports the row as already migrated.
|
|
21
|
+
*
|
|
22
|
+
* - **Architecture rule:** strong types, no `any`, no `unknown` in
|
|
23
|
+
* the public surface. Failures throw — no swallowed errors, no
|
|
24
|
+
* fallback values that mask broken data.
|
|
25
|
+
*
|
|
26
|
+
* Driver script: `plugins/plugin-personal-assistant/scripts/migrate-seed-routines.mjs`.
|
|
27
|
+
*/
|
|
28
|
+
import type { LifeOpsTaskDefinition } from "../../contracts/index.js";
|
|
29
|
+
import type { ScheduledTaskSeed } from "../../default-packs/contract-types.js";
|
|
30
|
+
/**
|
|
31
|
+
* The legacy seed-key prefix written by the now-deleted
|
|
32
|
+
* `applySeedRoutines` mixin method. Definitions whose
|
|
33
|
+
* `metadata.seedKey` starts with this prefix are migrator candidates.
|
|
34
|
+
*/
|
|
35
|
+
export declare const LEGACY_SEED_KEY_PREFIX = "load-test-user-profile";
|
|
36
|
+
export interface SeedRoutineMigrationCandidate {
|
|
37
|
+
/** Legacy `LifeOpsTaskDefinition.id`. */
|
|
38
|
+
definitionId: string;
|
|
39
|
+
/** Definition title (for human review). */
|
|
40
|
+
title: string;
|
|
41
|
+
/** Stable habit-starter key (e.g. `brush_teeth`). */
|
|
42
|
+
habitStarterKey: string;
|
|
43
|
+
/** The new `ScheduledTaskSeed` we would schedule on `--apply`. */
|
|
44
|
+
scheduledTaskSeed: ScheduledTaskSeed;
|
|
45
|
+
/** Idempotency key — equals the original legacy seed key. */
|
|
46
|
+
idempotencyKey: string;
|
|
47
|
+
/** True if the row has already been migrated in a prior `--apply` run. */
|
|
48
|
+
alreadyMigrated: boolean;
|
|
49
|
+
}
|
|
50
|
+
export interface SeedRoutineMigrationDiff {
|
|
51
|
+
agentId: string;
|
|
52
|
+
generatedAt: string;
|
|
53
|
+
candidates: SeedRoutineMigrationCandidate[];
|
|
54
|
+
legacyDefinitionsWithoutMatch: Array<{
|
|
55
|
+
definitionId: string;
|
|
56
|
+
title: string;
|
|
57
|
+
seedKey: string;
|
|
58
|
+
}>;
|
|
59
|
+
}
|
|
60
|
+
export interface SeedRoutineMigrationApplyResult {
|
|
61
|
+
agentId: string;
|
|
62
|
+
appliedAt: string;
|
|
63
|
+
scheduled: Array<{
|
|
64
|
+
definitionId: string;
|
|
65
|
+
idempotencyKey: string;
|
|
66
|
+
habitStarterKey: string;
|
|
67
|
+
scheduledTaskId: string;
|
|
68
|
+
}>;
|
|
69
|
+
skipped: Array<{
|
|
70
|
+
definitionId: string;
|
|
71
|
+
reason: "already_migrated" | "no_matching_habit_starter";
|
|
72
|
+
}>;
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Read-only handle into the legacy `LifeOpsDefinition` table that the
|
|
76
|
+
* migrator needs. Production callers pass `LifeOpsRepository`; tests
|
|
77
|
+
* pass a thin in-memory fake.
|
|
78
|
+
*/
|
|
79
|
+
export interface LegacyDefinitionReader {
|
|
80
|
+
listDefinitions(agentId: string): Promise<LifeOpsTaskDefinition[]>;
|
|
81
|
+
updateDefinitionMetadata(definition: LifeOpsTaskDefinition, metadata: Record<string, unknown>): Promise<void>;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Subset of the `ScheduledTaskRunner` surface the migrator needs during
|
|
85
|
+
* `--apply`.
|
|
86
|
+
*/
|
|
87
|
+
export interface ScheduledTaskScheduleSink {
|
|
88
|
+
schedule(seed: ScheduledTaskSeed): Promise<{
|
|
89
|
+
taskId: string;
|
|
90
|
+
}>;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Build the migration diff (dry-run output). Performs no writes.
|
|
94
|
+
*/
|
|
95
|
+
export declare function buildSeedRoutineMigrationDiff(args: {
|
|
96
|
+
agentId: string;
|
|
97
|
+
reader: LegacyDefinitionReader;
|
|
98
|
+
now?: Date;
|
|
99
|
+
}): Promise<SeedRoutineMigrationDiff>;
|
|
100
|
+
/**
|
|
101
|
+
* Apply the migration: schedule each candidate `ScheduledTaskSeed` via
|
|
102
|
+
* the runner sink, and stamp `metadata.migratedToScheduledTaskId` on
|
|
103
|
+
* the legacy definition so the row is skipped on subsequent runs.
|
|
104
|
+
*/
|
|
105
|
+
export declare function applySeedRoutineMigration(args: {
|
|
106
|
+
agentId: string;
|
|
107
|
+
reader: LegacyDefinitionReader;
|
|
108
|
+
sink: ScheduledTaskScheduleSink;
|
|
109
|
+
now?: Date;
|
|
110
|
+
/** Source of legacy definitions whose metadata may need stamping. */
|
|
111
|
+
definitionsById?: ReadonlyMap<string, LifeOpsTaskDefinition>;
|
|
112
|
+
}): Promise<SeedRoutineMigrationApplyResult>;
|
|
113
|
+
//# sourceMappingURL=migrator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrator.d.ts","sourceRoot":"","sources":["../../../src/lifeops/seed-routine-migration/migrator.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AAEH,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AAM/E;;;;GAIG;AACH,eAAO,MAAM,sBAAsB,2BAA2B,CAAC;AAE/D,MAAM,WAAW,6BAA6B;IAC5C,yCAAyC;IACzC,YAAY,EAAE,MAAM,CAAC;IACrB,2CAA2C;IAC3C,KAAK,EAAE,MAAM,CAAC;IACd,qDAAqD;IACrD,eAAe,EAAE,MAAM,CAAC;IACxB,kEAAkE;IAClE,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,6DAA6D;IAC7D,cAAc,EAAE,MAAM,CAAC;IACvB,0EAA0E;IAC1E,eAAe,EAAE,OAAO,CAAC;CAC1B;AAED,MAAM,WAAW,wBAAwB;IACvC,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,6BAA6B,EAAE,CAAC;IAC5C,6BAA6B,EAAE,KAAK,CAAC;QACnC,YAAY,EAAE,MAAM,CAAC;QACrB,KAAK,EAAE,MAAM,CAAC;QACd,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC,CAAC;CACJ;AAED,MAAM,WAAW,+BAA+B;IAC9C,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,KAAK,CAAC;QACf,YAAY,EAAE,MAAM,CAAC;QACrB,cAAc,EAAE,MAAM,CAAC;QACvB,eAAe,EAAE,MAAM,CAAC;QACxB,eAAe,EAAE,MAAM,CAAC;KACzB,CAAC,CAAC;IACH,OAAO,EAAE,KAAK,CAAC;QACb,YAAY,EAAE,MAAM,CAAC;QACrB,MAAM,EAAE,kBAAkB,GAAG,2BAA2B,CAAC;KAC1D,CAAC,CAAC;CACJ;AAED;;;;GAIG;AACH,MAAM,WAAW,sBAAsB;IACrC,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC;IACnE,wBAAwB,CACtB,UAAU,EAAE,qBAAqB,EACjC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAChC,OAAO,CAAC,IAAI,CAAC,CAAC;CAClB;AAED;;;GAGG;AACH,MAAM,WAAW,yBAAyB;IACxC,QAAQ,CAAC,IAAI,EAAE,iBAAiB,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAChE;AAkCD;;GAEG;AACH,wBAAsB,6BAA6B,CAAC,IAAI,EAAE;IACxD,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,sBAAsB,CAAC;IAC/B,GAAG,CAAC,EAAE,IAAI,CAAC;CACZ,GAAG,OAAO,CAAC,wBAAwB,CAAC,CA+CpC;AAED;;;;GAIG;AACH,wBAAsB,yBAAyB,CAAC,IAAI,EAAE;IACpD,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,sBAAsB,CAAC;IAC/B,IAAI,EAAE,yBAAyB,CAAC;IAChC,GAAG,CAAC,EAAE,IAAI,CAAC;IACX,qEAAqE;IACrE,eAAe,CAAC,EAAE,WAAW,CAAC,MAAM,EAAE,qBAAqB,CAAC,CAAC;CAC9D,GAAG,OAAO,CAAC,+BAA+B,CAAC,CAqE3C"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import {
|
|
2
|
+
HABIT_STARTER_KEYS,
|
|
3
|
+
HABIT_STARTER_RECORDS
|
|
4
|
+
} from "../../default-packs/habit-starters.js";
|
|
5
|
+
const LEGACY_SEED_KEY_PREFIX = "load-test-user-profile";
|
|
6
|
+
const HABIT_STARTER_BY_KEY = new Map(
|
|
7
|
+
Object.entries(HABIT_STARTER_KEYS).map(([_, key]) => {
|
|
8
|
+
const record = HABIT_STARTER_RECORDS.find(
|
|
9
|
+
(r) => r.metadata?.recordKey === key
|
|
10
|
+
);
|
|
11
|
+
if (!record) {
|
|
12
|
+
throw new Error(
|
|
13
|
+
`[seed-routine-migrator] Internal: no habit starter for key ${key}`
|
|
14
|
+
);
|
|
15
|
+
}
|
|
16
|
+
return [key, record];
|
|
17
|
+
})
|
|
18
|
+
);
|
|
19
|
+
function readSeedKey(metadata) {
|
|
20
|
+
const seedKey = metadata.seedKey;
|
|
21
|
+
return typeof seedKey === "string" && seedKey.length > 0 ? seedKey : null;
|
|
22
|
+
}
|
|
23
|
+
function readMigratedTaskId(metadata) {
|
|
24
|
+
const taskId = metadata.migratedToScheduledTaskId;
|
|
25
|
+
return typeof taskId === "string" && taskId.length > 0 ? taskId : null;
|
|
26
|
+
}
|
|
27
|
+
function legacySeedKeyToHabitStarterKey(seedKey) {
|
|
28
|
+
if (!seedKey.startsWith(`${LEGACY_SEED_KEY_PREFIX}:`)) {
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
return seedKey.slice(LEGACY_SEED_KEY_PREFIX.length + 1);
|
|
32
|
+
}
|
|
33
|
+
async function buildSeedRoutineMigrationDiff(args) {
|
|
34
|
+
const generatedAt = (args.now ?? /* @__PURE__ */ new Date()).toISOString();
|
|
35
|
+
const definitions = await args.reader.listDefinitions(args.agentId);
|
|
36
|
+
const candidates = [];
|
|
37
|
+
const legacyDefinitionsWithoutMatch = [];
|
|
38
|
+
for (const definition of definitions) {
|
|
39
|
+
const seedKey = readSeedKey(definition.metadata);
|
|
40
|
+
if (!seedKey?.startsWith(`${LEGACY_SEED_KEY_PREFIX}:`)) {
|
|
41
|
+
continue;
|
|
42
|
+
}
|
|
43
|
+
const habitKey = legacySeedKeyToHabitStarterKey(seedKey);
|
|
44
|
+
if (habitKey === null) {
|
|
45
|
+
legacyDefinitionsWithoutMatch.push({
|
|
46
|
+
definitionId: definition.id,
|
|
47
|
+
title: definition.title,
|
|
48
|
+
seedKey
|
|
49
|
+
});
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
const scheduledTaskSeed = HABIT_STARTER_BY_KEY.get(habitKey);
|
|
53
|
+
if (!scheduledTaskSeed) {
|
|
54
|
+
legacyDefinitionsWithoutMatch.push({
|
|
55
|
+
definitionId: definition.id,
|
|
56
|
+
title: definition.title,
|
|
57
|
+
seedKey
|
|
58
|
+
});
|
|
59
|
+
continue;
|
|
60
|
+
}
|
|
61
|
+
candidates.push({
|
|
62
|
+
definitionId: definition.id,
|
|
63
|
+
title: definition.title,
|
|
64
|
+
habitStarterKey: habitKey,
|
|
65
|
+
scheduledTaskSeed,
|
|
66
|
+
idempotencyKey: seedKey,
|
|
67
|
+
alreadyMigrated: readMigratedTaskId(definition.metadata) !== null
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
return {
|
|
71
|
+
agentId: args.agentId,
|
|
72
|
+
generatedAt,
|
|
73
|
+
candidates,
|
|
74
|
+
legacyDefinitionsWithoutMatch
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
async function applySeedRoutineMigration(args) {
|
|
78
|
+
const appliedAt = (args.now ?? /* @__PURE__ */ new Date()).toISOString();
|
|
79
|
+
const diff = await buildSeedRoutineMigrationDiff({
|
|
80
|
+
agentId: args.agentId,
|
|
81
|
+
reader: args.reader,
|
|
82
|
+
now: args.now
|
|
83
|
+
});
|
|
84
|
+
const scheduled = [];
|
|
85
|
+
const skipped = [];
|
|
86
|
+
const definitionsById = args.definitionsById ?? new Map(
|
|
87
|
+
(await args.reader.listDefinitions(args.agentId)).map(
|
|
88
|
+
(d) => [d.id, d]
|
|
89
|
+
)
|
|
90
|
+
);
|
|
91
|
+
for (const candidate of diff.candidates) {
|
|
92
|
+
if (candidate.alreadyMigrated) {
|
|
93
|
+
skipped.push({
|
|
94
|
+
definitionId: candidate.definitionId,
|
|
95
|
+
reason: "already_migrated"
|
|
96
|
+
});
|
|
97
|
+
continue;
|
|
98
|
+
}
|
|
99
|
+
const seedWithIdempotency = {
|
|
100
|
+
...candidate.scheduledTaskSeed,
|
|
101
|
+
idempotencyKey: candidate.idempotencyKey,
|
|
102
|
+
metadata: {
|
|
103
|
+
...candidate.scheduledTaskSeed.metadata ?? {},
|
|
104
|
+
migratedFromLegacyDefinitionId: candidate.definitionId,
|
|
105
|
+
migratedFromSeedKey: candidate.idempotencyKey
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
const result = await args.sink.schedule(seedWithIdempotency);
|
|
109
|
+
scheduled.push({
|
|
110
|
+
definitionId: candidate.definitionId,
|
|
111
|
+
idempotencyKey: candidate.idempotencyKey,
|
|
112
|
+
habitStarterKey: candidate.habitStarterKey,
|
|
113
|
+
scheduledTaskId: result.taskId
|
|
114
|
+
});
|
|
115
|
+
const definition = definitionsById.get(candidate.definitionId);
|
|
116
|
+
if (definition) {
|
|
117
|
+
await args.reader.updateDefinitionMetadata(definition, {
|
|
118
|
+
...definition.metadata,
|
|
119
|
+
migratedToScheduledTaskId: result.taskId,
|
|
120
|
+
migratedAt: appliedAt
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
for (const orphan of diff.legacyDefinitionsWithoutMatch) {
|
|
125
|
+
skipped.push({
|
|
126
|
+
definitionId: orphan.definitionId,
|
|
127
|
+
reason: "no_matching_habit_starter"
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
return {
|
|
131
|
+
agentId: args.agentId,
|
|
132
|
+
appliedAt,
|
|
133
|
+
scheduled,
|
|
134
|
+
skipped
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
export {
|
|
138
|
+
LEGACY_SEED_KEY_PREFIX,
|
|
139
|
+
applySeedRoutineMigration,
|
|
140
|
+
buildSeedRoutineMigrationDiff
|
|
141
|
+
};
|
|
142
|
+
//# sourceMappingURL=migrator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/lifeops/seed-routine-migration/migrator.ts"],"sourcesContent":["/**\n * One-shot migrator from legacy `LifeOpsDefinition` rows\n * (carrying the `metadata.seedKey === \"load-test-user-profile:<key>\"`\n * marker that the deleted `applySeedRoutines` API used to write) to the\n * new `default-packs/habit-starters.ts` `ScheduledTask` records.\n *\n * Behaviour:\n *\n * - **Dry-run by default.** Reads the legacy definitions for the\n * supplied agent id, resolves the corresponding habit-starter\n * `ScheduledTaskSeed` for each row, and emits a structured JSON\n * manual-review report. **No writes are issued.**\n *\n * - **`--apply` writes.** When `apply: true` is passed (CLI:\n * `--apply`), the migrator schedules the matching\n * `ScheduledTaskSeed` records via the supplied\n * `ScheduledTaskRunner` (using the legacy seed key as\n * `idempotencyKey`) and marks the legacy `LifeOpsDefinition` row's\n * `metadata.migratedToScheduledTaskId` so a subsequent dry-run\n * reports the row as already migrated.\n *\n * - **Architecture rule:** strong types, no `any`, no `unknown` in\n * the public surface. Failures throw — no swallowed errors, no\n * fallback values that mask broken data.\n *\n * Driver script: `plugins/plugin-personal-assistant/scripts/migrate-seed-routines.mjs`.\n */\n\nimport type { LifeOpsTaskDefinition } from \"../../contracts/index.js\";\nimport type { ScheduledTaskSeed } from \"../../default-packs/contract-types.js\";\nimport {\n HABIT_STARTER_KEYS,\n HABIT_STARTER_RECORDS,\n} from \"../../default-packs/habit-starters.js\";\n\n/**\n * The legacy seed-key prefix written by the now-deleted\n * `applySeedRoutines` mixin method. Definitions whose\n * `metadata.seedKey` starts with this prefix are migrator candidates.\n */\nexport const LEGACY_SEED_KEY_PREFIX = \"load-test-user-profile\";\n\nexport interface SeedRoutineMigrationCandidate {\n /** Legacy `LifeOpsTaskDefinition.id`. */\n definitionId: string;\n /** Definition title (for human review). */\n title: string;\n /** Stable habit-starter key (e.g. `brush_teeth`). */\n habitStarterKey: string;\n /** The new `ScheduledTaskSeed` we would schedule on `--apply`. */\n scheduledTaskSeed: ScheduledTaskSeed;\n /** Idempotency key — equals the original legacy seed key. */\n idempotencyKey: string;\n /** True if the row has already been migrated in a prior `--apply` run. */\n alreadyMigrated: boolean;\n}\n\nexport interface SeedRoutineMigrationDiff {\n agentId: string;\n generatedAt: string;\n candidates: SeedRoutineMigrationCandidate[];\n legacyDefinitionsWithoutMatch: Array<{\n definitionId: string;\n title: string;\n seedKey: string;\n }>;\n}\n\nexport interface SeedRoutineMigrationApplyResult {\n agentId: string;\n appliedAt: string;\n scheduled: Array<{\n definitionId: string;\n idempotencyKey: string;\n habitStarterKey: string;\n scheduledTaskId: string;\n }>;\n skipped: Array<{\n definitionId: string;\n reason: \"already_migrated\" | \"no_matching_habit_starter\";\n }>;\n}\n\n/**\n * Read-only handle into the legacy `LifeOpsDefinition` table that the\n * migrator needs. Production callers pass `LifeOpsRepository`; tests\n * pass a thin in-memory fake.\n */\nexport interface LegacyDefinitionReader {\n listDefinitions(agentId: string): Promise<LifeOpsTaskDefinition[]>;\n updateDefinitionMetadata(\n definition: LifeOpsTaskDefinition,\n metadata: Record<string, unknown>,\n ): Promise<void>;\n}\n\n/**\n * Subset of the `ScheduledTaskRunner` surface the migrator needs during\n * `--apply`.\n */\nexport interface ScheduledTaskScheduleSink {\n schedule(seed: ScheduledTaskSeed): Promise<{ taskId: string }>;\n}\n\nconst HABIT_STARTER_BY_KEY: ReadonlyMap<string, ScheduledTaskSeed> = new Map(\n Object.entries(HABIT_STARTER_KEYS).map(([_, key]) => {\n const record = HABIT_STARTER_RECORDS.find(\n (r) => (r.metadata?.recordKey as string | undefined) === key,\n );\n if (!record) {\n throw new Error(\n `[seed-routine-migrator] Internal: no habit starter for key ${key}`,\n );\n }\n return [key, record] as const;\n }),\n);\n\nfunction readSeedKey(metadata: Record<string, unknown>): string | null {\n const seedKey = metadata.seedKey;\n return typeof seedKey === \"string\" && seedKey.length > 0 ? seedKey : null;\n}\n\nfunction readMigratedTaskId(metadata: Record<string, unknown>): string | null {\n const taskId = metadata.migratedToScheduledTaskId;\n return typeof taskId === \"string\" && taskId.length > 0 ? taskId : null;\n}\n\nfunction legacySeedKeyToHabitStarterKey(seedKey: string): string | null {\n // Legacy format: \"load-test-user-profile:<habitKey>\"\n if (!seedKey.startsWith(`${LEGACY_SEED_KEY_PREFIX}:`)) {\n return null;\n }\n return seedKey.slice(LEGACY_SEED_KEY_PREFIX.length + 1);\n}\n\n/**\n * Build the migration diff (dry-run output). Performs no writes.\n */\nexport async function buildSeedRoutineMigrationDiff(args: {\n agentId: string;\n reader: LegacyDefinitionReader;\n now?: Date;\n}): Promise<SeedRoutineMigrationDiff> {\n const generatedAt = (args.now ?? new Date()).toISOString();\n const definitions = await args.reader.listDefinitions(args.agentId);\n\n const candidates: SeedRoutineMigrationCandidate[] = [];\n const legacyDefinitionsWithoutMatch: SeedRoutineMigrationDiff[\"legacyDefinitionsWithoutMatch\"] =\n [];\n\n for (const definition of definitions) {\n const seedKey = readSeedKey(definition.metadata);\n if (!seedKey?.startsWith(`${LEGACY_SEED_KEY_PREFIX}:`)) {\n continue;\n }\n const habitKey = legacySeedKeyToHabitStarterKey(seedKey);\n if (habitKey === null) {\n legacyDefinitionsWithoutMatch.push({\n definitionId: definition.id,\n title: definition.title,\n seedKey,\n });\n continue;\n }\n const scheduledTaskSeed = HABIT_STARTER_BY_KEY.get(habitKey);\n if (!scheduledTaskSeed) {\n legacyDefinitionsWithoutMatch.push({\n definitionId: definition.id,\n title: definition.title,\n seedKey,\n });\n continue;\n }\n candidates.push({\n definitionId: definition.id,\n title: definition.title,\n habitStarterKey: habitKey,\n scheduledTaskSeed,\n idempotencyKey: seedKey,\n alreadyMigrated: readMigratedTaskId(definition.metadata) !== null,\n });\n }\n\n return {\n agentId: args.agentId,\n generatedAt,\n candidates,\n legacyDefinitionsWithoutMatch,\n };\n}\n\n/**\n * Apply the migration: schedule each candidate `ScheduledTaskSeed` via\n * the runner sink, and stamp `metadata.migratedToScheduledTaskId` on\n * the legacy definition so the row is skipped on subsequent runs.\n */\nexport async function applySeedRoutineMigration(args: {\n agentId: string;\n reader: LegacyDefinitionReader;\n sink: ScheduledTaskScheduleSink;\n now?: Date;\n /** Source of legacy definitions whose metadata may need stamping. */\n definitionsById?: ReadonlyMap<string, LifeOpsTaskDefinition>;\n}): Promise<SeedRoutineMigrationApplyResult> {\n const appliedAt = (args.now ?? new Date()).toISOString();\n const diff = await buildSeedRoutineMigrationDiff({\n agentId: args.agentId,\n reader: args.reader,\n now: args.now,\n });\n\n const scheduled: SeedRoutineMigrationApplyResult[\"scheduled\"] = [];\n const skipped: SeedRoutineMigrationApplyResult[\"skipped\"] = [];\n\n // Build a fresh definitions-by-id index unless the caller already\n // computed it.\n const definitionsById =\n args.definitionsById ??\n new Map(\n (await args.reader.listDefinitions(args.agentId)).map(\n (d) => [d.id, d] as const,\n ),\n );\n\n for (const candidate of diff.candidates) {\n if (candidate.alreadyMigrated) {\n skipped.push({\n definitionId: candidate.definitionId,\n reason: \"already_migrated\",\n });\n continue;\n }\n const seedWithIdempotency: ScheduledTaskSeed = {\n ...candidate.scheduledTaskSeed,\n idempotencyKey: candidate.idempotencyKey,\n metadata: {\n ...(candidate.scheduledTaskSeed.metadata ?? {}),\n migratedFromLegacyDefinitionId: candidate.definitionId,\n migratedFromSeedKey: candidate.idempotencyKey,\n },\n };\n const result = await args.sink.schedule(seedWithIdempotency);\n scheduled.push({\n definitionId: candidate.definitionId,\n idempotencyKey: candidate.idempotencyKey,\n habitStarterKey: candidate.habitStarterKey,\n scheduledTaskId: result.taskId,\n });\n\n const definition = definitionsById.get(candidate.definitionId);\n if (definition) {\n await args.reader.updateDefinitionMetadata(definition, {\n ...definition.metadata,\n migratedToScheduledTaskId: result.taskId,\n migratedAt: appliedAt,\n });\n }\n }\n\n for (const orphan of diff.legacyDefinitionsWithoutMatch) {\n skipped.push({\n definitionId: orphan.definitionId,\n reason: \"no_matching_habit_starter\",\n });\n }\n\n return {\n agentId: args.agentId,\n appliedAt,\n scheduled,\n skipped,\n };\n}\n"],"mappings":"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","names":[]}
|