@elizaos/plugin-personal-assistant 2.0.3-beta.5 → 2.0.3-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/app-block.d.ts +15 -0
- package/dist/actions/app-block.d.ts.map +1 -0
- package/dist/actions/app-block.js +349 -0
- package/dist/actions/app-block.js.map +1 -0
- package/dist/actions/autofill.d.ts +20 -0
- package/dist/actions/autofill.d.ts.map +1 -0
- package/dist/actions/autofill.js +370 -0
- package/dist/actions/autofill.js.map +1 -0
- package/dist/actions/block.d.ts +30 -0
- package/dist/actions/block.d.ts.map +1 -0
- package/dist/actions/block.js +326 -0
- package/dist/actions/block.js.map +1 -0
- package/dist/actions/book-travel.d.ts +10 -0
- package/dist/actions/book-travel.d.ts.map +1 -0
- package/dist/actions/book-travel.js +467 -0
- package/dist/actions/book-travel.js.map +1 -0
- package/dist/actions/brief.d.ts +60 -0
- package/dist/actions/brief.d.ts.map +1 -0
- package/dist/actions/brief.js +485 -0
- package/dist/actions/brief.js.map +1 -0
- package/dist/actions/calendar.d.ts +22 -0
- package/dist/actions/calendar.d.ts.map +1 -0
- package/dist/actions/calendar.js +832 -0
- package/dist/actions/calendar.js.map +1 -0
- package/dist/actions/conflict-detect.d.ts +67 -0
- package/dist/actions/conflict-detect.d.ts.map +1 -0
- package/dist/actions/conflict-detect.js +310 -0
- package/dist/actions/conflict-detect.js.map +1 -0
- package/dist/actions/connector.d.ts +5 -0
- package/dist/actions/connector.d.ts.map +1 -0
- package/dist/actions/connector.js +1354 -0
- package/dist/actions/connector.js.map +1 -0
- package/dist/actions/credentials.d.ts +14 -0
- package/dist/actions/credentials.d.ts.map +1 -0
- package/dist/actions/credentials.js +191 -0
- package/dist/actions/credentials.js.map +1 -0
- package/dist/actions/document.d.ts +36 -0
- package/dist/actions/document.d.ts.map +1 -0
- package/dist/actions/document.js +613 -0
- package/dist/actions/document.js.map +1 -0
- package/dist/actions/entity.d.ts +20 -0
- package/dist/actions/entity.d.ts.map +1 -0
- package/dist/actions/entity.js +785 -0
- package/dist/actions/entity.js.map +1 -0
- package/dist/actions/health.d.ts +4 -0
- package/dist/actions/health.d.ts.map +1 -0
- package/dist/actions/health.js +37 -0
- package/dist/actions/health.js.map +1 -0
- package/dist/actions/inbox.d.ts +12 -0
- package/dist/actions/inbox.d.ts.map +1 -0
- package/dist/actions/inbox.js +13 -0
- package/dist/actions/inbox.js.map +1 -0
- package/dist/actions/lib/calendly-handler.d.ts +3 -0
- package/dist/actions/lib/calendly-handler.d.ts.map +1 -0
- package/dist/actions/lib/calendly-handler.js +506 -0
- package/dist/actions/lib/calendly-handler.js.map +1 -0
- package/dist/actions/lib/extract-goal-plan.d.ts +69 -0
- package/dist/actions/lib/extract-goal-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-goal-plan.js +488 -0
- package/dist/actions/lib/extract-goal-plan.js.map +1 -0
- package/dist/actions/lib/extract-life-operation.d.ts +18 -0
- package/dist/actions/lib/extract-life-operation.d.ts.map +1 -0
- package/dist/actions/lib/extract-life-operation.js +318 -0
- package/dist/actions/lib/extract-life-operation.js.map +1 -0
- package/dist/actions/lib/extract-task-plan.d.ts +78 -0
- package/dist/actions/lib/extract-task-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-task-plan.js +355 -0
- package/dist/actions/lib/extract-task-plan.js.map +1 -0
- package/dist/actions/lib/extract-update-fields.d.ts +27 -0
- package/dist/actions/lib/extract-update-fields.d.ts.map +1 -0
- package/dist/actions/lib/extract-update-fields.js +172 -0
- package/dist/actions/lib/extract-update-fields.js.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts +68 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.js +315 -0
- package/dist/actions/lib/lifeops-deferred-draft.js.map +1 -0
- package/dist/actions/lib/messaging-helpers.d.ts +20 -0
- package/dist/actions/lib/messaging-helpers.d.ts.map +1 -0
- package/dist/actions/lib/messaging-helpers.js +103 -0
- package/dist/actions/lib/messaging-helpers.js.map +1 -0
- package/dist/actions/lib/owner-policy-writes.d.ts +49 -0
- package/dist/actions/lib/owner-policy-writes.d.ts.map +1 -0
- package/dist/actions/lib/owner-policy-writes.js +157 -0
- package/dist/actions/lib/owner-policy-writes.js.map +1 -0
- package/dist/actions/lib/prompt-format.d.ts +3 -0
- package/dist/actions/lib/prompt-format.d.ts.map +1 -0
- package/dist/actions/lib/prompt-format.js +42 -0
- package/dist/actions/lib/prompt-format.js.map +1 -0
- package/dist/actions/lib/scheduling-handler.d.ts +93 -0
- package/dist/actions/lib/scheduling-handler.d.ts.map +1 -0
- package/dist/actions/lib/scheduling-handler.js +868 -0
- package/dist/actions/lib/scheduling-handler.js.map +1 -0
- package/dist/actions/life.d.ts +13 -0
- package/dist/actions/life.d.ts.map +1 -0
- package/dist/actions/life.js +2524 -0
- package/dist/actions/life.js.map +1 -0
- package/dist/actions/money.d.ts +24 -0
- package/dist/actions/money.d.ts.map +1 -0
- package/dist/actions/money.js +41 -0
- package/dist/actions/money.js.map +1 -0
- package/dist/actions/owner-surfaces.d.ts +11 -0
- package/dist/actions/owner-surfaces.d.ts.map +1 -0
- package/dist/actions/owner-surfaces.js +493 -0
- package/dist/actions/owner-surfaces.js.map +1 -0
- package/dist/actions/password-manager.d.ts +10 -0
- package/dist/actions/password-manager.d.ts.map +1 -0
- package/dist/actions/password-manager.js +195 -0
- package/dist/actions/password-manager.js.map +1 -0
- package/dist/actions/payments.d.ts +10 -0
- package/dist/actions/payments.d.ts.map +1 -0
- package/dist/actions/payments.js +5 -0
- package/dist/actions/payments.js.map +1 -0
- package/dist/actions/prioritize.d.ts +49 -0
- package/dist/actions/prioritize.d.ts.map +1 -0
- package/dist/actions/prioritize.js +313 -0
- package/dist/actions/prioritize.js.map +1 -0
- package/dist/actions/remote-desktop.d.ts +13 -0
- package/dist/actions/remote-desktop.d.ts.map +1 -0
- package/dist/actions/remote-desktop.js +11 -0
- package/dist/actions/remote-desktop.js.map +1 -0
- package/dist/actions/resolve-request.d.ts +12 -0
- package/dist/actions/resolve-request.d.ts.map +1 -0
- package/dist/actions/resolve-request.js +427 -0
- package/dist/actions/resolve-request.js.map +1 -0
- package/dist/actions/schedule.d.ts +10 -0
- package/dist/actions/schedule.d.ts.map +1 -0
- package/dist/actions/schedule.js +113 -0
- package/dist/actions/schedule.js.map +1 -0
- package/dist/actions/scheduled-task.d.ts +32 -0
- package/dist/actions/scheduled-task.d.ts.map +1 -0
- package/dist/actions/scheduled-task.js +661 -0
- package/dist/actions/scheduled-task.js.map +1 -0
- package/dist/actions/screen-time.d.ts +4 -0
- package/dist/actions/screen-time.d.ts.map +1 -0
- package/dist/actions/screen-time.js +47 -0
- package/dist/actions/screen-time.js.map +1 -0
- package/dist/actions/subscriptions.d.ts +8 -0
- package/dist/actions/subscriptions.d.ts.map +1 -0
- package/dist/actions/subscriptions.js +327 -0
- package/dist/actions/subscriptions.js.map +1 -0
- package/dist/actions/voice-call.d.ts +16 -0
- package/dist/actions/voice-call.d.ts.map +1 -0
- package/dist/actions/voice-call.js +756 -0
- package/dist/actions/voice-call.js.map +1 -0
- package/dist/actions/website-block.d.ts +15 -0
- package/dist/actions/website-block.d.ts.map +1 -0
- package/dist/actions/website-block.js +719 -0
- package/dist/actions/website-block.js.map +1 -0
- package/dist/actions/work-thread.d.ts +5 -0
- package/dist/actions/work-thread.d.ts.map +1 -0
- package/dist/actions/work-thread.js +556 -0
- package/dist/actions/work-thread.js.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts +28 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.js +61 -0
- package/dist/activity-profile/activity-tracker-repo.js.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts +52 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.js +119 -0
- package/dist/activity-profile/activity-tracker-reporting.js.map +1 -0
- package/dist/activity-profile/activity-tracker-service.d.ts +36 -0
- package/dist/activity-profile/activity-tracker-service.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-service.js +187 -0
- package/dist/activity-profile/activity-tracker-service.js.map +1 -0
- package/dist/activity-profile/analyzer.d.ts +23 -0
- package/dist/activity-profile/analyzer.d.ts.map +1 -0
- package/dist/activity-profile/analyzer.js +485 -0
- package/dist/activity-profile/analyzer.js.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts +14 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.js +159 -0
- package/dist/activity-profile/presence-signal-bridge-service.js.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts +3 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.js +21 -0
- package/dist/activity-profile/proactive-inbox-digest.js.map +1 -0
- package/dist/activity-profile/proactive-planner.d.ts +150 -0
- package/dist/activity-profile/proactive-planner.d.ts.map +1 -0
- package/dist/activity-profile/proactive-planner.js +529 -0
- package/dist/activity-profile/proactive-planner.js.map +1 -0
- package/dist/activity-profile/proactive-worker.d.ts +33 -0
- package/dist/activity-profile/proactive-worker.d.ts.map +1 -0
- package/dist/activity-profile/proactive-worker.js +779 -0
- package/dist/activity-profile/proactive-worker.js.map +1 -0
- package/dist/activity-profile/profile-metadata.d.ts +10 -0
- package/dist/activity-profile/profile-metadata.d.ts.map +1 -0
- package/dist/activity-profile/profile-metadata.js +16 -0
- package/dist/activity-profile/profile-metadata.js.map +1 -0
- package/dist/activity-profile/redactor.d.ts +15 -0
- package/dist/activity-profile/redactor.d.ts.map +1 -0
- package/dist/activity-profile/redactor.js +22 -0
- package/dist/activity-profile/redactor.js.map +1 -0
- package/dist/activity-profile/service.d.ts +11 -0
- package/dist/activity-profile/service.d.ts.map +1 -0
- package/dist/activity-profile/service.js +272 -0
- package/dist/activity-profile/service.js.map +1 -0
- package/dist/activity-profile/types.d.ts +97 -0
- package/dist/activity-profile/types.d.ts.map +1 -0
- package/dist/activity-profile/types.js +36 -0
- package/dist/activity-profile/types.js.map +1 -0
- package/dist/agent-lifeops.d.ts +2 -0
- package/dist/agent-lifeops.d.ts.map +1 -0
- package/dist/agent-lifeops.js +2 -0
- package/dist/agent-lifeops.js.map +1 -0
- package/dist/api/client-lifeops.d.ts +319 -0
- package/dist/api/client-lifeops.d.ts.map +1 -0
- package/dist/api/client-lifeops.js +794 -0
- package/dist/api/client-lifeops.js.map +1 -0
- package/dist/automation-node-contributor.d.ts +2 -0
- package/dist/automation-node-contributor.d.ts.map +1 -0
- package/dist/automation-node-contributor.js +184 -0
- package/dist/automation-node-contributor.js.map +1 -0
- package/dist/client.d.ts +16 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +18 -0
- package/dist/client.js.map +1 -0
- package/dist/components/AppBlockerSettingsCard.d.ts +3 -0
- package/dist/components/AppBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/AppBlockerSettingsCard.js +538 -0
- package/dist/components/AppBlockerSettingsCard.js.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts +3 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.js +148 -0
- package/dist/components/WebsiteBlockerSettingsCard.js.map +1 -0
- package/dist/contracts/index.d.ts +2 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/index.js +2 -0
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/lifeops.d.ts +2 -0
- package/dist/contracts/lifeops.d.ts.map +1 -0
- package/dist/contracts/lifeops.js +2 -0
- package/dist/contracts/lifeops.js.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts +17 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.js +56 -0
- package/dist/default-packs/autofill-whitelist-pack.js.map +1 -0
- package/dist/default-packs/consolidation-policies.d.ts +14 -0
- package/dist/default-packs/consolidation-policies.d.ts.map +1 -0
- package/dist/default-packs/consolidation-policies.js +17 -0
- package/dist/default-packs/consolidation-policies.js.map +1 -0
- package/dist/default-packs/contract-types.d.ts +200 -0
- package/dist/default-packs/contract-types.d.ts.map +1 -0
- package/dist/default-packs/contract-types.js +1 -0
- package/dist/default-packs/contract-types.js.map +1 -0
- package/dist/default-packs/daily-rhythm.d.ts +28 -0
- package/dist/default-packs/daily-rhythm.d.ts.map +1 -0
- package/dist/default-packs/daily-rhythm.js +136 -0
- package/dist/default-packs/daily-rhythm.js.map +1 -0
- package/dist/default-packs/escalation-ladders.d.ts +18 -0
- package/dist/default-packs/escalation-ladders.d.ts.map +1 -0
- package/dist/default-packs/escalation-ladders.js +17 -0
- package/dist/default-packs/escalation-ladders.js.map +1 -0
- package/dist/default-packs/executive-assistant.d.ts +50 -0
- package/dist/default-packs/executive-assistant.d.ts.map +1 -0
- package/dist/default-packs/executive-assistant.js +745 -0
- package/dist/default-packs/executive-assistant.js.map +1 -0
- package/dist/default-packs/followup-starter.d.ts +49 -0
- package/dist/default-packs/followup-starter.d.ts.map +1 -0
- package/dist/default-packs/followup-starter.js +104 -0
- package/dist/default-packs/followup-starter.js.map +1 -0
- package/dist/default-packs/habit-starters.d.ts +37 -0
- package/dist/default-packs/habit-starters.d.ts.map +1 -0
- package/dist/default-packs/habit-starters.js +255 -0
- package/dist/default-packs/habit-starters.js.map +1 -0
- package/dist/default-packs/inbox-triage-starter.d.ts +23 -0
- package/dist/default-packs/inbox-triage-starter.d.ts.map +1 -0
- package/dist/default-packs/inbox-triage-starter.js +61 -0
- package/dist/default-packs/inbox-triage-starter.js.map +1 -0
- package/dist/default-packs/index.d.ts +54 -0
- package/dist/default-packs/index.d.ts.map +1 -0
- package/dist/default-packs/index.js +150 -0
- package/dist/default-packs/index.js.map +1 -0
- package/dist/default-packs/lint.d.ts +62 -0
- package/dist/default-packs/lint.d.ts.map +1 -0
- package/dist/default-packs/lint.js +161 -0
- package/dist/default-packs/lint.js.map +1 -0
- package/dist/default-packs/morning-brief.d.ts +44 -0
- package/dist/default-packs/morning-brief.d.ts.map +1 -0
- package/dist/default-packs/morning-brief.js +69 -0
- package/dist/default-packs/morning-brief.js.map +1 -0
- package/dist/default-packs/quiet-user-watcher.d.ts +49 -0
- package/dist/default-packs/quiet-user-watcher.d.ts.map +1 -0
- package/dist/default-packs/quiet-user-watcher.js +92 -0
- package/dist/default-packs/quiet-user-watcher.js.map +1 -0
- package/dist/default-packs/registry-types.d.ts +51 -0
- package/dist/default-packs/registry-types.d.ts.map +1 -0
- package/dist/default-packs/registry-types.js +1 -0
- package/dist/default-packs/registry-types.js.map +1 -0
- package/dist/default-packs/task-definitions.d.ts +88 -0
- package/dist/default-packs/task-definitions.d.ts.map +1 -0
- package/dist/default-packs/task-definitions.js +87 -0
- package/dist/default-packs/task-definitions.js.map +1 -0
- package/dist/events/index.d.ts +34 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +30 -0
- package/dist/events/index.js.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts +3 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.js +90 -0
- package/dist/followup/actions/listOverdueFollowups.js.map +1 -0
- package/dist/followup/actions/markFollowupDone.d.ts +3 -0
- package/dist/followup/actions/markFollowupDone.d.ts.map +1 -0
- package/dist/followup/actions/markFollowupDone.js +171 -0
- package/dist/followup/actions/markFollowupDone.js.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts +3 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.js +171 -0
- package/dist/followup/actions/setFollowupThreshold.js.map +1 -0
- package/dist/followup/followup-tracker.d.ts +83 -0
- package/dist/followup/followup-tracker.d.ts.map +1 -0
- package/dist/followup/followup-tracker.js +311 -0
- package/dist/followup/followup-tracker.js.map +1 -0
- package/dist/followup/index.d.ts +5 -0
- package/dist/followup/index.d.ts.map +1 -0
- package/dist/followup/index.js +39 -0
- package/dist/followup/index.js.map +1 -0
- package/dist/hooks/connector-error.d.ts +2 -0
- package/dist/hooks/connector-error.d.ts.map +1 -0
- package/dist/hooks/connector-error.js +13 -0
- package/dist/hooks/connector-error.js.map +1 -0
- package/dist/hooks/useDiscordConnector.d.ts +11 -0
- package/dist/hooks/useDiscordConnector.d.ts.map +1 -0
- package/dist/hooks/useDiscordConnector.js +95 -0
- package/dist/hooks/useDiscordConnector.js.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts +23 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js +630 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js.map +1 -0
- package/dist/hooks/useIMessageConnector.d.ts +10 -0
- package/dist/hooks/useIMessageConnector.d.ts.map +1 -0
- package/dist/hooks/useIMessageConnector.js +57 -0
- package/dist/hooks/useIMessageConnector.js.map +1 -0
- package/dist/hooks/useInbox.d.ts +36 -0
- package/dist/hooks/useInbox.d.ts.map +1 -0
- package/dist/hooks/useInbox.js +96 -0
- package/dist/hooks/useInbox.js.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts +2 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.js +358 -0
- package/dist/hooks/useLifeOpsActivitySignals.js.map +1 -0
- package/dist/hooks/useLifeOpsAppState.d.ts +9 -0
- package/dist/hooks/useLifeOpsAppState.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsAppState.js +79 -0
- package/dist/hooks/useLifeOpsAppState.js.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts +8 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js +60 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts +11 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.js +92 -0
- package/dist/hooks/useLifeOpsXConnector.js.map +1 -0
- package/dist/hooks/useSignalConnector.d.ts +14 -0
- package/dist/hooks/useSignalConnector.d.ts.map +1 -0
- package/dist/hooks/useSignalConnector.js +89 -0
- package/dist/hooks/useSignalConnector.js.map +1 -0
- package/dist/hooks/useTelegramConnector.d.ts +14 -0
- package/dist/hooks/useTelegramConnector.d.ts.map +1 -0
- package/dist/hooks/useTelegramConnector.js +97 -0
- package/dist/hooks/useTelegramConnector.js.map +1 -0
- package/dist/hooks/useWhatsAppConnector.d.ts +8 -0
- package/dist/hooks/useWhatsAppConnector.d.ts.map +1 -0
- package/dist/hooks/useWhatsAppConnector.js +62 -0
- package/dist/hooks/useWhatsAppConnector.js.map +1 -0
- package/dist/inbox/message-fetcher.d.ts +11 -0
- package/dist/inbox/message-fetcher.d.ts.map +1 -0
- package/dist/inbox/message-fetcher.js +13 -0
- package/dist/inbox/message-fetcher.js.map +1 -0
- package/dist/inbox/repository.d.ts +11 -0
- package/dist/inbox/repository.d.ts.map +1 -0
- package/dist/inbox/repository.js +5 -0
- package/dist/inbox/repository.js.map +1 -0
- package/dist/inbox/types.d.ts +10 -0
- package/dist/inbox/types.d.ts.map +1 -0
- package/dist/inbox/types.js +2 -0
- package/dist/inbox/types.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +188 -0
- package/dist/index.js.map +1 -0
- package/dist/lifeops/access.d.ts +29 -0
- package/dist/lifeops/access.d.ts.map +1 -0
- package/dist/lifeops/access.js +56 -0
- package/dist/lifeops/access.js.map +1 -0
- package/dist/lifeops/app-state.d.ts +22 -0
- package/dist/lifeops/app-state.d.ts.map +1 -0
- package/dist/lifeops/app-state.js +67 -0
- package/dist/lifeops/app-state.js.map +1 -0
- package/dist/lifeops/apple-reminders.d.ts +67 -0
- package/dist/lifeops/apple-reminders.d.ts.map +1 -0
- package/dist/lifeops/apple-reminders.js +396 -0
- package/dist/lifeops/apple-reminders.js.map +1 -0
- package/dist/lifeops/approval-queue.d.ts +38 -0
- package/dist/lifeops/approval-queue.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.js +575 -0
- package/dist/lifeops/approval-queue.js.map +1 -0
- package/dist/lifeops/approval-queue.types.d.ts +172 -0
- package/dist/lifeops/approval-queue.types.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.types.js +27 -0
- package/dist/lifeops/approval-queue.types.js.map +1 -0
- package/dist/lifeops/autofill-whitelist.d.ts +20 -0
- package/dist/lifeops/autofill-whitelist.d.ts.map +1 -0
- package/dist/lifeops/autofill-whitelist.js +59 -0
- package/dist/lifeops/autofill-whitelist.js.map +1 -0
- package/dist/lifeops/background-planner-dispatch.d.ts +60 -0
- package/dist/lifeops/background-planner-dispatch.d.ts.map +1 -0
- package/dist/lifeops/background-planner-dispatch.js +113 -0
- package/dist/lifeops/background-planner-dispatch.js.map +1 -0
- package/dist/lifeops/background-planner.d.ts +140 -0
- package/dist/lifeops/background-planner.d.ts.map +1 -0
- package/dist/lifeops/background-planner.js +359 -0
- package/dist/lifeops/background-planner.js.map +1 -0
- package/dist/lifeops/bill-extraction.d.ts +46 -0
- package/dist/lifeops/bill-extraction.d.ts.map +1 -0
- package/dist/lifeops/bill-extraction.js +325 -0
- package/dist/lifeops/bill-extraction.js.map +1 -0
- package/dist/lifeops/browser-constants.d.ts +4 -0
- package/dist/lifeops/browser-constants.d.ts.map +1 -0
- package/dist/lifeops/browser-constants.js +27 -0
- package/dist/lifeops/browser-constants.js.map +1 -0
- package/dist/lifeops/browser-extension-store.d.ts +61 -0
- package/dist/lifeops/browser-extension-store.d.ts.map +1 -0
- package/dist/lifeops/browser-extension-store.js +176 -0
- package/dist/lifeops/browser-extension-store.js.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts +57 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.js +308 -0
- package/dist/lifeops/browser-session-lifecycle.js.map +1 -0
- package/dist/lifeops/bulk-review.d.ts +333 -0
- package/dist/lifeops/bulk-review.d.ts.map +1 -0
- package/dist/lifeops/bulk-review.js +1120 -0
- package/dist/lifeops/bulk-review.js.map +1 -0
- package/dist/lifeops/calendar-gate.d.ts +20 -0
- package/dist/lifeops/calendar-gate.d.ts.map +1 -0
- package/dist/lifeops/calendar-gate.js +30 -0
- package/dist/lifeops/calendar-gate.js.map +1 -0
- package/dist/lifeops/channels/contract.d.ts +47 -0
- package/dist/lifeops/channels/contract.d.ts.map +1 -0
- package/dist/lifeops/channels/contract.js +1 -0
- package/dist/lifeops/channels/contract.js.map +1 -0
- package/dist/lifeops/channels/default-pack.d.ts +26 -0
- package/dist/lifeops/channels/default-pack.d.ts.map +1 -0
- package/dist/lifeops/channels/default-pack.js +243 -0
- package/dist/lifeops/channels/default-pack.js.map +1 -0
- package/dist/lifeops/channels/index.d.ts +5 -0
- package/dist/lifeops/channels/index.d.ts.map +1 -0
- package/dist/lifeops/channels/index.js +23 -0
- package/dist/lifeops/channels/index.js.map +1 -0
- package/dist/lifeops/channels/priority-posture.d.ts +36 -0
- package/dist/lifeops/channels/priority-posture.d.ts.map +1 -0
- package/dist/lifeops/channels/priority-posture.js +27 -0
- package/dist/lifeops/channels/priority-posture.js.map +1 -0
- package/dist/lifeops/channels/registry.d.ts +7 -0
- package/dist/lifeops/channels/registry.d.ts.map +1 -0
- package/dist/lifeops/channels/registry.js +49 -0
- package/dist/lifeops/channels/registry.js.map +1 -0
- package/dist/lifeops/checkin/checkin-service.d.ts +66 -0
- package/dist/lifeops/checkin/checkin-service.d.ts.map +1 -0
- package/dist/lifeops/checkin/checkin-service.js +1084 -0
- package/dist/lifeops/checkin/checkin-service.js.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts +17 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.js +26 -0
- package/dist/lifeops/checkin/schedule-resolver.js.map +1 -0
- package/dist/lifeops/checkin/types.d.ts +106 -0
- package/dist/lifeops/checkin/types.d.ts.map +1 -0
- package/dist/lifeops/checkin/types.js +1 -0
- package/dist/lifeops/checkin/types.js.map +1 -0
- package/dist/lifeops/connectors/_helpers.d.ts +51 -0
- package/dist/lifeops/connectors/_helpers.d.ts.map +1 -0
- package/dist/lifeops/connectors/_helpers.js +104 -0
- package/dist/lifeops/connectors/_helpers.js.map +1 -0
- package/dist/lifeops/connectors/calendly.d.ts +11 -0
- package/dist/lifeops/connectors/calendly.d.ts.map +1 -0
- package/dist/lifeops/connectors/calendly.js +61 -0
- package/dist/lifeops/connectors/calendly.js.map +1 -0
- package/dist/lifeops/connectors/contract.d.ts +88 -0
- package/dist/lifeops/connectors/contract.d.ts.map +1 -0
- package/dist/lifeops/connectors/contract.js +1 -0
- package/dist/lifeops/connectors/contract.js.map +1 -0
- package/dist/lifeops/connectors/default-pack.d.ts +35 -0
- package/dist/lifeops/connectors/default-pack.d.ts.map +1 -0
- package/dist/lifeops/connectors/default-pack.js +37 -0
- package/dist/lifeops/connectors/default-pack.js.map +1 -0
- package/dist/lifeops/connectors/discord.d.ts +8 -0
- package/dist/lifeops/connectors/discord.d.ts.map +1 -0
- package/dist/lifeops/connectors/discord.js +53 -0
- package/dist/lifeops/connectors/discord.js.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts +75 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.js +35 -0
- package/dist/lifeops/connectors/dispatch-policy.js.map +1 -0
- package/dist/lifeops/connectors/duffel.d.ts +11 -0
- package/dist/lifeops/connectors/duffel.d.ts.map +1 -0
- package/dist/lifeops/connectors/duffel.js +74 -0
- package/dist/lifeops/connectors/duffel.js.map +1 -0
- package/dist/lifeops/connectors/google.d.ts +27 -0
- package/dist/lifeops/connectors/google.d.ts.map +1 -0
- package/dist/lifeops/connectors/google.js +80 -0
- package/dist/lifeops/connectors/google.js.map +1 -0
- package/dist/lifeops/connectors/imessage.d.ts +11 -0
- package/dist/lifeops/connectors/imessage.d.ts.map +1 -0
- package/dist/lifeops/connectors/imessage.js +55 -0
- package/dist/lifeops/connectors/imessage.js.map +1 -0
- package/dist/lifeops/connectors/index.d.ts +5 -0
- package/dist/lifeops/connectors/index.d.ts.map +1 -0
- package/dist/lifeops/connectors/index.js +23 -0
- package/dist/lifeops/connectors/index.js.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts +54 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.js +71 -0
- package/dist/lifeops/connectors/mockoon-redirect.js.map +1 -0
- package/dist/lifeops/connectors/registry.d.ts +7 -0
- package/dist/lifeops/connectors/registry.d.ts.map +1 -0
- package/dist/lifeops/connectors/registry.js +55 -0
- package/dist/lifeops/connectors/registry.js.map +1 -0
- package/dist/lifeops/connectors/signal.d.ts +8 -0
- package/dist/lifeops/connectors/signal.d.ts.map +1 -0
- package/dist/lifeops/connectors/signal.js +60 -0
- package/dist/lifeops/connectors/signal.js.map +1 -0
- package/dist/lifeops/connectors/telegram.d.ts +12 -0
- package/dist/lifeops/connectors/telegram.d.ts.map +1 -0
- package/dist/lifeops/connectors/telegram.js +65 -0
- package/dist/lifeops/connectors/telegram.js.map +1 -0
- package/dist/lifeops/connectors/twilio.d.ts +15 -0
- package/dist/lifeops/connectors/twilio.d.ts.map +1 -0
- package/dist/lifeops/connectors/twilio.js +126 -0
- package/dist/lifeops/connectors/twilio.js.map +1 -0
- package/dist/lifeops/connectors/whatsapp.d.ts +10 -0
- package/dist/lifeops/connectors/whatsapp.d.ts.map +1 -0
- package/dist/lifeops/connectors/whatsapp.js +56 -0
- package/dist/lifeops/connectors/whatsapp.js.map +1 -0
- package/dist/lifeops/connectors/x.d.ts +8 -0
- package/dist/lifeops/connectors/x.d.ts.map +1 -0
- package/dist/lifeops/connectors/x.js +62 -0
- package/dist/lifeops/connectors/x.js.map +1 -0
- package/dist/lifeops/contact-route-policy.d.ts +27 -0
- package/dist/lifeops/contact-route-policy.d.ts.map +1 -0
- package/dist/lifeops/contact-route-policy.js +153 -0
- package/dist/lifeops/contact-route-policy.js.map +1 -0
- package/dist/lifeops/continuity-probe.d.ts +49 -0
- package/dist/lifeops/continuity-probe.d.ts.map +1 -0
- package/dist/lifeops/continuity-probe.js +161 -0
- package/dist/lifeops/continuity-probe.js.map +1 -0
- package/dist/lifeops/cross-channel-search.d.ts +108 -0
- package/dist/lifeops/cross-channel-search.d.ts.map +1 -0
- package/dist/lifeops/cross-channel-search.js +888 -0
- package/dist/lifeops/cross-channel-search.js.map +1 -0
- package/dist/lifeops/defaults.d.ts +30 -0
- package/dist/lifeops/defaults.d.ts.map +1 -0
- package/dist/lifeops/defaults.js +206 -0
- package/dist/lifeops/defaults.js.map +1 -0
- package/dist/lifeops/device-bus-service.d.ts +16 -0
- package/dist/lifeops/device-bus-service.d.ts.map +1 -0
- package/dist/lifeops/device-bus-service.js +20 -0
- package/dist/lifeops/device-bus-service.js.map +1 -0
- package/dist/lifeops/device-identity.d.ts +31 -0
- package/dist/lifeops/device-identity.d.ts.map +1 -0
- package/dist/lifeops/device-identity.js +94 -0
- package/dist/lifeops/device-identity.js.map +1 -0
- package/dist/lifeops/document-review.d.ts +264 -0
- package/dist/lifeops/document-review.d.ts.map +1 -0
- package/dist/lifeops/document-review.js +925 -0
- package/dist/lifeops/document-review.js.map +1 -0
- package/dist/lifeops/email-classifier.d.ts +9 -0
- package/dist/lifeops/email-classifier.d.ts.map +1 -0
- package/dist/lifeops/email-classifier.js +15 -0
- package/dist/lifeops/email-classifier.js.map +1 -0
- package/dist/lifeops/email-curation.d.ts +13 -0
- package/dist/lifeops/email-curation.d.ts.map +1 -0
- package/dist/lifeops/email-curation.js +2 -0
- package/dist/lifeops/email-curation.js.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts +7 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.js +1 -0
- package/dist/lifeops/email-unsubscribe-types.js.map +1 -0
- package/dist/lifeops/enforcement-windows.d.ts +34 -0
- package/dist/lifeops/enforcement-windows.d.ts.map +1 -0
- package/dist/lifeops/enforcement-windows.js +80 -0
- package/dist/lifeops/enforcement-windows.js.map +1 -0
- package/dist/lifeops/engine.d.ts +8 -0
- package/dist/lifeops/engine.d.ts.map +1 -0
- package/dist/lifeops/engine.js +540 -0
- package/dist/lifeops/engine.js.map +1 -0
- package/dist/lifeops/entities/index.d.ts +4 -0
- package/dist/lifeops/entities/index.d.ts.map +1 -0
- package/dist/lifeops/entities/index.js +29 -0
- package/dist/lifeops/entities/index.js.map +1 -0
- package/dist/lifeops/entities/merge.d.ts +9 -0
- package/dist/lifeops/entities/merge.d.ts.map +1 -0
- package/dist/lifeops/entities/merge.js +17 -0
- package/dist/lifeops/entities/merge.js.map +1 -0
- package/dist/lifeops/entities/store.d.ts +13 -0
- package/dist/lifeops/entities/store.d.ts.map +1 -0
- package/dist/lifeops/entities/store.js +7 -0
- package/dist/lifeops/entities/store.js.map +1 -0
- package/dist/lifeops/entities/types.d.ts +9 -0
- package/dist/lifeops/entities/types.d.ts.map +1 -0
- package/dist/lifeops/entities/types.js +13 -0
- package/dist/lifeops/entities/types.js.map +1 -0
- package/dist/lifeops/entities/voice-attribution.d.ts +70 -0
- package/dist/lifeops/entities/voice-attribution.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-attribution.js +121 -0
- package/dist/lifeops/entities/voice-attribution.js.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts +32 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.js +68 -0
- package/dist/lifeops/entities/voice-observer-bridge.js.map +1 -0
- package/dist/lifeops/entities/voice-observer.d.ts +72 -0
- package/dist/lifeops/entities/voice-observer.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer.js +97 -0
- package/dist/lifeops/entities/voice-observer.js.map +1 -0
- package/dist/lifeops/escalation-ladders.d.ts +28 -0
- package/dist/lifeops/escalation-ladders.d.ts.map +1 -0
- package/dist/lifeops/escalation-ladders.js +17 -0
- package/dist/lifeops/escalation-ladders.js.map +1 -0
- package/dist/lifeops/fda-probe.d.ts +23 -0
- package/dist/lifeops/fda-probe.d.ts.map +1 -0
- package/dist/lifeops/fda-probe.js +59 -0
- package/dist/lifeops/fda-probe.js.map +1 -0
- package/dist/lifeops/feature-flags.d.ts +24 -0
- package/dist/lifeops/feature-flags.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.js +261 -0
- package/dist/lifeops/feature-flags.js.map +1 -0
- package/dist/lifeops/feature-flags.types.d.ts +156 -0
- package/dist/lifeops/feature-flags.types.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.types.js +129 -0
- package/dist/lifeops/feature-flags.types.js.map +1 -0
- package/dist/lifeops/first-run/defaults.d.ts +57 -0
- package/dist/lifeops/first-run/defaults.d.ts.map +1 -0
- package/dist/lifeops/first-run/defaults.js +159 -0
- package/dist/lifeops/first-run/defaults.js.map +1 -0
- package/dist/lifeops/first-run/questions.d.ts +74 -0
- package/dist/lifeops/first-run/questions.d.ts.map +1 -0
- package/dist/lifeops/first-run/questions.js +184 -0
- package/dist/lifeops/first-run/questions.js.map +1 -0
- package/dist/lifeops/first-run/replay.d.ts +41 -0
- package/dist/lifeops/first-run/replay.d.ts.map +1 -0
- package/dist/lifeops/first-run/replay.js +34 -0
- package/dist/lifeops/first-run/replay.js.map +1 -0
- package/dist/lifeops/first-run/service.d.ts +147 -0
- package/dist/lifeops/first-run/service.d.ts.map +1 -0
- package/dist/lifeops/first-run/service.js +455 -0
- package/dist/lifeops/first-run/service.js.map +1 -0
- package/dist/lifeops/first-run/state.d.ts +36 -0
- package/dist/lifeops/first-run/state.d.ts.map +1 -0
- package/dist/lifeops/first-run/state.js +128 -0
- package/dist/lifeops/first-run/state.js.map +1 -0
- package/dist/lifeops/global-pause/store.d.ts +22 -0
- package/dist/lifeops/global-pause/store.d.ts.map +1 -0
- package/dist/lifeops/global-pause/store.js +18 -0
- package/dist/lifeops/global-pause/store.js.map +1 -0
- package/dist/lifeops/goal-grounding.d.ts +9 -0
- package/dist/lifeops/goal-grounding.d.ts.map +1 -0
- package/dist/lifeops/goal-grounding.js +19 -0
- package/dist/lifeops/goal-grounding.js.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts +8 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.js +7 -0
- package/dist/lifeops/goal-semantic-evaluator.js.map +1 -0
- package/dist/lifeops/google/format-helpers.d.ts +63 -0
- package/dist/lifeops/google/format-helpers.d.ts.map +1 -0
- package/dist/lifeops/google/format-helpers.js +597 -0
- package/dist/lifeops/google/format-helpers.js.map +1 -0
- package/dist/lifeops/google-plugin-delegates.d.ts +59 -0
- package/dist/lifeops/google-plugin-delegates.d.ts.map +1 -0
- package/dist/lifeops/google-plugin-delegates.js +408 -0
- package/dist/lifeops/google-plugin-delegates.js.map +1 -0
- package/dist/lifeops/google-scopes.d.ts +15 -0
- package/dist/lifeops/google-scopes.d.ts.map +1 -0
- package/dist/lifeops/google-scopes.js +118 -0
- package/dist/lifeops/google-scopes.js.map +1 -0
- package/dist/lifeops/handoff/store.d.ts +23 -0
- package/dist/lifeops/handoff/store.d.ts.map +1 -0
- package/dist/lifeops/handoff/store.js +20 -0
- package/dist/lifeops/handoff/store.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts +16 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.js +33 -0
- package/dist/lifeops/i18n/localized-examples-provider.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts +32 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js +28 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts +64 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.js +283 -0
- package/dist/lifeops/i18n/prompt-registry.js.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts +7 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.js +81 -0
- package/dist/lifeops/imessage-outbound-probe.js.map +1 -0
- package/dist/lifeops/index.d.ts +24 -0
- package/dist/lifeops/index.d.ts.map +1 -0
- package/dist/lifeops/index.js +24 -0
- package/dist/lifeops/index.js.map +1 -0
- package/dist/lifeops/intent-sync.d.ts +64 -0
- package/dist/lifeops/intent-sync.d.ts.map +1 -0
- package/dist/lifeops/intent-sync.js +321 -0
- package/dist/lifeops/intent-sync.js.map +1 -0
- package/dist/lifeops/messaging/index.d.ts +2 -0
- package/dist/lifeops/messaging/index.d.ts.map +1 -0
- package/dist/lifeops/messaging/index.js +5 -0
- package/dist/lifeops/messaging/index.js.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts +3 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.js +83 -0
- package/dist/lifeops/messaging/owner-send-policy.js.map +1 -0
- package/dist/lifeops/notifications-push.d.ts +37 -0
- package/dist/lifeops/notifications-push.d.ts.map +1 -0
- package/dist/lifeops/notifications-push.js +95 -0
- package/dist/lifeops/notifications-push.js.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts +5 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.js +48 -0
- package/dist/lifeops/optimized-prompt-instructions.js.map +1 -0
- package/dist/lifeops/owner/fact-store.d.ts +143 -0
- package/dist/lifeops/owner/fact-store.d.ts.map +1 -0
- package/dist/lifeops/owner/fact-store.js +446 -0
- package/dist/lifeops/owner/fact-store.js.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts +3 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js +241 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js.map +1 -0
- package/dist/lifeops/owner-profile.d.ts +61 -0
- package/dist/lifeops/owner-profile.d.ts.map +1 -0
- package/dist/lifeops/owner-profile.js +407 -0
- package/dist/lifeops/owner-profile.js.map +1 -0
- package/dist/lifeops/pending-prompts/store.d.ts +23 -0
- package/dist/lifeops/pending-prompts/store.d.ts.map +1 -0
- package/dist/lifeops/pending-prompts/store.js +16 -0
- package/dist/lifeops/pending-prompts/store.js.map +1 -0
- package/dist/lifeops/policy-memory.d.ts +190 -0
- package/dist/lifeops/policy-memory.d.ts.map +1 -0
- package/dist/lifeops/policy-memory.js +1026 -0
- package/dist/lifeops/policy-memory.js.map +1 -0
- package/dist/lifeops/priority-scoring.d.ts +51 -0
- package/dist/lifeops/priority-scoring.d.ts.map +1 -0
- package/dist/lifeops/priority-scoring.js +305 -0
- package/dist/lifeops/priority-scoring.js.map +1 -0
- package/dist/lifeops/privacy-egress.d.ts +92 -0
- package/dist/lifeops/privacy-egress.d.ts.map +1 -0
- package/dist/lifeops/privacy-egress.js +230 -0
- package/dist/lifeops/privacy-egress.js.map +1 -0
- package/dist/lifeops/privacy.d.ts +49 -0
- package/dist/lifeops/privacy.d.ts.map +1 -0
- package/dist/lifeops/privacy.js +66 -0
- package/dist/lifeops/privacy.js.map +1 -0
- package/dist/lifeops/redact-sensitive-data.d.ts +32 -0
- package/dist/lifeops/redact-sensitive-data.d.ts.map +1 -0
- package/dist/lifeops/redact-sensitive-data.js +98 -0
- package/dist/lifeops/redact-sensitive-data.js.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts +13 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.js +73 -0
- package/dist/lifeops/registries/app-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/blocker-registry.d.ts +76 -0
- package/dist/lifeops/registries/blocker-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/blocker-registry.js +40 -0
- package/dist/lifeops/registries/blocker-registry.js.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts +57 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.js +82 -0
- package/dist/lifeops/registries/event-kind-registry.js.map +1 -0
- package/dist/lifeops/registries/family-registry.d.ts +72 -0
- package/dist/lifeops/registries/family-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/family-registry.js +98 -0
- package/dist/lifeops/registries/family-registry.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts +32 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js +36 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts +76 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.js +68 -0
- package/dist/lifeops/registries/feature-flag-registry.js.map +1 -0
- package/dist/lifeops/registries/index.d.ts +24 -0
- package/dist/lifeops/registries/index.d.ts.map +1 -0
- package/dist/lifeops/registries/index.js +115 -0
- package/dist/lifeops/registries/index.js.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts +21 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.js +76 -0
- package/dist/lifeops/registries/website-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts +30 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js +315 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts +101 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.js +56 -0
- package/dist/lifeops/registries/workflow-step-registry.js.map +1 -0
- package/dist/lifeops/relationships/extraction.d.ts +77 -0
- package/dist/lifeops/relationships/extraction.d.ts.map +1 -0
- package/dist/lifeops/relationships/extraction.js +146 -0
- package/dist/lifeops/relationships/extraction.js.map +1 -0
- package/dist/lifeops/relationships/index.d.ts +4 -0
- package/dist/lifeops/relationships/index.d.ts.map +1 -0
- package/dist/lifeops/relationships/index.js +19 -0
- package/dist/lifeops/relationships/index.js.map +1 -0
- package/dist/lifeops/relationships/mapping.d.ts +34 -0
- package/dist/lifeops/relationships/mapping.d.ts.map +1 -0
- package/dist/lifeops/relationships/mapping.js +87 -0
- package/dist/lifeops/relationships/mapping.js.map +1 -0
- package/dist/lifeops/relationships/store.d.ts +12 -0
- package/dist/lifeops/relationships/store.d.ts.map +1 -0
- package/dist/lifeops/relationships/store.js +5 -0
- package/dist/lifeops/relationships/store.js.map +1 -0
- package/dist/lifeops/relationships/types.d.ts +9 -0
- package/dist/lifeops/relationships/types.d.ts.map +1 -0
- package/dist/lifeops/relationships/types.js +11 -0
- package/dist/lifeops/relationships/types.js.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts +13 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.js +107 -0
- package/dist/lifeops/relative-schedule-resolver.js.map +1 -0
- package/dist/lifeops/relative-time.d.ts +15 -0
- package/dist/lifeops/relative-time.d.ts.map +1 -0
- package/dist/lifeops/relative-time.js +191 -0
- package/dist/lifeops/relative-time.js.map +1 -0
- package/dist/lifeops/repository.d.ts +638 -0
- package/dist/lifeops/repository.d.ts.map +1 -0
- package/dist/lifeops/repository.js +6289 -0
- package/dist/lifeops/repository.js.map +1 -0
- package/dist/lifeops/runtime-cache.d.ts +4 -0
- package/dist/lifeops/runtime-cache.d.ts.map +1 -0
- package/dist/lifeops/runtime-cache.js +7 -0
- package/dist/lifeops/runtime-cache.js.map +1 -0
- package/dist/lifeops/runtime-service-delegates.d.ts +236 -0
- package/dist/lifeops/runtime-service-delegates.d.ts.map +1 -0
- package/dist/lifeops/runtime-service-delegates.js +839 -0
- package/dist/lifeops/runtime-service-delegates.js.map +1 -0
- package/dist/lifeops/runtime.d.ts +13 -0
- package/dist/lifeops/runtime.d.ts.map +1 -0
- package/dist/lifeops/runtime.js +104 -0
- package/dist/lifeops/runtime.js.map +1 -0
- package/dist/lifeops/schedule-insight.d.ts +133 -0
- package/dist/lifeops/schedule-insight.d.ts.map +1 -0
- package/dist/lifeops/schedule-insight.js +726 -0
- package/dist/lifeops/schedule-insight.js.map +1 -0
- package/dist/lifeops/schedule-state.d.ts +39 -0
- package/dist/lifeops/schedule-state.d.ts.map +1 -0
- package/dist/lifeops/schedule-state.js +671 -0
- package/dist/lifeops/schedule-state.js.map +1 -0
- package/dist/lifeops/schedule-sync-config.d.ts +3 -0
- package/dist/lifeops/schedule-sync-config.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-config.js +23 -0
- package/dist/lifeops/schedule-sync-config.js.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts +2 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.js +2 -0
- package/dist/lifeops/schedule-sync-contracts.js.map +1 -0
- package/dist/lifeops/scheduled-task/index.d.ts +13 -0
- package/dist/lifeops/scheduled-task/index.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/index.js +14 -0
- package/dist/lifeops/scheduled-task/index.js.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts +33 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js +334 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts +28 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.js +202 -0
- package/dist/lifeops/scheduled-task/scheduler.js.map +1 -0
- package/dist/lifeops/scheduled-task/service.d.ts +61 -0
- package/dist/lifeops/scheduled-task/service.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/service.js +64 -0
- package/dist/lifeops/scheduled-task/service.js.map +1 -0
- package/dist/lifeops/scheduler-task.d.ts +19 -0
- package/dist/lifeops/scheduler-task.d.ts.map +1 -0
- package/dist/lifeops/scheduler-task.js +201 -0
- package/dist/lifeops/scheduler-task.js.map +1 -0
- package/dist/lifeops/schema.d.ts +28068 -0
- package/dist/lifeops/schema.d.ts.map +1 -0
- package/dist/lifeops/schema.js +1689 -0
- package/dist/lifeops/schema.js.map +1 -0
- package/dist/lifeops/screen-context.d.ts +66 -0
- package/dist/lifeops/screen-context.d.ts.map +1 -0
- package/dist/lifeops/screen-context.js +347 -0
- package/dist/lifeops/screen-context.js.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts +113 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.js +142 -0
- package/dist/lifeops/seed-routine-migration/migrator.js.map +1 -0
- package/dist/lifeops/seed-routines.d.ts +24 -0
- package/dist/lifeops/seed-routines.d.ts.map +1 -0
- package/dist/lifeops/seed-routines.js +140 -0
- package/dist/lifeops/seed-routines.js.map +1 -0
- package/dist/lifeops/send-policy/contract.d.ts +81 -0
- package/dist/lifeops/send-policy/contract.d.ts.map +1 -0
- package/dist/lifeops/send-policy/contract.js +1 -0
- package/dist/lifeops/send-policy/contract.js.map +1 -0
- package/dist/lifeops/send-policy/index.d.ts +3 -0
- package/dist/lifeops/send-policy/index.d.ts.map +1 -0
- package/dist/lifeops/send-policy/index.js +13 -0
- package/dist/lifeops/send-policy/index.js.map +1 -0
- package/dist/lifeops/send-policy/registry.d.ts +7 -0
- package/dist/lifeops/send-policy/registry.d.ts.map +1 -0
- package/dist/lifeops/send-policy/registry.js +62 -0
- package/dist/lifeops/send-policy/registry.js.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts +46 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.js +103 -0
- package/dist/lifeops/sensitive-request-delivery.js.map +1 -0
- package/dist/lifeops/service-constants.d.ts +10 -0
- package/dist/lifeops/service-constants.d.ts.map +1 -0
- package/dist/lifeops/service-constants.js +129 -0
- package/dist/lifeops/service-constants.js.map +1 -0
- package/dist/lifeops/service-helpers-browser.d.ts +41 -0
- package/dist/lifeops/service-helpers-browser.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-browser.js +290 -0
- package/dist/lifeops/service-helpers-browser.js.map +1 -0
- package/dist/lifeops/service-helpers-misc.d.ts +68 -0
- package/dist/lifeops/service-helpers-misc.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-misc.js +531 -0
- package/dist/lifeops/service-helpers-misc.js.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts +23 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.js +257 -0
- package/dist/lifeops/service-helpers-occurrence.js.map +1 -0
- package/dist/lifeops/service-helpers-reminder.d.ts +260 -0
- package/dist/lifeops/service-helpers-reminder.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-reminder.js +1186 -0
- package/dist/lifeops/service-helpers-reminder.js.map +1 -0
- package/dist/lifeops/service-mixin-browser.d.ts +31 -0
- package/dist/lifeops/service-mixin-browser.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-browser.js +975 -0
- package/dist/lifeops/service-mixin-browser.js.map +1 -0
- package/dist/lifeops/service-mixin-calendar.d.ts +53 -0
- package/dist/lifeops/service-mixin-calendar.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-calendar.js +68 -0
- package/dist/lifeops/service-mixin-calendar.js.map +1 -0
- package/dist/lifeops/service-mixin-core.d.ts +51 -0
- package/dist/lifeops/service-mixin-core.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-core.js +500 -0
- package/dist/lifeops/service-mixin-core.js.map +1 -0
- package/dist/lifeops/service-mixin-definitions.d.ts +14 -0
- package/dist/lifeops/service-mixin-definitions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-definitions.js +470 -0
- package/dist/lifeops/service-mixin-definitions.js.map +1 -0
- package/dist/lifeops/service-mixin-discord.d.ts +49 -0
- package/dist/lifeops/service-mixin-discord.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-discord.js +1253 -0
- package/dist/lifeops/service-mixin-discord.js.map +1 -0
- package/dist/lifeops/service-mixin-drive.d.ts +96 -0
- package/dist/lifeops/service-mixin-drive.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-drive.js +213 -0
- package/dist/lifeops/service-mixin-drive.js.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts +23 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js +27 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js.map +1 -0
- package/dist/lifeops/service-mixin-gmail.d.ts +43 -0
- package/dist/lifeops/service-mixin-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-gmail.js +727 -0
- package/dist/lifeops/service-mixin-gmail.js.map +1 -0
- package/dist/lifeops/service-mixin-goals.d.ts +22 -0
- package/dist/lifeops/service-mixin-goals.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-goals.js +884 -0
- package/dist/lifeops/service-mixin-goals.js.map +1 -0
- package/dist/lifeops/service-mixin-google.d.ts +13 -0
- package/dist/lifeops/service-mixin-google.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-google.js +398 -0
- package/dist/lifeops/service-mixin-google.js.map +1 -0
- package/dist/lifeops/service-mixin-health.d.ts +27 -0
- package/dist/lifeops/service-mixin-health.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-health.js +670 -0
- package/dist/lifeops/service-mixin-health.js.map +1 -0
- package/dist/lifeops/service-mixin-imessage.d.ts +106 -0
- package/dist/lifeops/service-mixin-imessage.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-imessage.js +303 -0
- package/dist/lifeops/service-mixin-imessage.js.map +1 -0
- package/dist/lifeops/service-mixin-inbox.d.ts +55 -0
- package/dist/lifeops/service-mixin-inbox.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-inbox.js +597 -0
- package/dist/lifeops/service-mixin-inbox.js.map +1 -0
- package/dist/lifeops/service-mixin-relationships.d.ts +65 -0
- package/dist/lifeops/service-mixin-relationships.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-relationships.js +150 -0
- package/dist/lifeops/service-mixin-relationships.js.map +1 -0
- package/dist/lifeops/service-mixin-reminders.d.ts +62 -0
- package/dist/lifeops/service-mixin-reminders.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-reminders.js +4003 -0
- package/dist/lifeops/service-mixin-reminders.js.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts +53 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.js +405 -0
- package/dist/lifeops/service-mixin-scheduling.js.map +1 -0
- package/dist/lifeops/service-mixin-screentime.d.ts +71 -0
- package/dist/lifeops/service-mixin-screentime.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-screentime.js +530 -0
- package/dist/lifeops/service-mixin-screentime.js.map +1 -0
- package/dist/lifeops/service-mixin-signal.d.ts +74 -0
- package/dist/lifeops/service-mixin-signal.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-signal.js +214 -0
- package/dist/lifeops/service-mixin-signal.js.map +1 -0
- package/dist/lifeops/service-mixin-sleep.d.ts +68 -0
- package/dist/lifeops/service-mixin-sleep.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-sleep.js +43 -0
- package/dist/lifeops/service-mixin-sleep.js.map +1 -0
- package/dist/lifeops/service-mixin-status.d.ts +31 -0
- package/dist/lifeops/service-mixin-status.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-status.js +373 -0
- package/dist/lifeops/service-mixin-status.js.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts +101 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.js +50 -0
- package/dist/lifeops/service-mixin-subscriptions.js.map +1 -0
- package/dist/lifeops/service-mixin-telegram.d.ts +104 -0
- package/dist/lifeops/service-mixin-telegram.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-telegram.js +280 -0
- package/dist/lifeops/service-mixin-telegram.js.map +1 -0
- package/dist/lifeops/service-mixin-travel.d.ts +66 -0
- package/dist/lifeops/service-mixin-travel.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-travel.js +275 -0
- package/dist/lifeops/service-mixin-travel.js.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts +96 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.js +186 -0
- package/dist/lifeops/service-mixin-whatsapp.js.map +1 -0
- package/dist/lifeops/service-mixin-workflows.d.ts +15 -0
- package/dist/lifeops/service-mixin-workflows.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-workflows.js +710 -0
- package/dist/lifeops/service-mixin-workflows.js.map +1 -0
- package/dist/lifeops/service-mixin-x-read.d.ts +31 -0
- package/dist/lifeops/service-mixin-x-read.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x-read.js +267 -0
- package/dist/lifeops/service-mixin-x-read.js.map +1 -0
- package/dist/lifeops/service-mixin-x.d.ts +66 -0
- package/dist/lifeops/service-mixin-x.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x.js +501 -0
- package/dist/lifeops/service-mixin-x.js.map +1 -0
- package/dist/lifeops/service-normalize-connector.d.ts +19 -0
- package/dist/lifeops/service-normalize-connector.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-connector.js +816 -0
- package/dist/lifeops/service-normalize-connector.js.map +1 -0
- package/dist/lifeops/service-normalize-gmail.d.ts +11 -0
- package/dist/lifeops/service-normalize-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-gmail.js +85 -0
- package/dist/lifeops/service-normalize-gmail.js.map +1 -0
- package/dist/lifeops/service-normalize-task.d.ts +9 -0
- package/dist/lifeops/service-normalize-task.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-task.js +567 -0
- package/dist/lifeops/service-normalize-task.js.map +1 -0
- package/dist/lifeops/service-normalize.d.ts +9 -0
- package/dist/lifeops/service-normalize.d.ts.map +1 -0
- package/dist/lifeops/service-normalize.js +53 -0
- package/dist/lifeops/service-normalize.js.map +1 -0
- package/dist/lifeops/service-types.d.ts +75 -0
- package/dist/lifeops/service-types.d.ts.map +1 -0
- package/dist/lifeops/service-types.js +5 -0
- package/dist/lifeops/service-types.js.map +1 -0
- package/dist/lifeops/service.d.ts +482 -0
- package/dist/lifeops/service.d.ts.map +1 -0
- package/dist/lifeops/service.js +62 -0
- package/dist/lifeops/service.js.map +1 -0
- package/dist/lifeops/signal-runtime-config.d.ts +13 -0
- package/dist/lifeops/signal-runtime-config.d.ts.map +1 -0
- package/dist/lifeops/signal-runtime-config.js +44 -0
- package/dist/lifeops/signal-runtime-config.js.map +1 -0
- package/dist/lifeops/signals/bus.d.ts +78 -0
- package/dist/lifeops/signals/bus.d.ts.map +1 -0
- package/dist/lifeops/signals/bus.js +117 -0
- package/dist/lifeops/signals/bus.js.map +1 -0
- package/dist/lifeops/sql.d.ts +65 -0
- package/dist/lifeops/sql.d.ts.map +1 -0
- package/dist/lifeops/sql.js +182 -0
- package/dist/lifeops/sql.js.map +1 -0
- package/dist/lifeops/stretch-decider.d.ts +73 -0
- package/dist/lifeops/stretch-decider.d.ts.map +1 -0
- package/dist/lifeops/stretch-decider.js +49 -0
- package/dist/lifeops/stretch-decider.js.map +1 -0
- package/dist/lifeops/telemetry-mapping.d.ts +14 -0
- package/dist/lifeops/telemetry-mapping.d.ts.map +1 -0
- package/dist/lifeops/telemetry-mapping.js +115 -0
- package/dist/lifeops/telemetry-mapping.js.map +1 -0
- package/dist/lifeops/telemetry-retention.d.ts +21 -0
- package/dist/lifeops/telemetry-retention.d.ts.map +1 -0
- package/dist/lifeops/telemetry-retention.js +13 -0
- package/dist/lifeops/telemetry-retention.js.map +1 -0
- package/dist/lifeops/time/timezone.d.ts +4 -0
- package/dist/lifeops/time/timezone.d.ts.map +1 -0
- package/dist/lifeops/time/timezone.js +154 -0
- package/dist/lifeops/time/timezone.js.map +1 -0
- package/dist/lifeops/time-util.d.ts +10 -0
- package/dist/lifeops/time-util.d.ts.map +1 -0
- package/dist/lifeops/time-util.js +14 -0
- package/dist/lifeops/time-util.js.map +1 -0
- package/dist/lifeops/time.d.ts +17 -0
- package/dist/lifeops/time.d.ts.map +1 -0
- package/dist/lifeops/time.js +152 -0
- package/dist/lifeops/time.js.map +1 -0
- package/dist/lifeops/travel-booking.types.d.ts +46 -0
- package/dist/lifeops/travel-booking.types.d.ts.map +1 -0
- package/dist/lifeops/travel-booking.types.js +1 -0
- package/dist/lifeops/travel-booking.types.js.map +1 -0
- package/dist/lifeops/triggers/schedule-once.d.ts +19 -0
- package/dist/lifeops/triggers/schedule-once.d.ts.map +1 -0
- package/dist/lifeops/triggers/schedule-once.js +99 -0
- package/dist/lifeops/triggers/schedule-once.js.map +1 -0
- package/dist/lifeops/validate/coding-task-request.d.ts +18 -0
- package/dist/lifeops/validate/coding-task-request.d.ts.map +1 -0
- package/dist/lifeops/validate/coding-task-request.js +16 -0
- package/dist/lifeops/validate/coding-task-request.js.map +1 -0
- package/dist/lifeops/voice/grounded-reply.d.ts +41 -0
- package/dist/lifeops/voice/grounded-reply.d.ts.map +1 -0
- package/dist/lifeops/voice/grounded-reply.js +24 -0
- package/dist/lifeops/voice/grounded-reply.js.map +1 -0
- package/dist/lifeops/voice-affect.d.ts +79 -0
- package/dist/lifeops/voice-affect.d.ts.map +1 -0
- package/dist/lifeops/voice-affect.js +253 -0
- package/dist/lifeops/voice-affect.js.map +1 -0
- package/dist/lifeops/wave1-types.d.ts +125 -0
- package/dist/lifeops/wave1-types.d.ts.map +1 -0
- package/dist/lifeops/wave1-types.js +1 -0
- package/dist/lifeops/wave1-types.js.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts +33 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js +226 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js.map +1 -0
- package/dist/lifeops/work-threads/index.d.ts +3 -0
- package/dist/lifeops/work-threads/index.d.ts.map +1 -0
- package/dist/lifeops/work-threads/index.js +7 -0
- package/dist/lifeops/work-threads/index.js.map +1 -0
- package/dist/lifeops/work-threads/store.d.ts +91 -0
- package/dist/lifeops/work-threads/store.d.ts.map +1 -0
- package/dist/lifeops/work-threads/store.js +245 -0
- package/dist/lifeops/work-threads/store.js.map +1 -0
- package/dist/lifeops/work-threads/types.d.ts +58 -0
- package/dist/lifeops/work-threads/types.d.ts.map +1 -0
- package/dist/lifeops/work-threads/types.js +1 -0
- package/dist/lifeops/work-threads/types.js.map +1 -0
- package/dist/platform/host.d.ts +16 -0
- package/dist/platform/host.d.ts.map +1 -0
- package/dist/platform/host.js +22 -0
- package/dist/platform/host.js.map +1 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.d.ts.map +1 -0
- package/dist/platform/index.js +3 -0
- package/dist/platform/index.js.map +1 -0
- package/dist/platform/lifeops-github.d.ts +15 -0
- package/dist/platform/lifeops-github.d.ts.map +1 -0
- package/dist/platform/lifeops-github.js +146 -0
- package/dist/platform/lifeops-github.js.map +1 -0
- package/dist/plugin.d.ts +106 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +989 -0
- package/dist/plugin.js.map +1 -0
- package/dist/provider.d.ts +4 -0
- package/dist/provider.d.ts.map +1 -0
- package/dist/provider.js +108 -0
- package/dist/provider.js.map +1 -0
- package/dist/providers/activity-profile.d.ts +3 -0
- package/dist/providers/activity-profile.d.ts.map +1 -0
- package/dist/providers/activity-profile.js +140 -0
- package/dist/providers/activity-profile.js.map +1 -0
- package/dist/providers/cross-channel-context.d.ts +29 -0
- package/dist/providers/cross-channel-context.d.ts.map +1 -0
- package/dist/providers/cross-channel-context.js +206 -0
- package/dist/providers/cross-channel-context.js.map +1 -0
- package/dist/providers/first-run.d.ts +22 -0
- package/dist/providers/first-run.d.ts.map +1 -0
- package/dist/providers/first-run.js +93 -0
- package/dist/providers/first-run.js.map +1 -0
- package/dist/providers/health.d.ts +2 -0
- package/dist/providers/health.d.ts.map +1 -0
- package/dist/providers/health.js +14 -0
- package/dist/providers/health.js.map +1 -0
- package/dist/providers/inbox-triage.d.ts +3 -0
- package/dist/providers/inbox-triage.d.ts.map +1 -0
- package/dist/providers/inbox-triage.js +134 -0
- package/dist/providers/inbox-triage.js.map +1 -0
- package/dist/providers/lifeops.d.ts +3 -0
- package/dist/providers/lifeops.d.ts.map +1 -0
- package/dist/providers/lifeops.js +548 -0
- package/dist/providers/lifeops.js.map +1 -0
- package/dist/providers/pending-prompts.d.ts +38 -0
- package/dist/providers/pending-prompts.d.ts.map +1 -0
- package/dist/providers/pending-prompts.js +81 -0
- package/dist/providers/pending-prompts.js.map +1 -0
- package/dist/providers/recent-task-states.d.ts +52 -0
- package/dist/providers/recent-task-states.d.ts.map +1 -0
- package/dist/providers/recent-task-states.js +166 -0
- package/dist/providers/recent-task-states.js.map +1 -0
- package/dist/providers/room-policy.d.ts +16 -0
- package/dist/providers/room-policy.d.ts.map +1 -0
- package/dist/providers/room-policy.js +71 -0
- package/dist/providers/room-policy.js.map +1 -0
- package/dist/providers/work-threads.d.ts +3 -0
- package/dist/providers/work-threads.d.ts.map +1 -0
- package/dist/providers/work-threads.js +97 -0
- package/dist/providers/work-threads.js.map +1 -0
- package/dist/public.d.ts +3 -0
- package/dist/public.d.ts.map +1 -0
- package/dist/public.js +17 -0
- package/dist/public.js.map +1 -0
- package/dist/routes/cloud-features-routes.d.ts +9 -0
- package/dist/routes/cloud-features-routes.d.ts.map +1 -0
- package/dist/routes/cloud-features-routes.js +164 -0
- package/dist/routes/cloud-features-routes.js.map +1 -0
- package/dist/routes/entities.d.ts +14 -0
- package/dist/routes/entities.d.ts.map +1 -0
- package/dist/routes/entities.js +203 -0
- package/dist/routes/entities.js.map +1 -0
- package/dist/routes/lifeops-routes.d.ts +20 -0
- package/dist/routes/lifeops-routes.d.ts.map +1 -0
- package/dist/routes/lifeops-routes.js +2337 -0
- package/dist/routes/lifeops-routes.js.map +1 -0
- package/dist/routes/plugin.d.ts +9 -0
- package/dist/routes/plugin.d.ts.map +1 -0
- package/dist/routes/plugin.js +568 -0
- package/dist/routes/plugin.js.map +1 -0
- package/dist/routes/relationships.d.ts +13 -0
- package/dist/routes/relationships.d.ts.map +1 -0
- package/dist/routes/relationships.js +195 -0
- package/dist/routes/relationships.js.map +1 -0
- package/dist/routes/scheduled-tasks.d.ts +102 -0
- package/dist/routes/scheduled-tasks.d.ts.map +1 -0
- package/dist/routes/scheduled-tasks.js +322 -0
- package/dist/routes/scheduled-tasks.js.map +1 -0
- package/dist/routes/sleep-routes.d.ts +3 -0
- package/dist/routes/sleep-routes.d.ts.map +1 -0
- package/dist/routes/sleep-routes.js +33 -0
- package/dist/routes/sleep-routes.js.map +1 -0
- package/dist/routes/travel-provider-relay-routes.d.ts +2 -0
- package/dist/routes/travel-provider-relay-routes.d.ts.map +1 -0
- package/dist/routes/travel-provider-relay-routes.js +7 -0
- package/dist/routes/travel-provider-relay-routes.js.map +1 -0
- package/dist/routes/website-blocker-routes.d.ts +6 -0
- package/dist/routes/website-blocker-routes.d.ts.map +1 -0
- package/dist/routes/website-blocker-routes.js +218 -0
- package/dist/routes/website-blocker-routes.js.map +1 -0
- package/dist/security/action-confirmation.d.ts +12 -0
- package/dist/security/action-confirmation.d.ts.map +1 -0
- package/dist/security/action-confirmation.js +36 -0
- package/dist/security/action-confirmation.js.map +1 -0
- package/dist/service.d.ts +34 -0
- package/dist/service.d.ts.map +1 -0
- package/dist/service.js +111 -0
- package/dist/service.js.map +1 -0
- package/dist/travel-time/calendar-create.d.ts +17 -0
- package/dist/travel-time/calendar-create.d.ts.map +1 -0
- package/dist/travel-time/calendar-create.js +28 -0
- package/dist/travel-time/calendar-create.js.map +1 -0
- package/dist/travel-time/service.d.ts +114 -0
- package/dist/travel-time/service.d.ts.map +1 -0
- package/dist/travel-time/service.js +209 -0
- package/dist/travel-time/service.js.map +1 -0
- package/dist/types/app-blocker-settings-card.d.ts +2 -0
- package/dist/types/app-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/app-blocker-settings-card.js +1 -0
- package/dist/types/app-blocker-settings-card.js.map +1 -0
- package/dist/types/briefing.d.ts +59 -0
- package/dist/types/briefing.d.ts.map +1 -0
- package/dist/types/briefing.js +1 -0
- package/dist/types/briefing.js.map +1 -0
- package/dist/types/document-request.d.ts +41 -0
- package/dist/types/document-request.d.ts.map +1 -0
- package/dist/types/document-request.js +1 -0
- package/dist/types/document-request.js.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/website-blocker-settings-card.d.ts +2 -0
- package/dist/types/website-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/website-blocker-settings-card.js +1 -0
- package/dist/types/website-blocker-settings-card.js.map +1 -0
- package/dist/ui.d.ts +13 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +25 -0
- package/dist/ui.js.map +1 -0
- package/dist/utils/format-duration.d.ts +2 -0
- package/dist/utils/format-duration.d.ts.map +1 -0
- package/dist/utils/format-duration.js +13 -0
- package/dist/utils/format-duration.js.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +3 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/lifeops-url.d.ts +3 -0
- package/dist/utils/lifeops-url.d.ts.map +1 -0
- package/dist/utils/lifeops-url.js +28 -0
- package/dist/utils/lifeops-url.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts +32 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.js +30 -0
- package/dist/website-blocker/chat-integration/block-activator.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts +7 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js +115 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts +39 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js +133 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts +21 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js +230 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts +13 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js +22 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js.map +1 -0
- package/dist/website-blocker/chat-integration/index.d.ts +5 -0
- package/dist/website-blocker/chat-integration/index.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/index.js +26 -0
- package/dist/website-blocker/chat-integration/index.js.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts +75 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.js +154 -0
- package/dist/website-blocker/proactive-block-bridge.js.map +1 -0
- package/dist/website-blocker/public.d.ts +12 -0
- package/dist/website-blocker/public.d.ts.map +1 -0
- package/dist/website-blocker/public.js +51 -0
- package/dist/website-blocker/public.js.map +1 -0
- package/package.json +28 -28
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/lifeops/connectors/twilio.ts"],"sourcesContent":["/**\n * Twilio connector contribution.\n *\n * Twilio doesn't have a `service-mixin-twilio.ts`; transport is owned by\n * `@elizaos/plugin-phone`. Credentials are read from `process.env` per the\n * legacy `readTwilioCredentialsFromEnv()` shape.\n *\n * Send target syntax:\n * - SMS: `\"sms:+15551234567\"` or just `\"+15551234567\"` (default).\n * - Voice: `\"voice:+15551234567\"` (TwiML <Say> wrapping `payload.message`).\n */\nimport type { IAgentRuntime } from \"@elizaos/core\";\nimport {\n readTwilioCredentialsFromEnv,\n sendTwilioSms,\n sendTwilioVoiceCall,\n type TwilioCredentials,\n type TwilioDeliveryResult,\n} from \"@elizaos/plugin-phone/twilio\";\nimport {\n errorToDispatchResult,\n isConnectorSendPayload,\n rejectInvalidPayload,\n} from \"./_helpers.js\";\nimport type {\n ConnectorContribution,\n ConnectorStatus,\n DispatchResult,\n} from \"./contract.js\";\n\nfunction parseTarget(target: string): {\n channel: \"sms\" | \"voice\";\n to: string;\n} {\n const trimmed = target.trim();\n if (trimmed.startsWith(\"voice:\")) {\n return { channel: \"voice\", to: trimmed.slice(\"voice:\".length).trim() };\n }\n if (trimmed.startsWith(\"sms:\")) {\n return { channel: \"sms\", to: trimmed.slice(\"sms:\".length).trim() };\n }\n return { channel: \"sms\", to: trimmed };\n}\n\nfunction deliveryResultToDispatch(\n result: TwilioDeliveryResult,\n): DispatchResult {\n if (result.ok) {\n return { ok: true, messageId: result.sid };\n }\n if (result.status === 401 || result.status === 403) {\n return {\n ok: false,\n reason: \"auth_expired\",\n userActionable: true,\n message: result.error ?? \"Twilio rejected the request (auth).\",\n };\n }\n if (result.status === 429) {\n return {\n ok: false,\n reason: \"rate_limited\",\n retryAfterMinutes: 5,\n userActionable: false,\n message: result.error ?? \"Twilio rate limited.\",\n };\n }\n if (result.status === 404 || result.status === 400) {\n return {\n ok: false,\n reason: \"unknown_recipient\",\n userActionable: true,\n message: result.error ?? \"Twilio rejected the recipient.\",\n };\n }\n return {\n ok: false,\n reason: \"transport_error\",\n userActionable: false,\n message: result.error ?? \"Twilio delivery failed.\",\n };\n}\n\nexport function createTwilioConnectorContribution(\n _runtime: IAgentRuntime,\n): ConnectorContribution {\n return {\n kind: \"twilio\",\n capabilities: [\"twilio.sms.send\", \"twilio.voice.send\"],\n modes: [\"cloud\"],\n describe: { label: \"Twilio (SMS + Voice)\" },\n async start() {},\n async disconnect() {\n // Twilio is configured via env vars; LifeOps doesn't manage credential\n // lifecycle. Operator clears env to disconnect.\n },\n async verify(): Promise<boolean> {\n return readTwilioCredentialsFromEnv() != null;\n },\n async status(): Promise<ConnectorStatus> {\n const credentials: TwilioCredentials | null =\n readTwilioCredentialsFromEnv();\n const observedAt = new Date().toISOString();\n if (!credentials) {\n return {\n state: \"disconnected\",\n message:\n \"Twilio is not configured. Set TWILIO_ACCOUNT_SID, TWILIO_AUTH_TOKEN, and TWILIO_PHONE_NUMBER.\",\n observedAt,\n };\n }\n return { state: \"ok\", observedAt };\n },\n async send(payload: unknown): Promise<DispatchResult> {\n if (!isConnectorSendPayload(payload)) return rejectInvalidPayload();\n const credentials = readTwilioCredentialsFromEnv();\n if (!credentials) {\n return {\n ok: false,\n reason: \"disconnected\",\n userActionable: true,\n message:\n \"Twilio is not configured. Set TWILIO_ACCOUNT_SID, TWILIO_AUTH_TOKEN, and TWILIO_PHONE_NUMBER.\",\n };\n }\n try {\n const { channel, to } = parseTarget(payload.target);\n if (!to) {\n return {\n ok: false,\n reason: \"unknown_recipient\",\n userActionable: true,\n message: \"Twilio target is empty.\",\n };\n }\n if (channel === \"voice\") {\n const result = await sendTwilioVoiceCall({\n credentials,\n to,\n message: payload.message,\n });\n return deliveryResultToDispatch(result);\n }\n const result = await sendTwilioSms({\n credentials,\n to,\n body: payload.message,\n });\n return deliveryResultToDispatch(result);\n } catch (error) {\n return errorToDispatchResult(error);\n }\n },\n };\n}\n"],"mappings":"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","names":["result"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WhatsApp connector contribution.
|
|
3
|
+
*
|
|
4
|
+
* Wraps the LifeOps WhatsApp mixin (`service-mixin-whatsapp.ts`). The actual
|
|
5
|
+
* transport is owned by `@elizaos/plugin-whatsapp`.
|
|
6
|
+
*/
|
|
7
|
+
import type { IAgentRuntime } from "@elizaos/core";
|
|
8
|
+
import type { ConnectorContribution } from "./contract.js";
|
|
9
|
+
export declare function createWhatsAppConnectorContribution(runtime: IAgentRuntime): ConnectorContribution;
|
|
10
|
+
//# sourceMappingURL=whatsapp.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"whatsapp.d.ts","sourceRoot":"","sources":["../../../src/lifeops/connectors/whatsapp.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAQnD,OAAO,KAAK,EACV,qBAAqB,EAGtB,MAAM,eAAe,CAAC;AAEvB,wBAAgB,mCAAmC,CACjD,OAAO,EAAE,aAAa,GACrB,qBAAqB,CA6CvB"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { LifeOpsService } from "../service.js";
|
|
2
|
+
import {
|
|
3
|
+
errorToDispatchResult,
|
|
4
|
+
isConnectorSendPayload,
|
|
5
|
+
legacyStatusToConnectorStatus,
|
|
6
|
+
rejectInvalidPayload
|
|
7
|
+
} from "./_helpers.js";
|
|
8
|
+
function createWhatsAppConnectorContribution(runtime) {
|
|
9
|
+
const service = new LifeOpsService(runtime);
|
|
10
|
+
return {
|
|
11
|
+
kind: "whatsapp",
|
|
12
|
+
capabilities: ["whatsapp.read", "whatsapp.send"],
|
|
13
|
+
modes: ["local"],
|
|
14
|
+
describe: { label: "WhatsApp" },
|
|
15
|
+
async start() {
|
|
16
|
+
},
|
|
17
|
+
async disconnect() {
|
|
18
|
+
},
|
|
19
|
+
async verify() {
|
|
20
|
+
const status = await service.getWhatsAppConnectorStatus();
|
|
21
|
+
return Boolean(status.connected);
|
|
22
|
+
},
|
|
23
|
+
async status() {
|
|
24
|
+
try {
|
|
25
|
+
const status = await service.getWhatsAppConnectorStatus();
|
|
26
|
+
return legacyStatusToConnectorStatus(status);
|
|
27
|
+
} catch (error) {
|
|
28
|
+
return {
|
|
29
|
+
state: "disconnected",
|
|
30
|
+
message: error instanceof Error ? error.message : String(error),
|
|
31
|
+
observedAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
async send(payload) {
|
|
36
|
+
if (!isConnectorSendPayload(payload)) return rejectInvalidPayload();
|
|
37
|
+
try {
|
|
38
|
+
const result = await service.sendWhatsAppMessage({
|
|
39
|
+
to: payload.target,
|
|
40
|
+
text: payload.message
|
|
41
|
+
});
|
|
42
|
+
return { ok: true, messageId: result.messageId };
|
|
43
|
+
} catch (error) {
|
|
44
|
+
return errorToDispatchResult(error);
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
async read(query) {
|
|
48
|
+
const params = query ?? {};
|
|
49
|
+
return service.pullWhatsAppRecent(params.limit ?? 25);
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
export {
|
|
54
|
+
createWhatsAppConnectorContribution
|
|
55
|
+
};
|
|
56
|
+
//# sourceMappingURL=whatsapp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/lifeops/connectors/whatsapp.ts"],"sourcesContent":["/**\n * WhatsApp connector contribution.\n *\n * Wraps the LifeOps WhatsApp mixin (`service-mixin-whatsapp.ts`). The actual\n * transport is owned by `@elizaos/plugin-whatsapp`.\n */\nimport type { IAgentRuntime } from \"@elizaos/core\";\nimport { LifeOpsService } from \"../service.js\";\nimport {\n errorToDispatchResult,\n isConnectorSendPayload,\n legacyStatusToConnectorStatus,\n rejectInvalidPayload,\n} from \"./_helpers.js\";\nimport type {\n ConnectorContribution,\n ConnectorStatus,\n DispatchResult,\n} from \"./contract.js\";\n\nexport function createWhatsAppConnectorContribution(\n runtime: IAgentRuntime,\n): ConnectorContribution {\n const service = new LifeOpsService(runtime);\n return {\n kind: \"whatsapp\",\n capabilities: [\"whatsapp.read\", \"whatsapp.send\"],\n modes: [\"local\"],\n describe: { label: \"WhatsApp\" },\n async start() {},\n async disconnect() {\n // WhatsApp account auth is owned by @elizaos/plugin-whatsapp; LifeOps\n // doesn't manage the credential lifecycle directly.\n },\n async verify(): Promise<boolean> {\n const status = await service.getWhatsAppConnectorStatus();\n return Boolean(status.connected);\n },\n async status(): Promise<ConnectorStatus> {\n try {\n const status = await service.getWhatsAppConnectorStatus();\n return legacyStatusToConnectorStatus(status);\n } catch (error) {\n return {\n state: \"disconnected\",\n message: error instanceof Error ? error.message : String(error),\n observedAt: new Date().toISOString(),\n };\n }\n },\n async send(payload: unknown): Promise<DispatchResult> {\n if (!isConnectorSendPayload(payload)) return rejectInvalidPayload();\n try {\n const result = await service.sendWhatsAppMessage({\n to: payload.target,\n text: payload.message,\n });\n return { ok: true, messageId: result.messageId };\n } catch (error) {\n return errorToDispatchResult(error);\n }\n },\n async read(query: unknown) {\n const params = (query ?? {}) as { limit?: number };\n return service.pullWhatsAppRecent(params.limit ?? 25);\n },\n };\n}\n"],"mappings":"AAOA,SAAS,sBAAsB;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAOA,SAAS,oCACd,SACuB;AACvB,QAAM,UAAU,IAAI,eAAe,OAAO;AAC1C,SAAO;AAAA,IACL,MAAM;AAAA,IACN,cAAc,CAAC,iBAAiB,eAAe;AAAA,IAC/C,OAAO,CAAC,OAAO;AAAA,IACf,UAAU,EAAE,OAAO,WAAW;AAAA,IAC9B,MAAM,QAAQ;AAAA,IAAC;AAAA,IACf,MAAM,aAAa;AAAA,IAGnB;AAAA,IACA,MAAM,SAA2B;AAC/B,YAAM,SAAS,MAAM,QAAQ,2BAA2B;AACxD,aAAO,QAAQ,OAAO,SAAS;AAAA,IACjC;AAAA,IACA,MAAM,SAAmC;AACvC,UAAI;AACF,cAAM,SAAS,MAAM,QAAQ,2BAA2B;AACxD,eAAO,8BAA8B,MAAM;AAAA,MAC7C,SAAS,OAAO;AACd,eAAO;AAAA,UACL,OAAO;AAAA,UACP,SAAS,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AAAA,UAC9D,aAAY,oBAAI,KAAK,GAAE,YAAY;AAAA,QACrC;AAAA,MACF;AAAA,IACF;AAAA,IACA,MAAM,KAAK,SAA2C;AACpD,UAAI,CAAC,uBAAuB,OAAO,EAAG,QAAO,qBAAqB;AAClE,UAAI;AACF,cAAM,SAAS,MAAM,QAAQ,oBAAoB;AAAA,UAC/C,IAAI,QAAQ;AAAA,UACZ,MAAM,QAAQ;AAAA,QAChB,CAAC;AACD,eAAO,EAAE,IAAI,MAAM,WAAW,OAAO,UAAU;AAAA,MACjD,SAAS,OAAO;AACd,eAAO,sBAAsB,KAAK;AAAA,MACpC;AAAA,IACF;AAAA,IACA,MAAM,KAAK,OAAgB;AACzB,YAAM,SAAU,SAAS,CAAC;AAC1B,aAAO,QAAQ,mBAAmB,OAAO,SAAS,EAAE;AAAA,IACtD;AAAA,EACF;AACF;","names":[]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* X (Twitter) connector contribution. Wraps the LifeOps X mixin
|
|
3
|
+
* (`service-mixin-x.ts`).
|
|
4
|
+
*/
|
|
5
|
+
import type { IAgentRuntime } from "@elizaos/core";
|
|
6
|
+
import type { ConnectorContribution } from "./contract.js";
|
|
7
|
+
export declare function createXConnectorContribution(runtime: IAgentRuntime): ConnectorContribution;
|
|
8
|
+
//# sourceMappingURL=x.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"x.d.ts","sourceRoot":"","sources":["../../../src/lifeops/connectors/x.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAQnD,OAAO,KAAK,EACV,qBAAqB,EAGtB,MAAM,eAAe,CAAC;AAEvB,wBAAgB,4BAA4B,CAC1C,OAAO,EAAE,aAAa,GACrB,qBAAqB,CAgDvB"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { LifeOpsService } from "../service.js";
|
|
2
|
+
import {
|
|
3
|
+
errorToDispatchResult,
|
|
4
|
+
isConnectorSendPayload,
|
|
5
|
+
legacyStatusToConnectorStatus,
|
|
6
|
+
rejectInvalidPayload
|
|
7
|
+
} from "./_helpers.js";
|
|
8
|
+
function createXConnectorContribution(runtime) {
|
|
9
|
+
const service = new LifeOpsService(runtime);
|
|
10
|
+
return {
|
|
11
|
+
kind: "x",
|
|
12
|
+
capabilities: ["x.read", "x.write", "x.dm.read", "x.dm.write"],
|
|
13
|
+
modes: ["local", "cloud"],
|
|
14
|
+
describe: { label: "X (Twitter)" },
|
|
15
|
+
async start() {
|
|
16
|
+
},
|
|
17
|
+
async disconnect() {
|
|
18
|
+
},
|
|
19
|
+
async verify() {
|
|
20
|
+
const status = await service.getXConnectorStatus(void 0, "owner");
|
|
21
|
+
return Boolean(status.connected);
|
|
22
|
+
},
|
|
23
|
+
async status() {
|
|
24
|
+
try {
|
|
25
|
+
const status = await service.getXConnectorStatus(void 0, "owner");
|
|
26
|
+
return legacyStatusToConnectorStatus(status);
|
|
27
|
+
} catch (error) {
|
|
28
|
+
return {
|
|
29
|
+
state: "disconnected",
|
|
30
|
+
message: error instanceof Error ? error.message : String(error),
|
|
31
|
+
observedAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
async send(payload) {
|
|
36
|
+
if (!isConnectorSendPayload(payload)) return rejectInvalidPayload();
|
|
37
|
+
try {
|
|
38
|
+
const result = await service.sendXDirectMessage({
|
|
39
|
+
participantId: payload.target,
|
|
40
|
+
text: payload.message,
|
|
41
|
+
confirmSend: true,
|
|
42
|
+
side: "owner"
|
|
43
|
+
});
|
|
44
|
+
if (result.ok) {
|
|
45
|
+
return { ok: true };
|
|
46
|
+
}
|
|
47
|
+
return {
|
|
48
|
+
ok: false,
|
|
49
|
+
reason: "transport_error",
|
|
50
|
+
userActionable: false,
|
|
51
|
+
message: result.error ?? "X DM send returned a non-ok response."
|
|
52
|
+
};
|
|
53
|
+
} catch (error) {
|
|
54
|
+
return errorToDispatchResult(error);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
export {
|
|
60
|
+
createXConnectorContribution
|
|
61
|
+
};
|
|
62
|
+
//# sourceMappingURL=x.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/lifeops/connectors/x.ts"],"sourcesContent":["/**\n * X (Twitter) connector contribution. Wraps the LifeOps X mixin\n * (`service-mixin-x.ts`).\n */\nimport type { IAgentRuntime } from \"@elizaos/core\";\nimport { LifeOpsService } from \"../service.js\";\nimport {\n errorToDispatchResult,\n isConnectorSendPayload,\n legacyStatusToConnectorStatus,\n rejectInvalidPayload,\n} from \"./_helpers.js\";\nimport type {\n ConnectorContribution,\n ConnectorStatus,\n DispatchResult,\n} from \"./contract.js\";\n\nexport function createXConnectorContribution(\n runtime: IAgentRuntime,\n): ConnectorContribution {\n const service = new LifeOpsService(runtime);\n return {\n kind: \"x\",\n capabilities: [\"x.read\", \"x.write\", \"x.dm.read\", \"x.dm.write\"],\n modes: [\"local\", \"cloud\"],\n describe: { label: \"X (Twitter)\" },\n async start() {},\n async disconnect() {},\n async verify(): Promise<boolean> {\n const status = await service.getXConnectorStatus(undefined, \"owner\");\n return Boolean(status.connected);\n },\n async status(): Promise<ConnectorStatus> {\n try {\n const status = await service.getXConnectorStatus(undefined, \"owner\");\n return legacyStatusToConnectorStatus(status);\n } catch (error) {\n return {\n state: \"disconnected\",\n message: error instanceof Error ? error.message : String(error),\n observedAt: new Date().toISOString(),\n };\n }\n },\n async send(payload: unknown): Promise<DispatchResult> {\n if (!isConnectorSendPayload(payload)) return rejectInvalidPayload();\n try {\n const result = await service.sendXDirectMessage({\n participantId: payload.target,\n text: payload.message,\n confirmSend: true,\n side: \"owner\",\n });\n if (result.ok) {\n return { ok: true };\n }\n return {\n ok: false,\n reason: \"transport_error\",\n userActionable: false,\n message: result.error ?? \"X DM send returned a non-ok response.\",\n };\n } catch (error) {\n return errorToDispatchResult(error);\n }\n },\n };\n}\n"],"mappings":"AAKA,SAAS,sBAAsB;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAOA,SAAS,6BACd,SACuB;AACvB,QAAM,UAAU,IAAI,eAAe,OAAO;AAC1C,SAAO;AAAA,IACL,MAAM;AAAA,IACN,cAAc,CAAC,UAAU,WAAW,aAAa,YAAY;AAAA,IAC7D,OAAO,CAAC,SAAS,OAAO;AAAA,IACxB,UAAU,EAAE,OAAO,cAAc;AAAA,IACjC,MAAM,QAAQ;AAAA,IAAC;AAAA,IACf,MAAM,aAAa;AAAA,IAAC;AAAA,IACpB,MAAM,SAA2B;AAC/B,YAAM,SAAS,MAAM,QAAQ,oBAAoB,QAAW,OAAO;AACnE,aAAO,QAAQ,OAAO,SAAS;AAAA,IACjC;AAAA,IACA,MAAM,SAAmC;AACvC,UAAI;AACF,cAAM,SAAS,MAAM,QAAQ,oBAAoB,QAAW,OAAO;AACnE,eAAO,8BAA8B,MAAM;AAAA,MAC7C,SAAS,OAAO;AACd,eAAO;AAAA,UACL,OAAO;AAAA,UACP,SAAS,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AAAA,UAC9D,aAAY,oBAAI,KAAK,GAAE,YAAY;AAAA,QACrC;AAAA,MACF;AAAA,IACF;AAAA,IACA,MAAM,KAAK,SAA2C;AACpD,UAAI,CAAC,uBAAuB,OAAO,EAAG,QAAO,qBAAqB;AAClE,UAAI;AACF,cAAM,SAAS,MAAM,QAAQ,mBAAmB;AAAA,UAC9C,eAAe,QAAQ;AAAA,UACvB,MAAM,QAAQ;AAAA,UACd,aAAa;AAAA,UACb,MAAM;AAAA,QACR,CAAC;AACD,YAAI,OAAO,IAAI;AACb,iBAAO,EAAE,IAAI,KAAK;AAAA,QACpB;AACA,eAAO;AAAA,UACL,IAAI;AAAA,UACJ,QAAQ;AAAA,UACR,gBAAgB;AAAA,UAChB,SAAS,OAAO,SAAS;AAAA,QAC3B;AAAA,MACF,SAAS,OAAO;AACd,eAAO,sBAAsB,KAAK;AAAA,MACpC;AAAA,IACF;AAAA,EACF;AACF;","names":[]}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { LifeOpsChannelPolicy, LifeOpsReminderAttempt, LifeOpsReminderChannel, LifeOpsReminderUrgency } from "../contracts/index.js";
|
|
2
|
+
import { type ReminderEscalationRoutingHint, type ReminderRouteCandidate } from "./service-helpers-reminder.js";
|
|
3
|
+
import type { ReminderActivityProfileSnapshot } from "./service-types.js";
|
|
4
|
+
export declare const DEFAULT_CONTACT_ROUTE_FAILURE_COOLDOWN_MS: number;
|
|
5
|
+
export type ContactRoutePurpose = "reminder_escalation" | "checkin" | "workflow" | "proactive" | "inbox";
|
|
6
|
+
export type ContactRoutePolicyCallbacks = {
|
|
7
|
+
resolvePrimaryChannelPolicy: (channel: LifeOpsReminderChannel) => Promise<LifeOpsChannelPolicy | null>;
|
|
8
|
+
hasRuntimeTarget: (channel: LifeOpsReminderChannel, policy: LifeOpsChannelPolicy | null) => Promise<boolean>;
|
|
9
|
+
runtimeTargetSendAvailable: boolean;
|
|
10
|
+
};
|
|
11
|
+
export type ContactRoutePolicyOptions = {
|
|
12
|
+
failureCooldownMs?: number;
|
|
13
|
+
directPolicyRequiredChannels?: readonly LifeOpsReminderChannel[];
|
|
14
|
+
};
|
|
15
|
+
export declare function resolveContactRouteCandidates(args: {
|
|
16
|
+
purpose?: ContactRoutePurpose;
|
|
17
|
+
activityProfile: ReminderActivityProfileSnapshot | null;
|
|
18
|
+
ownerContactHints: Record<string, ReminderEscalationRoutingHint>;
|
|
19
|
+
ownerContactSources: readonly string[];
|
|
20
|
+
policies: readonly LifeOpsChannelPolicy[];
|
|
21
|
+
urgency: LifeOpsReminderUrgency;
|
|
22
|
+
attempts?: readonly LifeOpsReminderAttempt[];
|
|
23
|
+
now?: Date | number;
|
|
24
|
+
callbacks: ContactRoutePolicyCallbacks;
|
|
25
|
+
options?: ContactRoutePolicyOptions;
|
|
26
|
+
}): Promise<ReminderRouteCandidate[]>;
|
|
27
|
+
//# sourceMappingURL=contact-route-policy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contact-route-policy.d.ts","sourceRoot":"","sources":["../../src/lifeops/contact-route-policy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,oBAAoB,EACpB,sBAAsB,EACtB,sBAAsB,EACtB,sBAAsB,EACvB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAEL,KAAK,6BAA6B,EAClC,KAAK,sBAAsB,EAG5B,MAAM,+BAA+B,CAAC;AACvC,OAAO,KAAK,EAAE,+BAA+B,EAAE,MAAM,oBAAoB,CAAC;AAE1E,eAAO,MAAM,yCAAyC,QAAkB,CAAC;AAEzE,MAAM,MAAM,mBAAmB,GAC3B,qBAAqB,GACrB,SAAS,GACT,UAAU,GACV,WAAW,GACX,OAAO,CAAC;AAEZ,MAAM,MAAM,2BAA2B,GAAG;IACxC,2BAA2B,EAAE,CAC3B,OAAO,EAAE,sBAAsB,KAC5B,OAAO,CAAC,oBAAoB,GAAG,IAAI,CAAC,CAAC;IAC1C,gBAAgB,EAAE,CAChB,OAAO,EAAE,sBAAsB,EAC/B,MAAM,EAAE,oBAAoB,GAAG,IAAI,KAChC,OAAO,CAAC,OAAO,CAAC,CAAC;IACtB,0BAA0B,EAAE,OAAO,CAAC;CACrC,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG;IACtC,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,4BAA4B,CAAC,EAAE,SAAS,sBAAsB,EAAE,CAAC;CAClE,CAAC;AAwJF,wBAAsB,6BAA6B,CAAC,IAAI,EAAE;IACxD,OAAO,CAAC,EAAE,mBAAmB,CAAC;IAC9B,eAAe,EAAE,+BAA+B,GAAG,IAAI,CAAC;IACxD,iBAAiB,EAAE,MAAM,CAAC,MAAM,EAAE,6BAA6B,CAAC,CAAC;IACjE,mBAAmB,EAAE,SAAS,MAAM,EAAE,CAAC;IACvC,QAAQ,EAAE,SAAS,oBAAoB,EAAE,CAAC;IAC1C,OAAO,EAAE,sBAAsB,CAAC;IAChC,QAAQ,CAAC,EAAE,SAAS,sBAAsB,EAAE,CAAC;IAC7C,GAAG,CAAC,EAAE,IAAI,GAAG,MAAM,CAAC;IACpB,SAAS,EAAE,2BAA2B,CAAC;IACvC,OAAO,CAAC,EAAE,yBAAyB,CAAC;CACrC,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC,CAuCpC"}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { isReminderChannelAllowedForUrgency } from "./service-helpers-misc.js";
|
|
2
|
+
import {
|
|
3
|
+
isReminderChannel,
|
|
4
|
+
rankReminderEscalationChannelCandidates,
|
|
5
|
+
resolveReminderEscalationRoutingPolicy
|
|
6
|
+
} from "./service-helpers-reminder.js";
|
|
7
|
+
const DEFAULT_CONTACT_ROUTE_FAILURE_COOLDOWN_MS = 6 * 60 * 6e4;
|
|
8
|
+
function normalizeNowMs(value) {
|
|
9
|
+
if (value instanceof Date) {
|
|
10
|
+
return value.getTime();
|
|
11
|
+
}
|
|
12
|
+
return typeof value === "number" && Number.isFinite(value) ? value : Date.now();
|
|
13
|
+
}
|
|
14
|
+
function hasRecentChannelFailure(args) {
|
|
15
|
+
return args.attempts.some((attempt) => {
|
|
16
|
+
if (attempt.channel !== args.channel) {
|
|
17
|
+
return false;
|
|
18
|
+
}
|
|
19
|
+
if (attempt.outcome !== "blocked_connector" && attempt.outcome !== "blocked_policy") {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
const attemptedMs = attempt.attemptedAt ? Date.parse(attempt.attemptedAt) : Number.NaN;
|
|
23
|
+
return Number.isFinite(attemptedMs) && args.nowMs - attemptedMs <= args.failureCooldownMs;
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
function buildPolicyWeightAdjustments(policies) {
|
|
27
|
+
const policyWeightAdjustments = {};
|
|
28
|
+
for (const policy of policies) {
|
|
29
|
+
const channel = isReminderChannel(policy.channelType) ? policy.channelType : null;
|
|
30
|
+
if (!channel) {
|
|
31
|
+
continue;
|
|
32
|
+
}
|
|
33
|
+
const weight = policy.metadata.routingWeight;
|
|
34
|
+
if (typeof weight === "number" && Number.isFinite(weight)) {
|
|
35
|
+
policyWeightAdjustments[channel] = (policyWeightAdjustments[channel] ?? 0) + weight;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return policyWeightAdjustments;
|
|
39
|
+
}
|
|
40
|
+
async function evaluateRouteCandidate(args) {
|
|
41
|
+
if (args.candidates.some(
|
|
42
|
+
(resolvedCandidate) => resolvedCandidate.channel === args.candidate.channel
|
|
43
|
+
)) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const vetoReasons = [];
|
|
47
|
+
const channel = args.candidate.channel;
|
|
48
|
+
if (!isReminderChannelAllowedForUrgency(channel, args.urgency)) {
|
|
49
|
+
vetoReasons.push("urgency_policy");
|
|
50
|
+
}
|
|
51
|
+
if (args.urgency !== "critical" && hasRecentChannelFailure({
|
|
52
|
+
attempts: args.attempts,
|
|
53
|
+
channel,
|
|
54
|
+
nowMs: args.nowMs,
|
|
55
|
+
failureCooldownMs: args.failureCooldownMs
|
|
56
|
+
})) {
|
|
57
|
+
vetoReasons.push("recent_channel_failure");
|
|
58
|
+
}
|
|
59
|
+
if (channel !== "in_app" && args.interruptionBudget === "low") {
|
|
60
|
+
vetoReasons.push("attention_budget_low");
|
|
61
|
+
}
|
|
62
|
+
if (vetoReasons.length > 0) {
|
|
63
|
+
args.candidates.push({ ...args.candidate, vetoReasons });
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
if (channel === "in_app") {
|
|
67
|
+
args.candidates.push({ ...args.candidate, vetoReasons });
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
const policy = await args.callbacks.resolvePrimaryChannelPolicy(channel);
|
|
71
|
+
if (policy) {
|
|
72
|
+
if (policy.metadata.disableReminderRouting === true) {
|
|
73
|
+
args.candidates.push({
|
|
74
|
+
...args.candidate,
|
|
75
|
+
vetoReasons: ["channel_policy_disabled"]
|
|
76
|
+
});
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
if (!policy.allowReminders || !policy.allowEscalation) {
|
|
80
|
+
args.candidates.push({
|
|
81
|
+
...args.candidate,
|
|
82
|
+
vetoReasons: ["channel_policy_blocks_escalation"]
|
|
83
|
+
});
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
} else if (args.directPolicyRequiredChannels.includes(channel)) {
|
|
87
|
+
args.candidates.push({
|
|
88
|
+
...args.candidate,
|
|
89
|
+
vetoReasons: ["missing_required_direct_policy"]
|
|
90
|
+
});
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
if (args.directPolicyRequiredChannels.includes(channel)) {
|
|
94
|
+
args.candidates.push({ ...args.candidate, vetoReasons });
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
if (!args.callbacks.runtimeTargetSendAvailable) {
|
|
98
|
+
args.candidates.push({
|
|
99
|
+
...args.candidate,
|
|
100
|
+
vetoReasons: ["runtime_target_send_unavailable"]
|
|
101
|
+
});
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
if (await args.callbacks.hasRuntimeTarget(channel, policy)) {
|
|
105
|
+
args.candidates.push({ ...args.candidate, vetoReasons });
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
args.candidates.push({
|
|
109
|
+
...args.candidate,
|
|
110
|
+
vetoReasons: ["runtime_target_missing"]
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
async function resolveContactRouteCandidates(args) {
|
|
114
|
+
const candidates = [];
|
|
115
|
+
const nowMs = normalizeNowMs(args.now);
|
|
116
|
+
const purpose = args.purpose ?? "proactive";
|
|
117
|
+
const routingPolicy = resolveReminderEscalationRoutingPolicy({
|
|
118
|
+
activityProfile: args.activityProfile,
|
|
119
|
+
urgency: args.urgency
|
|
120
|
+
});
|
|
121
|
+
const rankedCandidates = rankReminderEscalationChannelCandidates({
|
|
122
|
+
activityProfile: args.activityProfile,
|
|
123
|
+
ownerContactHints: args.ownerContactHints,
|
|
124
|
+
ownerContactSources: args.ownerContactSources,
|
|
125
|
+
policyChannels: args.policies.map((policy) => policy.channelType),
|
|
126
|
+
policyChannelWeightAdjustments: buildPolicyWeightAdjustments(args.policies),
|
|
127
|
+
urgency: args.urgency,
|
|
128
|
+
routingPolicy,
|
|
129
|
+
now: nowMs
|
|
130
|
+
});
|
|
131
|
+
for (const candidate of rankedCandidates) {
|
|
132
|
+
await evaluateRouteCandidate({
|
|
133
|
+
candidate: {
|
|
134
|
+
...candidate,
|
|
135
|
+
evidence: [`purpose:${purpose}`, ...candidate.evidence]
|
|
136
|
+
},
|
|
137
|
+
candidates,
|
|
138
|
+
attempts: args.attempts ?? [],
|
|
139
|
+
urgency: args.urgency,
|
|
140
|
+
nowMs,
|
|
141
|
+
failureCooldownMs: args.options?.failureCooldownMs ?? DEFAULT_CONTACT_ROUTE_FAILURE_COOLDOWN_MS,
|
|
142
|
+
directPolicyRequiredChannels: args.options?.directPolicyRequiredChannels ?? ["sms", "voice"],
|
|
143
|
+
interruptionBudget: routingPolicy.interruptionBudget,
|
|
144
|
+
callbacks: args.callbacks
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
return candidates;
|
|
148
|
+
}
|
|
149
|
+
export {
|
|
150
|
+
DEFAULT_CONTACT_ROUTE_FAILURE_COOLDOWN_MS,
|
|
151
|
+
resolveContactRouteCandidates
|
|
152
|
+
};
|
|
153
|
+
//# sourceMappingURL=contact-route-policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/contact-route-policy.ts"],"sourcesContent":["import type {\n LifeOpsChannelPolicy,\n LifeOpsReminderAttempt,\n LifeOpsReminderChannel,\n LifeOpsReminderUrgency,\n} from \"../contracts/index.js\";\nimport { isReminderChannelAllowedForUrgency } from \"./service-helpers-misc.js\";\nimport {\n isReminderChannel,\n type ReminderEscalationRoutingHint,\n type ReminderRouteCandidate,\n rankReminderEscalationChannelCandidates,\n resolveReminderEscalationRoutingPolicy,\n} from \"./service-helpers-reminder.js\";\nimport type { ReminderActivityProfileSnapshot } from \"./service-types.js\";\n\nexport const DEFAULT_CONTACT_ROUTE_FAILURE_COOLDOWN_MS = 6 * 60 * 60_000;\n\nexport type ContactRoutePurpose =\n | \"reminder_escalation\"\n | \"checkin\"\n | \"workflow\"\n | \"proactive\"\n | \"inbox\";\n\nexport type ContactRoutePolicyCallbacks = {\n resolvePrimaryChannelPolicy: (\n channel: LifeOpsReminderChannel,\n ) => Promise<LifeOpsChannelPolicy | null>;\n hasRuntimeTarget: (\n channel: LifeOpsReminderChannel,\n policy: LifeOpsChannelPolicy | null,\n ) => Promise<boolean>;\n runtimeTargetSendAvailable: boolean;\n};\n\nexport type ContactRoutePolicyOptions = {\n failureCooldownMs?: number;\n directPolicyRequiredChannels?: readonly LifeOpsReminderChannel[];\n};\n\nfunction normalizeNowMs(value: Date | number | undefined): number {\n if (value instanceof Date) {\n return value.getTime();\n }\n return typeof value === \"number\" && Number.isFinite(value)\n ? value\n : Date.now();\n}\n\nfunction hasRecentChannelFailure(args: {\n attempts: readonly LifeOpsReminderAttempt[];\n channel: LifeOpsReminderChannel;\n nowMs: number;\n failureCooldownMs: number;\n}): boolean {\n return args.attempts.some((attempt) => {\n if (attempt.channel !== args.channel) {\n return false;\n }\n if (\n attempt.outcome !== \"blocked_connector\" &&\n attempt.outcome !== \"blocked_policy\"\n ) {\n return false;\n }\n const attemptedMs = attempt.attemptedAt\n ? Date.parse(attempt.attemptedAt)\n : Number.NaN;\n return (\n Number.isFinite(attemptedMs) &&\n args.nowMs - attemptedMs <= args.failureCooldownMs\n );\n });\n}\n\nfunction buildPolicyWeightAdjustments(\n policies: readonly LifeOpsChannelPolicy[],\n): Partial<Record<LifeOpsReminderChannel, number>> {\n const policyWeightAdjustments: Partial<\n Record<LifeOpsReminderChannel, number>\n > = {};\n for (const policy of policies) {\n const channel = isReminderChannel(policy.channelType)\n ? policy.channelType\n : null;\n if (!channel) {\n continue;\n }\n const weight = policy.metadata.routingWeight;\n if (typeof weight === \"number\" && Number.isFinite(weight)) {\n policyWeightAdjustments[channel] =\n (policyWeightAdjustments[channel] ?? 0) + weight;\n }\n }\n return policyWeightAdjustments;\n}\n\nasync function evaluateRouteCandidate(args: {\n candidate: ReminderRouteCandidate;\n candidates: ReminderRouteCandidate[];\n attempts: readonly LifeOpsReminderAttempt[];\n urgency: LifeOpsReminderUrgency;\n nowMs: number;\n failureCooldownMs: number;\n directPolicyRequiredChannels: readonly LifeOpsReminderChannel[];\n interruptionBudget: ReminderRouteCandidate[\"interruptionBudget\"];\n callbacks: ContactRoutePolicyCallbacks;\n}): Promise<void> {\n if (\n args.candidates.some(\n (resolvedCandidate) =>\n resolvedCandidate.channel === args.candidate.channel,\n )\n ) {\n return;\n }\n\n const vetoReasons: string[] = [];\n const channel = args.candidate.channel;\n if (!isReminderChannelAllowedForUrgency(channel, args.urgency)) {\n vetoReasons.push(\"urgency_policy\");\n }\n if (\n args.urgency !== \"critical\" &&\n hasRecentChannelFailure({\n attempts: args.attempts,\n channel,\n nowMs: args.nowMs,\n failureCooldownMs: args.failureCooldownMs,\n })\n ) {\n vetoReasons.push(\"recent_channel_failure\");\n }\n if (channel !== \"in_app\" && args.interruptionBudget === \"low\") {\n vetoReasons.push(\"attention_budget_low\");\n }\n if (vetoReasons.length > 0) {\n args.candidates.push({ ...args.candidate, vetoReasons });\n return;\n }\n if (channel === \"in_app\") {\n args.candidates.push({ ...args.candidate, vetoReasons });\n return;\n }\n\n const policy = await args.callbacks.resolvePrimaryChannelPolicy(channel);\n if (policy) {\n if (policy.metadata.disableReminderRouting === true) {\n args.candidates.push({\n ...args.candidate,\n vetoReasons: [\"channel_policy_disabled\"],\n });\n return;\n }\n if (!policy.allowReminders || !policy.allowEscalation) {\n args.candidates.push({\n ...args.candidate,\n vetoReasons: [\"channel_policy_blocks_escalation\"],\n });\n return;\n }\n } else if (args.directPolicyRequiredChannels.includes(channel)) {\n args.candidates.push({\n ...args.candidate,\n vetoReasons: [\"missing_required_direct_policy\"],\n });\n return;\n }\n\n if (args.directPolicyRequiredChannels.includes(channel)) {\n args.candidates.push({ ...args.candidate, vetoReasons });\n return;\n }\n if (!args.callbacks.runtimeTargetSendAvailable) {\n args.candidates.push({\n ...args.candidate,\n vetoReasons: [\"runtime_target_send_unavailable\"],\n });\n return;\n }\n if (await args.callbacks.hasRuntimeTarget(channel, policy)) {\n args.candidates.push({ ...args.candidate, vetoReasons });\n return;\n }\n args.candidates.push({\n ...args.candidate,\n vetoReasons: [\"runtime_target_missing\"],\n });\n}\n\nexport async function resolveContactRouteCandidates(args: {\n purpose?: ContactRoutePurpose;\n activityProfile: ReminderActivityProfileSnapshot | null;\n ownerContactHints: Record<string, ReminderEscalationRoutingHint>;\n ownerContactSources: readonly string[];\n policies: readonly LifeOpsChannelPolicy[];\n urgency: LifeOpsReminderUrgency;\n attempts?: readonly LifeOpsReminderAttempt[];\n now?: Date | number;\n callbacks: ContactRoutePolicyCallbacks;\n options?: ContactRoutePolicyOptions;\n}): Promise<ReminderRouteCandidate[]> {\n const candidates: ReminderRouteCandidate[] = [];\n const nowMs = normalizeNowMs(args.now);\n const purpose = args.purpose ?? \"proactive\";\n const routingPolicy = resolveReminderEscalationRoutingPolicy({\n activityProfile: args.activityProfile,\n urgency: args.urgency,\n });\n const rankedCandidates = rankReminderEscalationChannelCandidates({\n activityProfile: args.activityProfile,\n ownerContactHints: args.ownerContactHints,\n ownerContactSources: args.ownerContactSources,\n policyChannels: args.policies.map((policy) => policy.channelType),\n policyChannelWeightAdjustments: buildPolicyWeightAdjustments(args.policies),\n urgency: args.urgency,\n routingPolicy,\n now: nowMs,\n });\n\n for (const candidate of rankedCandidates) {\n await evaluateRouteCandidate({\n candidate: {\n ...candidate,\n evidence: [`purpose:${purpose}`, ...candidate.evidence],\n },\n candidates,\n attempts: args.attempts ?? [],\n urgency: args.urgency,\n nowMs,\n failureCooldownMs:\n args.options?.failureCooldownMs ??\n DEFAULT_CONTACT_ROUTE_FAILURE_COOLDOWN_MS,\n directPolicyRequiredChannels: args.options\n ?.directPolicyRequiredChannels ?? [\"sms\", \"voice\"],\n interruptionBudget: routingPolicy.interruptionBudget,\n callbacks: args.callbacks,\n });\n }\n return candidates;\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Continuity / paired-iPhone presence probe for macOS hosts.
|
|
3
|
+
*
|
|
4
|
+
* When the Eliza iOS app is not installed, the owner's iPhone is still
|
|
5
|
+
* visible to the Mac via:
|
|
6
|
+
* - `xcrun devicectl list devices --json-output -` — developer-tools
|
|
7
|
+
* device list that includes paired iPhones with current connection
|
|
8
|
+
* state. Requires Xcode to be installed.
|
|
9
|
+
* - `system_profiler SPBluetoothDataType -json` — Bluetooth pairing
|
|
10
|
+
* metadata including whether the phone is currently connected.
|
|
11
|
+
*
|
|
12
|
+
* We query both sources and emit a `mobile_device` activity signal whenever
|
|
13
|
+
* the connected state transitions. The probe is enabled only on darwin and
|
|
14
|
+
* only when there is no recent `mobile_device` signal from a Capacitor
|
|
15
|
+
* source (to avoid double-counting when the iOS app is already reporting).
|
|
16
|
+
*
|
|
17
|
+
* See `eliza/plugins/plugin-personal-assistant/docs/telemetry-event-families.md` §2.6 for
|
|
18
|
+
* the canonical payload shape.
|
|
19
|
+
*/
|
|
20
|
+
import { type LifeOpsRepository } from "./repository.js";
|
|
21
|
+
/**
|
|
22
|
+
* Injectable shell-runner used by the continuity probe. Defaults to a real
|
|
23
|
+
* `execFile`-backed runner; tests override this with a deterministic fixture
|
|
24
|
+
* instead of touching `xcrun` / `system_profiler` on the developer machine.
|
|
25
|
+
*/
|
|
26
|
+
export interface ContinuityShellRunner {
|
|
27
|
+
run(command: string, args: readonly string[], options: {
|
|
28
|
+
timeoutMs: number;
|
|
29
|
+
maxBuffer: number;
|
|
30
|
+
}): Promise<{
|
|
31
|
+
stdout: string;
|
|
32
|
+
}>;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Emits `mobile_device` activity signals for any paired-iPhone presence
|
|
36
|
+
* transitions observed since the last probe run. Idempotent per
|
|
37
|
+
* `(deviceId, connected, observedAt)` tuple.
|
|
38
|
+
*/
|
|
39
|
+
export declare function probeContinuityDevices(args: {
|
|
40
|
+
repository: LifeOpsRepository;
|
|
41
|
+
agentId: string;
|
|
42
|
+
now?: Date;
|
|
43
|
+
/**
|
|
44
|
+
* Optional shell runner override. Tests inject a fixture to avoid spawning
|
|
45
|
+
* `xcrun` and `system_profiler` on the host machine.
|
|
46
|
+
*/
|
|
47
|
+
shell?: ContinuityShellRunner;
|
|
48
|
+
}): Promise<void>;
|
|
49
|
+
//# sourceMappingURL=continuity-probe.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"continuity-probe.d.ts","sourceRoot":"","sources":["../../src/lifeops/continuity-probe.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAIH,OAAO,EAEL,KAAK,iBAAiB,EACvB,MAAM,iBAAiB,CAAC;AAOzB;;;;GAIG;AACH,MAAM,WAAW,qBAAqB;IACpC,GAAG,CACD,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,SAAS,MAAM,EAAE,EACvB,OAAO,EAAE;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,GAChD,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAChC;AA6KD;;;;GAIG;AACH,wBAAsB,sBAAsB,CAAC,IAAI,EAAE;IACjD,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,IAAI,CAAC;IACX;;;OAGG;IACH,KAAK,CAAC,EAAE,qBAAqB,CAAC;CAC/B,GAAG,OAAO,CAAC,IAAI,CAAC,CAqEhB"}
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { execFile } from "node:child_process";
|
|
2
|
+
import { promisify } from "node:util";
|
|
3
|
+
import {
|
|
4
|
+
createLifeOpsActivitySignal
|
|
5
|
+
} from "./repository.js";
|
|
6
|
+
const execFileAsync = promisify(execFile);
|
|
7
|
+
const CONTINUITY_LOOKBACK_MS = 15 * 60 * 1e3;
|
|
8
|
+
const CONTINUITY_COMMAND_TIMEOUT_MS = 5e3;
|
|
9
|
+
const defaultContinuityShellRunner = {
|
|
10
|
+
async run(command, args, options) {
|
|
11
|
+
const { stdout } = await execFileAsync(command, [...args], {
|
|
12
|
+
timeout: options.timeoutMs,
|
|
13
|
+
maxBuffer: options.maxBuffer
|
|
14
|
+
});
|
|
15
|
+
return { stdout };
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
function isRecord(value) {
|
|
19
|
+
return Boolean(value) && typeof value === "object" && !Array.isArray(value);
|
|
20
|
+
}
|
|
21
|
+
function normalizeString(value) {
|
|
22
|
+
return typeof value === "string" && value.trim().length > 0 ? value.trim() : null;
|
|
23
|
+
}
|
|
24
|
+
async function readDevicectlPairedIphones(nowIso, shell) {
|
|
25
|
+
try {
|
|
26
|
+
const { stdout } = await shell.run(
|
|
27
|
+
"xcrun",
|
|
28
|
+
["devicectl", "list", "devices", "--json-output", "-"],
|
|
29
|
+
{ timeoutMs: CONTINUITY_COMMAND_TIMEOUT_MS, maxBuffer: 512 * 1024 }
|
|
30
|
+
);
|
|
31
|
+
const parsed = JSON.parse(stdout);
|
|
32
|
+
if (!isRecord(parsed)) return [];
|
|
33
|
+
const payload = parsed;
|
|
34
|
+
const devices = payload.result?.devices ?? [];
|
|
35
|
+
return devices.map((device) => {
|
|
36
|
+
const identifier = normalizeString(device.identifier);
|
|
37
|
+
if (!identifier) return null;
|
|
38
|
+
const deviceType = normalizeString(device.deviceProperties?.deviceType);
|
|
39
|
+
if (deviceType !== "iPhone" && deviceType !== "iPad" && deviceType !== "appleTV") {
|
|
40
|
+
if (!deviceType?.toLowerCase().includes("iphone")) {
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
const pairingState = normalizeString(
|
|
45
|
+
device.connectionProperties?.pairingState
|
|
46
|
+
);
|
|
47
|
+
const tunnelState = normalizeString(
|
|
48
|
+
device.connectionProperties?.tunnelState
|
|
49
|
+
);
|
|
50
|
+
const connected = pairingState?.toLowerCase() === "paired" && (tunnelState?.toLowerCase() === "connected" || tunnelState?.toLowerCase() === "available");
|
|
51
|
+
return {
|
|
52
|
+
deviceId: identifier,
|
|
53
|
+
displayName: normalizeString(device.deviceProperties?.name) ?? deviceType,
|
|
54
|
+
connected,
|
|
55
|
+
source: "xcrun_devicectl",
|
|
56
|
+
observedAt: nowIso
|
|
57
|
+
};
|
|
58
|
+
}).filter((entry) => entry !== null);
|
|
59
|
+
} catch {
|
|
60
|
+
return [];
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
async function readBluetoothPairedIphones(nowIso, shell) {
|
|
64
|
+
try {
|
|
65
|
+
const { stdout } = await shell.run(
|
|
66
|
+
"system_profiler",
|
|
67
|
+
["SPBluetoothDataType", "-json"],
|
|
68
|
+
{ timeoutMs: CONTINUITY_COMMAND_TIMEOUT_MS, maxBuffer: 1024 * 1024 }
|
|
69
|
+
);
|
|
70
|
+
const parsed = JSON.parse(stdout);
|
|
71
|
+
if (!isRecord(parsed)) return [];
|
|
72
|
+
const payload = parsed;
|
|
73
|
+
const roots = payload.SPBluetoothDataType ?? [];
|
|
74
|
+
const results = [];
|
|
75
|
+
for (const root of roots) {
|
|
76
|
+
const connectedGroup = isRecord(root.device_connected) ? root.device_connected : null;
|
|
77
|
+
const notConnectedGroup = isRecord(root.device_not_connected) ? root.device_not_connected : null;
|
|
78
|
+
const processGroup = (group, connected) => {
|
|
79
|
+
for (const [name, rawEntry] of Object.entries(group)) {
|
|
80
|
+
if (!isRecord(rawEntry)) continue;
|
|
81
|
+
const entry = rawEntry;
|
|
82
|
+
const minorType = normalizeString(entry.device_minorType)?.toLowerCase() ?? "";
|
|
83
|
+
if (!minorType.includes("phone")) continue;
|
|
84
|
+
const address = normalizeString(entry.device_address);
|
|
85
|
+
if (!address) continue;
|
|
86
|
+
results.push({
|
|
87
|
+
deviceId: address,
|
|
88
|
+
displayName: name,
|
|
89
|
+
connected,
|
|
90
|
+
source: "system_profiler_bluetooth",
|
|
91
|
+
observedAt: nowIso
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
if (connectedGroup) processGroup(connectedGroup, true);
|
|
96
|
+
if (notConnectedGroup) processGroup(notConnectedGroup, false);
|
|
97
|
+
}
|
|
98
|
+
return results;
|
|
99
|
+
} catch {
|
|
100
|
+
return [];
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
async function probeContinuityDevices(args) {
|
|
104
|
+
if (process.platform !== "darwin") return;
|
|
105
|
+
const now = args.now ?? /* @__PURE__ */ new Date();
|
|
106
|
+
const nowIso = now.toISOString();
|
|
107
|
+
const shell = args.shell ?? defaultContinuityShellRunner;
|
|
108
|
+
const recentSignals = await args.repository.listActivitySignals(
|
|
109
|
+
args.agentId,
|
|
110
|
+
{
|
|
111
|
+
sinceAt: new Date(now.getTime() - CONTINUITY_LOOKBACK_MS).toISOString(),
|
|
112
|
+
limit: 64
|
|
113
|
+
}
|
|
114
|
+
);
|
|
115
|
+
const hasAuthoritativeMobile = recentSignals.some(
|
|
116
|
+
(signal) => signal.source === "mobile_device" && typeof signal.platform === "string" && signal.platform.startsWith("capacitor")
|
|
117
|
+
);
|
|
118
|
+
if (hasAuthoritativeMobile) {
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
const [devicectl, bluetooth] = await Promise.all([
|
|
122
|
+
readDevicectlPairedIphones(nowIso, shell),
|
|
123
|
+
readBluetoothPairedIphones(nowIso, shell)
|
|
124
|
+
]);
|
|
125
|
+
const merged = /* @__PURE__ */ new Map();
|
|
126
|
+
for (const entry of bluetooth) {
|
|
127
|
+
merged.set(entry.deviceId, entry);
|
|
128
|
+
}
|
|
129
|
+
for (const entry of devicectl) {
|
|
130
|
+
merged.set(entry.deviceId, entry);
|
|
131
|
+
}
|
|
132
|
+
for (const entry of merged.values()) {
|
|
133
|
+
const previouslySeen = recentSignals.some(
|
|
134
|
+
(signal) => signal.source === "mobile_device" && signal.platform === `macos_continuity:${entry.source}` && typeof signal.metadata.deviceId === "string" && signal.metadata.deviceId === entry.deviceId && signal.state === (entry.connected ? "active" : "background")
|
|
135
|
+
);
|
|
136
|
+
if (previouslySeen) continue;
|
|
137
|
+
await args.repository.createActivitySignal(
|
|
138
|
+
createLifeOpsActivitySignal({
|
|
139
|
+
agentId: args.agentId,
|
|
140
|
+
source: "mobile_device",
|
|
141
|
+
platform: `macos_continuity:${entry.source}`,
|
|
142
|
+
state: entry.connected ? "active" : "background",
|
|
143
|
+
observedAt: entry.observedAt,
|
|
144
|
+
idleState: entry.connected ? "active" : "idle",
|
|
145
|
+
idleTimeSeconds: null,
|
|
146
|
+
onBattery: null,
|
|
147
|
+
health: null,
|
|
148
|
+
metadata: {
|
|
149
|
+
probe: "continuity",
|
|
150
|
+
deviceId: entry.deviceId,
|
|
151
|
+
displayName: entry.displayName,
|
|
152
|
+
source: entry.source
|
|
153
|
+
}
|
|
154
|
+
})
|
|
155
|
+
);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
export {
|
|
159
|
+
probeContinuityDevices
|
|
160
|
+
};
|
|
161
|
+
//# sourceMappingURL=continuity-probe.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/continuity-probe.ts"],"sourcesContent":["/**\n * Continuity / paired-iPhone presence probe for macOS hosts.\n *\n * When the Eliza iOS app is not installed, the owner's iPhone is still\n * visible to the Mac via:\n * - `xcrun devicectl list devices --json-output -` — developer-tools\n * device list that includes paired iPhones with current connection\n * state. Requires Xcode to be installed.\n * - `system_profiler SPBluetoothDataType -json` — Bluetooth pairing\n * metadata including whether the phone is currently connected.\n *\n * We query both sources and emit a `mobile_device` activity signal whenever\n * the connected state transitions. The probe is enabled only on darwin and\n * only when there is no recent `mobile_device` signal from a Capacitor\n * source (to avoid double-counting when the iOS app is already reporting).\n *\n * See `eliza/plugins/plugin-personal-assistant/docs/telemetry-event-families.md` §2.6 for\n * the canonical payload shape.\n */\n\nimport { execFile } from \"node:child_process\";\nimport { promisify } from \"node:util\";\nimport {\n createLifeOpsActivitySignal,\n type LifeOpsRepository,\n} from \"./repository.js\";\n\nconst execFileAsync = promisify(execFile);\n\nconst CONTINUITY_LOOKBACK_MS = 15 * 60 * 1_000;\nconst CONTINUITY_COMMAND_TIMEOUT_MS = 5_000;\n\n/**\n * Injectable shell-runner used by the continuity probe. Defaults to a real\n * `execFile`-backed runner; tests override this with a deterministic fixture\n * instead of touching `xcrun` / `system_profiler` on the developer machine.\n */\nexport interface ContinuityShellRunner {\n run(\n command: string,\n args: readonly string[],\n options: { timeoutMs: number; maxBuffer: number },\n ): Promise<{ stdout: string }>;\n}\n\nconst defaultContinuityShellRunner: ContinuityShellRunner = {\n async run(command, args, options) {\n const { stdout } = await execFileAsync(command, [...args], {\n timeout: options.timeoutMs,\n maxBuffer: options.maxBuffer,\n });\n return { stdout };\n },\n};\n\n/** Shape of a single paired-iPhone presence observation. */\ninterface PairedDevicePresence {\n deviceId: string;\n displayName: string;\n connected: boolean;\n source: \"xcrun_devicectl\" | \"system_profiler_bluetooth\";\n observedAt: string;\n}\n\ninterface DevicectlDevice {\n identifier?: unknown;\n deviceProperties?: {\n name?: unknown;\n deviceType?: unknown;\n };\n connectionProperties?: {\n pairingState?: unknown;\n tunnelState?: unknown;\n };\n}\n\ninterface DevicectlPayload {\n result?: {\n devices?: DevicectlDevice[];\n };\n}\n\ninterface BluetoothRawEntry {\n device_name?: unknown;\n device_address?: unknown;\n device_minorType?: unknown;\n device_connected?: unknown;\n}\n\ninterface BluetoothPayload {\n SPBluetoothDataType?: Array<{\n device_title?: unknown;\n device_connected?: unknown;\n device_not_connected?: unknown;\n }>;\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value) && typeof value === \"object\" && !Array.isArray(value);\n}\n\nfunction normalizeString(value: unknown): string | null {\n return typeof value === \"string\" && value.trim().length > 0\n ? value.trim()\n : null;\n}\n\nasync function readDevicectlPairedIphones(\n nowIso: string,\n shell: ContinuityShellRunner,\n): Promise<PairedDevicePresence[]> {\n try {\n const { stdout } = await shell.run(\n \"xcrun\",\n [\"devicectl\", \"list\", \"devices\", \"--json-output\", \"-\"],\n { timeoutMs: CONTINUITY_COMMAND_TIMEOUT_MS, maxBuffer: 512 * 1024 },\n );\n const parsed: unknown = JSON.parse(stdout);\n if (!isRecord(parsed)) return [];\n const payload = parsed as DevicectlPayload;\n const devices = payload.result?.devices ?? [];\n return devices\n .map((device): PairedDevicePresence | null => {\n const identifier = normalizeString(device.identifier);\n if (!identifier) return null;\n const deviceType = normalizeString(device.deviceProperties?.deviceType);\n // Only report iPhones / iPads; ignore Vision Pro, Apple Watch, etc.\n if (\n deviceType !== \"iPhone\" &&\n deviceType !== \"iPad\" &&\n deviceType !== \"appleTV\"\n ) {\n // deviceType is free-form — also accept values that include \"iPhone\".\n if (!deviceType?.toLowerCase().includes(\"iphone\")) {\n return null;\n }\n }\n const pairingState = normalizeString(\n device.connectionProperties?.pairingState,\n );\n const tunnelState = normalizeString(\n device.connectionProperties?.tunnelState,\n );\n const connected =\n pairingState?.toLowerCase() === \"paired\" &&\n (tunnelState?.toLowerCase() === \"connected\" ||\n tunnelState?.toLowerCase() === \"available\");\n return {\n deviceId: identifier,\n displayName:\n normalizeString(device.deviceProperties?.name) ?? deviceType,\n connected,\n source: \"xcrun_devicectl\",\n observedAt: nowIso,\n };\n })\n .filter((entry): entry is PairedDevicePresence => entry !== null);\n } catch {\n // `xcrun devicectl` is unavailable when Xcode isn't installed — fall\n // through to the bluetooth probe silently.\n return [];\n }\n}\n\nasync function readBluetoothPairedIphones(\n nowIso: string,\n shell: ContinuityShellRunner,\n): Promise<PairedDevicePresence[]> {\n try {\n const { stdout } = await shell.run(\n \"system_profiler\",\n [\"SPBluetoothDataType\", \"-json\"],\n { timeoutMs: CONTINUITY_COMMAND_TIMEOUT_MS, maxBuffer: 1024 * 1024 },\n );\n const parsed: unknown = JSON.parse(stdout);\n if (!isRecord(parsed)) return [];\n const payload = parsed as BluetoothPayload;\n const roots = payload.SPBluetoothDataType ?? [];\n const results: PairedDevicePresence[] = [];\n for (const root of roots) {\n const connectedGroup = isRecord(root.device_connected)\n ? root.device_connected\n : null;\n const notConnectedGroup = isRecord(root.device_not_connected)\n ? root.device_not_connected\n : null;\n const processGroup = (\n group: Record<string, unknown>,\n connected: boolean,\n ) => {\n for (const [name, rawEntry] of Object.entries(group)) {\n if (!isRecord(rawEntry)) continue;\n const entry = rawEntry as BluetoothRawEntry;\n const minorType =\n normalizeString(entry.device_minorType)?.toLowerCase() ?? \"\";\n if (!minorType.includes(\"phone\")) continue;\n const address = normalizeString(entry.device_address);\n if (!address) continue;\n results.push({\n deviceId: address,\n displayName: name,\n connected,\n source: \"system_profiler_bluetooth\",\n observedAt: nowIso,\n });\n }\n };\n if (connectedGroup) processGroup(connectedGroup, true);\n if (notConnectedGroup) processGroup(notConnectedGroup, false);\n }\n return results;\n } catch {\n return [];\n }\n}\n\n/**\n * Emits `mobile_device` activity signals for any paired-iPhone presence\n * transitions observed since the last probe run. Idempotent per\n * `(deviceId, connected, observedAt)` tuple.\n */\nexport async function probeContinuityDevices(args: {\n repository: LifeOpsRepository;\n agentId: string;\n now?: Date;\n /**\n * Optional shell runner override. Tests inject a fixture to avoid spawning\n * `xcrun` and `system_profiler` on the host machine.\n */\n shell?: ContinuityShellRunner;\n}): Promise<void> {\n if (process.platform !== \"darwin\") return;\n const now = args.now ?? new Date();\n const nowIso = now.toISOString();\n const shell = args.shell ?? defaultContinuityShellRunner;\n\n // Skip if a Capacitor mobile-signals source has been active recently —\n // the iOS app is authoritative when it's running.\n const recentSignals = await args.repository.listActivitySignals(\n args.agentId,\n {\n sinceAt: new Date(now.getTime() - CONTINUITY_LOOKBACK_MS).toISOString(),\n limit: 64,\n },\n );\n const hasAuthoritativeMobile = recentSignals.some(\n (signal) =>\n signal.source === \"mobile_device\" &&\n typeof signal.platform === \"string\" &&\n signal.platform.startsWith(\"capacitor\"),\n );\n if (hasAuthoritativeMobile) {\n return;\n }\n\n const [devicectl, bluetooth] = await Promise.all([\n readDevicectlPairedIphones(nowIso, shell),\n readBluetoothPairedIphones(nowIso, shell),\n ]);\n\n // Merge by deviceId — devicectl wins over bluetooth for the same device.\n const merged = new Map<string, PairedDevicePresence>();\n for (const entry of bluetooth) {\n merged.set(entry.deviceId, entry);\n }\n for (const entry of devicectl) {\n merged.set(entry.deviceId, entry);\n }\n\n for (const entry of merged.values()) {\n const previouslySeen = recentSignals.some(\n (signal) =>\n signal.source === \"mobile_device\" &&\n signal.platform === `macos_continuity:${entry.source}` &&\n typeof signal.metadata.deviceId === \"string\" &&\n signal.metadata.deviceId === entry.deviceId &&\n signal.state === (entry.connected ? \"active\" : \"background\"),\n );\n if (previouslySeen) continue;\n await args.repository.createActivitySignal(\n createLifeOpsActivitySignal({\n agentId: args.agentId,\n source: \"mobile_device\",\n platform: `macos_continuity:${entry.source}`,\n state: entry.connected ? \"active\" : \"background\",\n observedAt: entry.observedAt,\n idleState: entry.connected ? \"active\" : \"idle\",\n idleTimeSeconds: null,\n onBattery: null,\n health: null,\n metadata: {\n probe: \"continuity\",\n deviceId: entry.deviceId,\n displayName: entry.displayName,\n source: entry.source,\n },\n }),\n );\n }\n}\n"],"mappings":"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","names":[]}
|