@elizaos/plugin-personal-assistant 2.0.3-beta.6 → 2.0.3-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/app-block.d.ts +15 -0
- package/dist/actions/app-block.d.ts.map +1 -0
- package/dist/actions/app-block.js +349 -0
- package/dist/actions/app-block.js.map +1 -0
- package/dist/actions/autofill.d.ts +20 -0
- package/dist/actions/autofill.d.ts.map +1 -0
- package/dist/actions/autofill.js +370 -0
- package/dist/actions/autofill.js.map +1 -0
- package/dist/actions/block.d.ts +30 -0
- package/dist/actions/block.d.ts.map +1 -0
- package/dist/actions/block.js +326 -0
- package/dist/actions/block.js.map +1 -0
- package/dist/actions/book-travel.d.ts +10 -0
- package/dist/actions/book-travel.d.ts.map +1 -0
- package/dist/actions/book-travel.js +467 -0
- package/dist/actions/book-travel.js.map +1 -0
- package/dist/actions/brief.d.ts +60 -0
- package/dist/actions/brief.d.ts.map +1 -0
- package/dist/actions/brief.js +485 -0
- package/dist/actions/brief.js.map +1 -0
- package/dist/actions/calendar.d.ts +22 -0
- package/dist/actions/calendar.d.ts.map +1 -0
- package/dist/actions/calendar.js +832 -0
- package/dist/actions/calendar.js.map +1 -0
- package/dist/actions/conflict-detect.d.ts +67 -0
- package/dist/actions/conflict-detect.d.ts.map +1 -0
- package/dist/actions/conflict-detect.js +310 -0
- package/dist/actions/conflict-detect.js.map +1 -0
- package/dist/actions/connector.d.ts +5 -0
- package/dist/actions/connector.d.ts.map +1 -0
- package/dist/actions/connector.js +1354 -0
- package/dist/actions/connector.js.map +1 -0
- package/dist/actions/credentials.d.ts +14 -0
- package/dist/actions/credentials.d.ts.map +1 -0
- package/dist/actions/credentials.js +191 -0
- package/dist/actions/credentials.js.map +1 -0
- package/dist/actions/document.d.ts +36 -0
- package/dist/actions/document.d.ts.map +1 -0
- package/dist/actions/document.js +613 -0
- package/dist/actions/document.js.map +1 -0
- package/dist/actions/entity.d.ts +20 -0
- package/dist/actions/entity.d.ts.map +1 -0
- package/dist/actions/entity.js +785 -0
- package/dist/actions/entity.js.map +1 -0
- package/dist/actions/health.d.ts +4 -0
- package/dist/actions/health.d.ts.map +1 -0
- package/dist/actions/health.js +37 -0
- package/dist/actions/health.js.map +1 -0
- package/dist/actions/inbox.d.ts +12 -0
- package/dist/actions/inbox.d.ts.map +1 -0
- package/dist/actions/inbox.js +13 -0
- package/dist/actions/inbox.js.map +1 -0
- package/dist/actions/lib/calendly-handler.d.ts +3 -0
- package/dist/actions/lib/calendly-handler.d.ts.map +1 -0
- package/dist/actions/lib/calendly-handler.js +506 -0
- package/dist/actions/lib/calendly-handler.js.map +1 -0
- package/dist/actions/lib/extract-goal-plan.d.ts +69 -0
- package/dist/actions/lib/extract-goal-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-goal-plan.js +488 -0
- package/dist/actions/lib/extract-goal-plan.js.map +1 -0
- package/dist/actions/lib/extract-life-operation.d.ts +18 -0
- package/dist/actions/lib/extract-life-operation.d.ts.map +1 -0
- package/dist/actions/lib/extract-life-operation.js +318 -0
- package/dist/actions/lib/extract-life-operation.js.map +1 -0
- package/dist/actions/lib/extract-task-plan.d.ts +78 -0
- package/dist/actions/lib/extract-task-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-task-plan.js +355 -0
- package/dist/actions/lib/extract-task-plan.js.map +1 -0
- package/dist/actions/lib/extract-update-fields.d.ts +27 -0
- package/dist/actions/lib/extract-update-fields.d.ts.map +1 -0
- package/dist/actions/lib/extract-update-fields.js +172 -0
- package/dist/actions/lib/extract-update-fields.js.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts +68 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.js +315 -0
- package/dist/actions/lib/lifeops-deferred-draft.js.map +1 -0
- package/dist/actions/lib/messaging-helpers.d.ts +20 -0
- package/dist/actions/lib/messaging-helpers.d.ts.map +1 -0
- package/dist/actions/lib/messaging-helpers.js +103 -0
- package/dist/actions/lib/messaging-helpers.js.map +1 -0
- package/dist/actions/lib/owner-policy-writes.d.ts +49 -0
- package/dist/actions/lib/owner-policy-writes.d.ts.map +1 -0
- package/dist/actions/lib/owner-policy-writes.js +157 -0
- package/dist/actions/lib/owner-policy-writes.js.map +1 -0
- package/dist/actions/lib/prompt-format.d.ts +3 -0
- package/dist/actions/lib/prompt-format.d.ts.map +1 -0
- package/dist/actions/lib/prompt-format.js +42 -0
- package/dist/actions/lib/prompt-format.js.map +1 -0
- package/dist/actions/lib/scheduling-handler.d.ts +93 -0
- package/dist/actions/lib/scheduling-handler.d.ts.map +1 -0
- package/dist/actions/lib/scheduling-handler.js +868 -0
- package/dist/actions/lib/scheduling-handler.js.map +1 -0
- package/dist/actions/life.d.ts +13 -0
- package/dist/actions/life.d.ts.map +1 -0
- package/dist/actions/life.js +2524 -0
- package/dist/actions/life.js.map +1 -0
- package/dist/actions/money.d.ts +24 -0
- package/dist/actions/money.d.ts.map +1 -0
- package/dist/actions/money.js +41 -0
- package/dist/actions/money.js.map +1 -0
- package/dist/actions/owner-surfaces.d.ts +11 -0
- package/dist/actions/owner-surfaces.d.ts.map +1 -0
- package/dist/actions/owner-surfaces.js +493 -0
- package/dist/actions/owner-surfaces.js.map +1 -0
- package/dist/actions/password-manager.d.ts +10 -0
- package/dist/actions/password-manager.d.ts.map +1 -0
- package/dist/actions/password-manager.js +195 -0
- package/dist/actions/password-manager.js.map +1 -0
- package/dist/actions/payments.d.ts +10 -0
- package/dist/actions/payments.d.ts.map +1 -0
- package/dist/actions/payments.js +5 -0
- package/dist/actions/payments.js.map +1 -0
- package/dist/actions/prioritize.d.ts +49 -0
- package/dist/actions/prioritize.d.ts.map +1 -0
- package/dist/actions/prioritize.js +313 -0
- package/dist/actions/prioritize.js.map +1 -0
- package/dist/actions/remote-desktop.d.ts +13 -0
- package/dist/actions/remote-desktop.d.ts.map +1 -0
- package/dist/actions/remote-desktop.js +11 -0
- package/dist/actions/remote-desktop.js.map +1 -0
- package/dist/actions/resolve-request.d.ts +12 -0
- package/dist/actions/resolve-request.d.ts.map +1 -0
- package/dist/actions/resolve-request.js +427 -0
- package/dist/actions/resolve-request.js.map +1 -0
- package/dist/actions/schedule.d.ts +10 -0
- package/dist/actions/schedule.d.ts.map +1 -0
- package/dist/actions/schedule.js +113 -0
- package/dist/actions/schedule.js.map +1 -0
- package/dist/actions/scheduled-task.d.ts +32 -0
- package/dist/actions/scheduled-task.d.ts.map +1 -0
- package/dist/actions/scheduled-task.js +661 -0
- package/dist/actions/scheduled-task.js.map +1 -0
- package/dist/actions/screen-time.d.ts +4 -0
- package/dist/actions/screen-time.d.ts.map +1 -0
- package/dist/actions/screen-time.js +47 -0
- package/dist/actions/screen-time.js.map +1 -0
- package/dist/actions/subscriptions.d.ts +8 -0
- package/dist/actions/subscriptions.d.ts.map +1 -0
- package/dist/actions/subscriptions.js +327 -0
- package/dist/actions/subscriptions.js.map +1 -0
- package/dist/actions/voice-call.d.ts +16 -0
- package/dist/actions/voice-call.d.ts.map +1 -0
- package/dist/actions/voice-call.js +756 -0
- package/dist/actions/voice-call.js.map +1 -0
- package/dist/actions/website-block.d.ts +15 -0
- package/dist/actions/website-block.d.ts.map +1 -0
- package/dist/actions/website-block.js +719 -0
- package/dist/actions/website-block.js.map +1 -0
- package/dist/actions/work-thread.d.ts +5 -0
- package/dist/actions/work-thread.d.ts.map +1 -0
- package/dist/actions/work-thread.js +556 -0
- package/dist/actions/work-thread.js.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts +28 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.js +61 -0
- package/dist/activity-profile/activity-tracker-repo.js.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts +52 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.js +119 -0
- package/dist/activity-profile/activity-tracker-reporting.js.map +1 -0
- package/dist/activity-profile/activity-tracker-service.d.ts +36 -0
- package/dist/activity-profile/activity-tracker-service.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-service.js +187 -0
- package/dist/activity-profile/activity-tracker-service.js.map +1 -0
- package/dist/activity-profile/analyzer.d.ts +23 -0
- package/dist/activity-profile/analyzer.d.ts.map +1 -0
- package/dist/activity-profile/analyzer.js +485 -0
- package/dist/activity-profile/analyzer.js.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts +14 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.js +159 -0
- package/dist/activity-profile/presence-signal-bridge-service.js.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts +3 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.js +21 -0
- package/dist/activity-profile/proactive-inbox-digest.js.map +1 -0
- package/dist/activity-profile/proactive-planner.d.ts +150 -0
- package/dist/activity-profile/proactive-planner.d.ts.map +1 -0
- package/dist/activity-profile/proactive-planner.js +529 -0
- package/dist/activity-profile/proactive-planner.js.map +1 -0
- package/dist/activity-profile/proactive-worker.d.ts +33 -0
- package/dist/activity-profile/proactive-worker.d.ts.map +1 -0
- package/dist/activity-profile/proactive-worker.js +779 -0
- package/dist/activity-profile/proactive-worker.js.map +1 -0
- package/dist/activity-profile/profile-metadata.d.ts +10 -0
- package/dist/activity-profile/profile-metadata.d.ts.map +1 -0
- package/dist/activity-profile/profile-metadata.js +16 -0
- package/dist/activity-profile/profile-metadata.js.map +1 -0
- package/dist/activity-profile/redactor.d.ts +15 -0
- package/dist/activity-profile/redactor.d.ts.map +1 -0
- package/dist/activity-profile/redactor.js +22 -0
- package/dist/activity-profile/redactor.js.map +1 -0
- package/dist/activity-profile/service.d.ts +11 -0
- package/dist/activity-profile/service.d.ts.map +1 -0
- package/dist/activity-profile/service.js +272 -0
- package/dist/activity-profile/service.js.map +1 -0
- package/dist/activity-profile/types.d.ts +97 -0
- package/dist/activity-profile/types.d.ts.map +1 -0
- package/dist/activity-profile/types.js +36 -0
- package/dist/activity-profile/types.js.map +1 -0
- package/dist/agent-lifeops.d.ts +2 -0
- package/dist/agent-lifeops.d.ts.map +1 -0
- package/dist/agent-lifeops.js +2 -0
- package/dist/agent-lifeops.js.map +1 -0
- package/dist/api/client-lifeops.d.ts +319 -0
- package/dist/api/client-lifeops.d.ts.map +1 -0
- package/dist/api/client-lifeops.js +794 -0
- package/dist/api/client-lifeops.js.map +1 -0
- package/dist/automation-node-contributor.d.ts +2 -0
- package/dist/automation-node-contributor.d.ts.map +1 -0
- package/dist/automation-node-contributor.js +184 -0
- package/dist/automation-node-contributor.js.map +1 -0
- package/dist/client.d.ts +16 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +18 -0
- package/dist/client.js.map +1 -0
- package/dist/components/AppBlockerSettingsCard.d.ts +3 -0
- package/dist/components/AppBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/AppBlockerSettingsCard.js +538 -0
- package/dist/components/AppBlockerSettingsCard.js.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts +3 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.js +148 -0
- package/dist/components/WebsiteBlockerSettingsCard.js.map +1 -0
- package/dist/contracts/index.d.ts +2 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/index.js +2 -0
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/lifeops.d.ts +2 -0
- package/dist/contracts/lifeops.d.ts.map +1 -0
- package/dist/contracts/lifeops.js +2 -0
- package/dist/contracts/lifeops.js.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts +17 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.js +56 -0
- package/dist/default-packs/autofill-whitelist-pack.js.map +1 -0
- package/dist/default-packs/consolidation-policies.d.ts +14 -0
- package/dist/default-packs/consolidation-policies.d.ts.map +1 -0
- package/dist/default-packs/consolidation-policies.js +17 -0
- package/dist/default-packs/consolidation-policies.js.map +1 -0
- package/dist/default-packs/contract-types.d.ts +200 -0
- package/dist/default-packs/contract-types.d.ts.map +1 -0
- package/dist/default-packs/contract-types.js +1 -0
- package/dist/default-packs/contract-types.js.map +1 -0
- package/dist/default-packs/daily-rhythm.d.ts +28 -0
- package/dist/default-packs/daily-rhythm.d.ts.map +1 -0
- package/dist/default-packs/daily-rhythm.js +136 -0
- package/dist/default-packs/daily-rhythm.js.map +1 -0
- package/dist/default-packs/escalation-ladders.d.ts +18 -0
- package/dist/default-packs/escalation-ladders.d.ts.map +1 -0
- package/dist/default-packs/escalation-ladders.js +17 -0
- package/dist/default-packs/escalation-ladders.js.map +1 -0
- package/dist/default-packs/executive-assistant.d.ts +50 -0
- package/dist/default-packs/executive-assistant.d.ts.map +1 -0
- package/dist/default-packs/executive-assistant.js +745 -0
- package/dist/default-packs/executive-assistant.js.map +1 -0
- package/dist/default-packs/followup-starter.d.ts +49 -0
- package/dist/default-packs/followup-starter.d.ts.map +1 -0
- package/dist/default-packs/followup-starter.js +104 -0
- package/dist/default-packs/followup-starter.js.map +1 -0
- package/dist/default-packs/habit-starters.d.ts +37 -0
- package/dist/default-packs/habit-starters.d.ts.map +1 -0
- package/dist/default-packs/habit-starters.js +255 -0
- package/dist/default-packs/habit-starters.js.map +1 -0
- package/dist/default-packs/inbox-triage-starter.d.ts +23 -0
- package/dist/default-packs/inbox-triage-starter.d.ts.map +1 -0
- package/dist/default-packs/inbox-triage-starter.js +61 -0
- package/dist/default-packs/inbox-triage-starter.js.map +1 -0
- package/dist/default-packs/index.d.ts +54 -0
- package/dist/default-packs/index.d.ts.map +1 -0
- package/dist/default-packs/index.js +150 -0
- package/dist/default-packs/index.js.map +1 -0
- package/dist/default-packs/lint.d.ts +62 -0
- package/dist/default-packs/lint.d.ts.map +1 -0
- package/dist/default-packs/lint.js +161 -0
- package/dist/default-packs/lint.js.map +1 -0
- package/dist/default-packs/morning-brief.d.ts +44 -0
- package/dist/default-packs/morning-brief.d.ts.map +1 -0
- package/dist/default-packs/morning-brief.js +69 -0
- package/dist/default-packs/morning-brief.js.map +1 -0
- package/dist/default-packs/quiet-user-watcher.d.ts +49 -0
- package/dist/default-packs/quiet-user-watcher.d.ts.map +1 -0
- package/dist/default-packs/quiet-user-watcher.js +92 -0
- package/dist/default-packs/quiet-user-watcher.js.map +1 -0
- package/dist/default-packs/registry-types.d.ts +51 -0
- package/dist/default-packs/registry-types.d.ts.map +1 -0
- package/dist/default-packs/registry-types.js +1 -0
- package/dist/default-packs/registry-types.js.map +1 -0
- package/dist/default-packs/task-definitions.d.ts +88 -0
- package/dist/default-packs/task-definitions.d.ts.map +1 -0
- package/dist/default-packs/task-definitions.js +87 -0
- package/dist/default-packs/task-definitions.js.map +1 -0
- package/dist/events/index.d.ts +34 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +30 -0
- package/dist/events/index.js.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts +3 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.js +90 -0
- package/dist/followup/actions/listOverdueFollowups.js.map +1 -0
- package/dist/followup/actions/markFollowupDone.d.ts +3 -0
- package/dist/followup/actions/markFollowupDone.d.ts.map +1 -0
- package/dist/followup/actions/markFollowupDone.js +171 -0
- package/dist/followup/actions/markFollowupDone.js.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts +3 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.js +171 -0
- package/dist/followup/actions/setFollowupThreshold.js.map +1 -0
- package/dist/followup/followup-tracker.d.ts +83 -0
- package/dist/followup/followup-tracker.d.ts.map +1 -0
- package/dist/followup/followup-tracker.js +311 -0
- package/dist/followup/followup-tracker.js.map +1 -0
- package/dist/followup/index.d.ts +5 -0
- package/dist/followup/index.d.ts.map +1 -0
- package/dist/followup/index.js +39 -0
- package/dist/followup/index.js.map +1 -0
- package/dist/hooks/connector-error.d.ts +2 -0
- package/dist/hooks/connector-error.d.ts.map +1 -0
- package/dist/hooks/connector-error.js +13 -0
- package/dist/hooks/connector-error.js.map +1 -0
- package/dist/hooks/useDiscordConnector.d.ts +11 -0
- package/dist/hooks/useDiscordConnector.d.ts.map +1 -0
- package/dist/hooks/useDiscordConnector.js +95 -0
- package/dist/hooks/useDiscordConnector.js.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts +23 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js +630 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js.map +1 -0
- package/dist/hooks/useIMessageConnector.d.ts +10 -0
- package/dist/hooks/useIMessageConnector.d.ts.map +1 -0
- package/dist/hooks/useIMessageConnector.js +57 -0
- package/dist/hooks/useIMessageConnector.js.map +1 -0
- package/dist/hooks/useInbox.d.ts +36 -0
- package/dist/hooks/useInbox.d.ts.map +1 -0
- package/dist/hooks/useInbox.js +96 -0
- package/dist/hooks/useInbox.js.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts +2 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.js +358 -0
- package/dist/hooks/useLifeOpsActivitySignals.js.map +1 -0
- package/dist/hooks/useLifeOpsAppState.d.ts +9 -0
- package/dist/hooks/useLifeOpsAppState.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsAppState.js +79 -0
- package/dist/hooks/useLifeOpsAppState.js.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts +8 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js +60 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts +11 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.js +92 -0
- package/dist/hooks/useLifeOpsXConnector.js.map +1 -0
- package/dist/hooks/useSignalConnector.d.ts +14 -0
- package/dist/hooks/useSignalConnector.d.ts.map +1 -0
- package/dist/hooks/useSignalConnector.js +89 -0
- package/dist/hooks/useSignalConnector.js.map +1 -0
- package/dist/hooks/useTelegramConnector.d.ts +14 -0
- package/dist/hooks/useTelegramConnector.d.ts.map +1 -0
- package/dist/hooks/useTelegramConnector.js +97 -0
- package/dist/hooks/useTelegramConnector.js.map +1 -0
- package/dist/hooks/useWhatsAppConnector.d.ts +8 -0
- package/dist/hooks/useWhatsAppConnector.d.ts.map +1 -0
- package/dist/hooks/useWhatsAppConnector.js +62 -0
- package/dist/hooks/useWhatsAppConnector.js.map +1 -0
- package/dist/inbox/message-fetcher.d.ts +11 -0
- package/dist/inbox/message-fetcher.d.ts.map +1 -0
- package/dist/inbox/message-fetcher.js +13 -0
- package/dist/inbox/message-fetcher.js.map +1 -0
- package/dist/inbox/repository.d.ts +11 -0
- package/dist/inbox/repository.d.ts.map +1 -0
- package/dist/inbox/repository.js +5 -0
- package/dist/inbox/repository.js.map +1 -0
- package/dist/inbox/types.d.ts +10 -0
- package/dist/inbox/types.d.ts.map +1 -0
- package/dist/inbox/types.js +2 -0
- package/dist/inbox/types.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +188 -0
- package/dist/index.js.map +1 -0
- package/dist/lifeops/access.d.ts +29 -0
- package/dist/lifeops/access.d.ts.map +1 -0
- package/dist/lifeops/access.js +56 -0
- package/dist/lifeops/access.js.map +1 -0
- package/dist/lifeops/app-state.d.ts +22 -0
- package/dist/lifeops/app-state.d.ts.map +1 -0
- package/dist/lifeops/app-state.js +67 -0
- package/dist/lifeops/app-state.js.map +1 -0
- package/dist/lifeops/apple-reminders.d.ts +67 -0
- package/dist/lifeops/apple-reminders.d.ts.map +1 -0
- package/dist/lifeops/apple-reminders.js +396 -0
- package/dist/lifeops/apple-reminders.js.map +1 -0
- package/dist/lifeops/approval-queue.d.ts +38 -0
- package/dist/lifeops/approval-queue.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.js +575 -0
- package/dist/lifeops/approval-queue.js.map +1 -0
- package/dist/lifeops/approval-queue.types.d.ts +172 -0
- package/dist/lifeops/approval-queue.types.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.types.js +27 -0
- package/dist/lifeops/approval-queue.types.js.map +1 -0
- package/dist/lifeops/autofill-whitelist.d.ts +20 -0
- package/dist/lifeops/autofill-whitelist.d.ts.map +1 -0
- package/dist/lifeops/autofill-whitelist.js +59 -0
- package/dist/lifeops/autofill-whitelist.js.map +1 -0
- package/dist/lifeops/background-planner-dispatch.d.ts +60 -0
- package/dist/lifeops/background-planner-dispatch.d.ts.map +1 -0
- package/dist/lifeops/background-planner-dispatch.js +113 -0
- package/dist/lifeops/background-planner-dispatch.js.map +1 -0
- package/dist/lifeops/background-planner.d.ts +140 -0
- package/dist/lifeops/background-planner.d.ts.map +1 -0
- package/dist/lifeops/background-planner.js +359 -0
- package/dist/lifeops/background-planner.js.map +1 -0
- package/dist/lifeops/bill-extraction.d.ts +46 -0
- package/dist/lifeops/bill-extraction.d.ts.map +1 -0
- package/dist/lifeops/bill-extraction.js +325 -0
- package/dist/lifeops/bill-extraction.js.map +1 -0
- package/dist/lifeops/browser-constants.d.ts +4 -0
- package/dist/lifeops/browser-constants.d.ts.map +1 -0
- package/dist/lifeops/browser-constants.js +27 -0
- package/dist/lifeops/browser-constants.js.map +1 -0
- package/dist/lifeops/browser-extension-store.d.ts +61 -0
- package/dist/lifeops/browser-extension-store.d.ts.map +1 -0
- package/dist/lifeops/browser-extension-store.js +176 -0
- package/dist/lifeops/browser-extension-store.js.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts +57 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.js +308 -0
- package/dist/lifeops/browser-session-lifecycle.js.map +1 -0
- package/dist/lifeops/bulk-review.d.ts +333 -0
- package/dist/lifeops/bulk-review.d.ts.map +1 -0
- package/dist/lifeops/bulk-review.js +1120 -0
- package/dist/lifeops/bulk-review.js.map +1 -0
- package/dist/lifeops/calendar-gate.d.ts +20 -0
- package/dist/lifeops/calendar-gate.d.ts.map +1 -0
- package/dist/lifeops/calendar-gate.js +30 -0
- package/dist/lifeops/calendar-gate.js.map +1 -0
- package/dist/lifeops/channels/contract.d.ts +47 -0
- package/dist/lifeops/channels/contract.d.ts.map +1 -0
- package/dist/lifeops/channels/contract.js +1 -0
- package/dist/lifeops/channels/contract.js.map +1 -0
- package/dist/lifeops/channels/default-pack.d.ts +26 -0
- package/dist/lifeops/channels/default-pack.d.ts.map +1 -0
- package/dist/lifeops/channels/default-pack.js +243 -0
- package/dist/lifeops/channels/default-pack.js.map +1 -0
- package/dist/lifeops/channels/index.d.ts +5 -0
- package/dist/lifeops/channels/index.d.ts.map +1 -0
- package/dist/lifeops/channels/index.js +23 -0
- package/dist/lifeops/channels/index.js.map +1 -0
- package/dist/lifeops/channels/priority-posture.d.ts +36 -0
- package/dist/lifeops/channels/priority-posture.d.ts.map +1 -0
- package/dist/lifeops/channels/priority-posture.js +27 -0
- package/dist/lifeops/channels/priority-posture.js.map +1 -0
- package/dist/lifeops/channels/registry.d.ts +7 -0
- package/dist/lifeops/channels/registry.d.ts.map +1 -0
- package/dist/lifeops/channels/registry.js +49 -0
- package/dist/lifeops/channels/registry.js.map +1 -0
- package/dist/lifeops/checkin/checkin-service.d.ts +66 -0
- package/dist/lifeops/checkin/checkin-service.d.ts.map +1 -0
- package/dist/lifeops/checkin/checkin-service.js +1084 -0
- package/dist/lifeops/checkin/checkin-service.js.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts +17 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.js +26 -0
- package/dist/lifeops/checkin/schedule-resolver.js.map +1 -0
- package/dist/lifeops/checkin/types.d.ts +106 -0
- package/dist/lifeops/checkin/types.d.ts.map +1 -0
- package/dist/lifeops/checkin/types.js +1 -0
- package/dist/lifeops/checkin/types.js.map +1 -0
- package/dist/lifeops/connectors/_helpers.d.ts +51 -0
- package/dist/lifeops/connectors/_helpers.d.ts.map +1 -0
- package/dist/lifeops/connectors/_helpers.js +104 -0
- package/dist/lifeops/connectors/_helpers.js.map +1 -0
- package/dist/lifeops/connectors/calendly.d.ts +11 -0
- package/dist/lifeops/connectors/calendly.d.ts.map +1 -0
- package/dist/lifeops/connectors/calendly.js +61 -0
- package/dist/lifeops/connectors/calendly.js.map +1 -0
- package/dist/lifeops/connectors/contract.d.ts +88 -0
- package/dist/lifeops/connectors/contract.d.ts.map +1 -0
- package/dist/lifeops/connectors/contract.js +1 -0
- package/dist/lifeops/connectors/contract.js.map +1 -0
- package/dist/lifeops/connectors/default-pack.d.ts +35 -0
- package/dist/lifeops/connectors/default-pack.d.ts.map +1 -0
- package/dist/lifeops/connectors/default-pack.js +37 -0
- package/dist/lifeops/connectors/default-pack.js.map +1 -0
- package/dist/lifeops/connectors/discord.d.ts +8 -0
- package/dist/lifeops/connectors/discord.d.ts.map +1 -0
- package/dist/lifeops/connectors/discord.js +53 -0
- package/dist/lifeops/connectors/discord.js.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts +75 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.js +35 -0
- package/dist/lifeops/connectors/dispatch-policy.js.map +1 -0
- package/dist/lifeops/connectors/duffel.d.ts +11 -0
- package/dist/lifeops/connectors/duffel.d.ts.map +1 -0
- package/dist/lifeops/connectors/duffel.js +74 -0
- package/dist/lifeops/connectors/duffel.js.map +1 -0
- package/dist/lifeops/connectors/google.d.ts +27 -0
- package/dist/lifeops/connectors/google.d.ts.map +1 -0
- package/dist/lifeops/connectors/google.js +80 -0
- package/dist/lifeops/connectors/google.js.map +1 -0
- package/dist/lifeops/connectors/imessage.d.ts +11 -0
- package/dist/lifeops/connectors/imessage.d.ts.map +1 -0
- package/dist/lifeops/connectors/imessage.js +55 -0
- package/dist/lifeops/connectors/imessage.js.map +1 -0
- package/dist/lifeops/connectors/index.d.ts +5 -0
- package/dist/lifeops/connectors/index.d.ts.map +1 -0
- package/dist/lifeops/connectors/index.js +23 -0
- package/dist/lifeops/connectors/index.js.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts +54 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.js +71 -0
- package/dist/lifeops/connectors/mockoon-redirect.js.map +1 -0
- package/dist/lifeops/connectors/registry.d.ts +7 -0
- package/dist/lifeops/connectors/registry.d.ts.map +1 -0
- package/dist/lifeops/connectors/registry.js +55 -0
- package/dist/lifeops/connectors/registry.js.map +1 -0
- package/dist/lifeops/connectors/signal.d.ts +8 -0
- package/dist/lifeops/connectors/signal.d.ts.map +1 -0
- package/dist/lifeops/connectors/signal.js +60 -0
- package/dist/lifeops/connectors/signal.js.map +1 -0
- package/dist/lifeops/connectors/telegram.d.ts +12 -0
- package/dist/lifeops/connectors/telegram.d.ts.map +1 -0
- package/dist/lifeops/connectors/telegram.js +65 -0
- package/dist/lifeops/connectors/telegram.js.map +1 -0
- package/dist/lifeops/connectors/twilio.d.ts +15 -0
- package/dist/lifeops/connectors/twilio.d.ts.map +1 -0
- package/dist/lifeops/connectors/twilio.js +126 -0
- package/dist/lifeops/connectors/twilio.js.map +1 -0
- package/dist/lifeops/connectors/whatsapp.d.ts +10 -0
- package/dist/lifeops/connectors/whatsapp.d.ts.map +1 -0
- package/dist/lifeops/connectors/whatsapp.js +56 -0
- package/dist/lifeops/connectors/whatsapp.js.map +1 -0
- package/dist/lifeops/connectors/x.d.ts +8 -0
- package/dist/lifeops/connectors/x.d.ts.map +1 -0
- package/dist/lifeops/connectors/x.js +62 -0
- package/dist/lifeops/connectors/x.js.map +1 -0
- package/dist/lifeops/contact-route-policy.d.ts +27 -0
- package/dist/lifeops/contact-route-policy.d.ts.map +1 -0
- package/dist/lifeops/contact-route-policy.js +153 -0
- package/dist/lifeops/contact-route-policy.js.map +1 -0
- package/dist/lifeops/continuity-probe.d.ts +49 -0
- package/dist/lifeops/continuity-probe.d.ts.map +1 -0
- package/dist/lifeops/continuity-probe.js +161 -0
- package/dist/lifeops/continuity-probe.js.map +1 -0
- package/dist/lifeops/cross-channel-search.d.ts +108 -0
- package/dist/lifeops/cross-channel-search.d.ts.map +1 -0
- package/dist/lifeops/cross-channel-search.js +888 -0
- package/dist/lifeops/cross-channel-search.js.map +1 -0
- package/dist/lifeops/defaults.d.ts +30 -0
- package/dist/lifeops/defaults.d.ts.map +1 -0
- package/dist/lifeops/defaults.js +206 -0
- package/dist/lifeops/defaults.js.map +1 -0
- package/dist/lifeops/device-bus-service.d.ts +16 -0
- package/dist/lifeops/device-bus-service.d.ts.map +1 -0
- package/dist/lifeops/device-bus-service.js +20 -0
- package/dist/lifeops/device-bus-service.js.map +1 -0
- package/dist/lifeops/device-identity.d.ts +31 -0
- package/dist/lifeops/device-identity.d.ts.map +1 -0
- package/dist/lifeops/device-identity.js +94 -0
- package/dist/lifeops/device-identity.js.map +1 -0
- package/dist/lifeops/document-review.d.ts +264 -0
- package/dist/lifeops/document-review.d.ts.map +1 -0
- package/dist/lifeops/document-review.js +925 -0
- package/dist/lifeops/document-review.js.map +1 -0
- package/dist/lifeops/email-classifier.d.ts +9 -0
- package/dist/lifeops/email-classifier.d.ts.map +1 -0
- package/dist/lifeops/email-classifier.js +15 -0
- package/dist/lifeops/email-classifier.js.map +1 -0
- package/dist/lifeops/email-curation.d.ts +13 -0
- package/dist/lifeops/email-curation.d.ts.map +1 -0
- package/dist/lifeops/email-curation.js +2 -0
- package/dist/lifeops/email-curation.js.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts +7 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.js +1 -0
- package/dist/lifeops/email-unsubscribe-types.js.map +1 -0
- package/dist/lifeops/enforcement-windows.d.ts +34 -0
- package/dist/lifeops/enforcement-windows.d.ts.map +1 -0
- package/dist/lifeops/enforcement-windows.js +80 -0
- package/dist/lifeops/enforcement-windows.js.map +1 -0
- package/dist/lifeops/engine.d.ts +8 -0
- package/dist/lifeops/engine.d.ts.map +1 -0
- package/dist/lifeops/engine.js +540 -0
- package/dist/lifeops/engine.js.map +1 -0
- package/dist/lifeops/entities/index.d.ts +4 -0
- package/dist/lifeops/entities/index.d.ts.map +1 -0
- package/dist/lifeops/entities/index.js +29 -0
- package/dist/lifeops/entities/index.js.map +1 -0
- package/dist/lifeops/entities/merge.d.ts +9 -0
- package/dist/lifeops/entities/merge.d.ts.map +1 -0
- package/dist/lifeops/entities/merge.js +17 -0
- package/dist/lifeops/entities/merge.js.map +1 -0
- package/dist/lifeops/entities/store.d.ts +13 -0
- package/dist/lifeops/entities/store.d.ts.map +1 -0
- package/dist/lifeops/entities/store.js +7 -0
- package/dist/lifeops/entities/store.js.map +1 -0
- package/dist/lifeops/entities/types.d.ts +9 -0
- package/dist/lifeops/entities/types.d.ts.map +1 -0
- package/dist/lifeops/entities/types.js +13 -0
- package/dist/lifeops/entities/types.js.map +1 -0
- package/dist/lifeops/entities/voice-attribution.d.ts +70 -0
- package/dist/lifeops/entities/voice-attribution.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-attribution.js +121 -0
- package/dist/lifeops/entities/voice-attribution.js.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts +32 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.js +68 -0
- package/dist/lifeops/entities/voice-observer-bridge.js.map +1 -0
- package/dist/lifeops/entities/voice-observer.d.ts +72 -0
- package/dist/lifeops/entities/voice-observer.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer.js +97 -0
- package/dist/lifeops/entities/voice-observer.js.map +1 -0
- package/dist/lifeops/escalation-ladders.d.ts +28 -0
- package/dist/lifeops/escalation-ladders.d.ts.map +1 -0
- package/dist/lifeops/escalation-ladders.js +17 -0
- package/dist/lifeops/escalation-ladders.js.map +1 -0
- package/dist/lifeops/fda-probe.d.ts +23 -0
- package/dist/lifeops/fda-probe.d.ts.map +1 -0
- package/dist/lifeops/fda-probe.js +59 -0
- package/dist/lifeops/fda-probe.js.map +1 -0
- package/dist/lifeops/feature-flags.d.ts +24 -0
- package/dist/lifeops/feature-flags.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.js +261 -0
- package/dist/lifeops/feature-flags.js.map +1 -0
- package/dist/lifeops/feature-flags.types.d.ts +156 -0
- package/dist/lifeops/feature-flags.types.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.types.js +129 -0
- package/dist/lifeops/feature-flags.types.js.map +1 -0
- package/dist/lifeops/first-run/defaults.d.ts +57 -0
- package/dist/lifeops/first-run/defaults.d.ts.map +1 -0
- package/dist/lifeops/first-run/defaults.js +159 -0
- package/dist/lifeops/first-run/defaults.js.map +1 -0
- package/dist/lifeops/first-run/questions.d.ts +74 -0
- package/dist/lifeops/first-run/questions.d.ts.map +1 -0
- package/dist/lifeops/first-run/questions.js +184 -0
- package/dist/lifeops/first-run/questions.js.map +1 -0
- package/dist/lifeops/first-run/replay.d.ts +41 -0
- package/dist/lifeops/first-run/replay.d.ts.map +1 -0
- package/dist/lifeops/first-run/replay.js +34 -0
- package/dist/lifeops/first-run/replay.js.map +1 -0
- package/dist/lifeops/first-run/service.d.ts +147 -0
- package/dist/lifeops/first-run/service.d.ts.map +1 -0
- package/dist/lifeops/first-run/service.js +455 -0
- package/dist/lifeops/first-run/service.js.map +1 -0
- package/dist/lifeops/first-run/state.d.ts +36 -0
- package/dist/lifeops/first-run/state.d.ts.map +1 -0
- package/dist/lifeops/first-run/state.js +128 -0
- package/dist/lifeops/first-run/state.js.map +1 -0
- package/dist/lifeops/global-pause/store.d.ts +22 -0
- package/dist/lifeops/global-pause/store.d.ts.map +1 -0
- package/dist/lifeops/global-pause/store.js +18 -0
- package/dist/lifeops/global-pause/store.js.map +1 -0
- package/dist/lifeops/goal-grounding.d.ts +9 -0
- package/dist/lifeops/goal-grounding.d.ts.map +1 -0
- package/dist/lifeops/goal-grounding.js +19 -0
- package/dist/lifeops/goal-grounding.js.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts +8 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.js +7 -0
- package/dist/lifeops/goal-semantic-evaluator.js.map +1 -0
- package/dist/lifeops/google/format-helpers.d.ts +63 -0
- package/dist/lifeops/google/format-helpers.d.ts.map +1 -0
- package/dist/lifeops/google/format-helpers.js +597 -0
- package/dist/lifeops/google/format-helpers.js.map +1 -0
- package/dist/lifeops/google-plugin-delegates.d.ts +59 -0
- package/dist/lifeops/google-plugin-delegates.d.ts.map +1 -0
- package/dist/lifeops/google-plugin-delegates.js +408 -0
- package/dist/lifeops/google-plugin-delegates.js.map +1 -0
- package/dist/lifeops/google-scopes.d.ts +15 -0
- package/dist/lifeops/google-scopes.d.ts.map +1 -0
- package/dist/lifeops/google-scopes.js +118 -0
- package/dist/lifeops/google-scopes.js.map +1 -0
- package/dist/lifeops/handoff/store.d.ts +23 -0
- package/dist/lifeops/handoff/store.d.ts.map +1 -0
- package/dist/lifeops/handoff/store.js +20 -0
- package/dist/lifeops/handoff/store.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts +16 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.js +33 -0
- package/dist/lifeops/i18n/localized-examples-provider.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts +32 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js +28 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts +64 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.js +283 -0
- package/dist/lifeops/i18n/prompt-registry.js.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts +7 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.js +81 -0
- package/dist/lifeops/imessage-outbound-probe.js.map +1 -0
- package/dist/lifeops/index.d.ts +24 -0
- package/dist/lifeops/index.d.ts.map +1 -0
- package/dist/lifeops/index.js +24 -0
- package/dist/lifeops/index.js.map +1 -0
- package/dist/lifeops/intent-sync.d.ts +64 -0
- package/dist/lifeops/intent-sync.d.ts.map +1 -0
- package/dist/lifeops/intent-sync.js +321 -0
- package/dist/lifeops/intent-sync.js.map +1 -0
- package/dist/lifeops/messaging/index.d.ts +2 -0
- package/dist/lifeops/messaging/index.d.ts.map +1 -0
- package/dist/lifeops/messaging/index.js +5 -0
- package/dist/lifeops/messaging/index.js.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts +3 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.js +83 -0
- package/dist/lifeops/messaging/owner-send-policy.js.map +1 -0
- package/dist/lifeops/notifications-push.d.ts +37 -0
- package/dist/lifeops/notifications-push.d.ts.map +1 -0
- package/dist/lifeops/notifications-push.js +95 -0
- package/dist/lifeops/notifications-push.js.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts +5 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.js +48 -0
- package/dist/lifeops/optimized-prompt-instructions.js.map +1 -0
- package/dist/lifeops/owner/fact-store.d.ts +143 -0
- package/dist/lifeops/owner/fact-store.d.ts.map +1 -0
- package/dist/lifeops/owner/fact-store.js +446 -0
- package/dist/lifeops/owner/fact-store.js.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts +3 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js +241 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js.map +1 -0
- package/dist/lifeops/owner-profile.d.ts +61 -0
- package/dist/lifeops/owner-profile.d.ts.map +1 -0
- package/dist/lifeops/owner-profile.js +407 -0
- package/dist/lifeops/owner-profile.js.map +1 -0
- package/dist/lifeops/pending-prompts/store.d.ts +23 -0
- package/dist/lifeops/pending-prompts/store.d.ts.map +1 -0
- package/dist/lifeops/pending-prompts/store.js +16 -0
- package/dist/lifeops/pending-prompts/store.js.map +1 -0
- package/dist/lifeops/policy-memory.d.ts +190 -0
- package/dist/lifeops/policy-memory.d.ts.map +1 -0
- package/dist/lifeops/policy-memory.js +1026 -0
- package/dist/lifeops/policy-memory.js.map +1 -0
- package/dist/lifeops/priority-scoring.d.ts +51 -0
- package/dist/lifeops/priority-scoring.d.ts.map +1 -0
- package/dist/lifeops/priority-scoring.js +305 -0
- package/dist/lifeops/priority-scoring.js.map +1 -0
- package/dist/lifeops/privacy-egress.d.ts +92 -0
- package/dist/lifeops/privacy-egress.d.ts.map +1 -0
- package/dist/lifeops/privacy-egress.js +230 -0
- package/dist/lifeops/privacy-egress.js.map +1 -0
- package/dist/lifeops/privacy.d.ts +49 -0
- package/dist/lifeops/privacy.d.ts.map +1 -0
- package/dist/lifeops/privacy.js +66 -0
- package/dist/lifeops/privacy.js.map +1 -0
- package/dist/lifeops/redact-sensitive-data.d.ts +32 -0
- package/dist/lifeops/redact-sensitive-data.d.ts.map +1 -0
- package/dist/lifeops/redact-sensitive-data.js +98 -0
- package/dist/lifeops/redact-sensitive-data.js.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts +13 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.js +73 -0
- package/dist/lifeops/registries/app-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/blocker-registry.d.ts +76 -0
- package/dist/lifeops/registries/blocker-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/blocker-registry.js +40 -0
- package/dist/lifeops/registries/blocker-registry.js.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts +57 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.js +82 -0
- package/dist/lifeops/registries/event-kind-registry.js.map +1 -0
- package/dist/lifeops/registries/family-registry.d.ts +72 -0
- package/dist/lifeops/registries/family-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/family-registry.js +98 -0
- package/dist/lifeops/registries/family-registry.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts +32 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js +36 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts +76 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.js +68 -0
- package/dist/lifeops/registries/feature-flag-registry.js.map +1 -0
- package/dist/lifeops/registries/index.d.ts +24 -0
- package/dist/lifeops/registries/index.d.ts.map +1 -0
- package/dist/lifeops/registries/index.js +115 -0
- package/dist/lifeops/registries/index.js.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts +21 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.js +76 -0
- package/dist/lifeops/registries/website-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts +30 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js +315 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts +101 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.js +56 -0
- package/dist/lifeops/registries/workflow-step-registry.js.map +1 -0
- package/dist/lifeops/relationships/extraction.d.ts +77 -0
- package/dist/lifeops/relationships/extraction.d.ts.map +1 -0
- package/dist/lifeops/relationships/extraction.js +146 -0
- package/dist/lifeops/relationships/extraction.js.map +1 -0
- package/dist/lifeops/relationships/index.d.ts +4 -0
- package/dist/lifeops/relationships/index.d.ts.map +1 -0
- package/dist/lifeops/relationships/index.js +19 -0
- package/dist/lifeops/relationships/index.js.map +1 -0
- package/dist/lifeops/relationships/mapping.d.ts +34 -0
- package/dist/lifeops/relationships/mapping.d.ts.map +1 -0
- package/dist/lifeops/relationships/mapping.js +87 -0
- package/dist/lifeops/relationships/mapping.js.map +1 -0
- package/dist/lifeops/relationships/store.d.ts +12 -0
- package/dist/lifeops/relationships/store.d.ts.map +1 -0
- package/dist/lifeops/relationships/store.js +5 -0
- package/dist/lifeops/relationships/store.js.map +1 -0
- package/dist/lifeops/relationships/types.d.ts +9 -0
- package/dist/lifeops/relationships/types.d.ts.map +1 -0
- package/dist/lifeops/relationships/types.js +11 -0
- package/dist/lifeops/relationships/types.js.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts +13 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.js +107 -0
- package/dist/lifeops/relative-schedule-resolver.js.map +1 -0
- package/dist/lifeops/relative-time.d.ts +15 -0
- package/dist/lifeops/relative-time.d.ts.map +1 -0
- package/dist/lifeops/relative-time.js +191 -0
- package/dist/lifeops/relative-time.js.map +1 -0
- package/dist/lifeops/repository.d.ts +638 -0
- package/dist/lifeops/repository.d.ts.map +1 -0
- package/dist/lifeops/repository.js +6289 -0
- package/dist/lifeops/repository.js.map +1 -0
- package/dist/lifeops/runtime-cache.d.ts +4 -0
- package/dist/lifeops/runtime-cache.d.ts.map +1 -0
- package/dist/lifeops/runtime-cache.js +7 -0
- package/dist/lifeops/runtime-cache.js.map +1 -0
- package/dist/lifeops/runtime-service-delegates.d.ts +236 -0
- package/dist/lifeops/runtime-service-delegates.d.ts.map +1 -0
- package/dist/lifeops/runtime-service-delegates.js +839 -0
- package/dist/lifeops/runtime-service-delegates.js.map +1 -0
- package/dist/lifeops/runtime.d.ts +13 -0
- package/dist/lifeops/runtime.d.ts.map +1 -0
- package/dist/lifeops/runtime.js +104 -0
- package/dist/lifeops/runtime.js.map +1 -0
- package/dist/lifeops/schedule-insight.d.ts +133 -0
- package/dist/lifeops/schedule-insight.d.ts.map +1 -0
- package/dist/lifeops/schedule-insight.js +726 -0
- package/dist/lifeops/schedule-insight.js.map +1 -0
- package/dist/lifeops/schedule-state.d.ts +39 -0
- package/dist/lifeops/schedule-state.d.ts.map +1 -0
- package/dist/lifeops/schedule-state.js +671 -0
- package/dist/lifeops/schedule-state.js.map +1 -0
- package/dist/lifeops/schedule-sync-config.d.ts +3 -0
- package/dist/lifeops/schedule-sync-config.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-config.js +23 -0
- package/dist/lifeops/schedule-sync-config.js.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts +2 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.js +2 -0
- package/dist/lifeops/schedule-sync-contracts.js.map +1 -0
- package/dist/lifeops/scheduled-task/index.d.ts +13 -0
- package/dist/lifeops/scheduled-task/index.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/index.js +14 -0
- package/dist/lifeops/scheduled-task/index.js.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts +33 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js +334 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts +28 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.js +202 -0
- package/dist/lifeops/scheduled-task/scheduler.js.map +1 -0
- package/dist/lifeops/scheduled-task/service.d.ts +61 -0
- package/dist/lifeops/scheduled-task/service.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/service.js +64 -0
- package/dist/lifeops/scheduled-task/service.js.map +1 -0
- package/dist/lifeops/scheduler-task.d.ts +19 -0
- package/dist/lifeops/scheduler-task.d.ts.map +1 -0
- package/dist/lifeops/scheduler-task.js +201 -0
- package/dist/lifeops/scheduler-task.js.map +1 -0
- package/dist/lifeops/schema.d.ts +28068 -0
- package/dist/lifeops/schema.d.ts.map +1 -0
- package/dist/lifeops/schema.js +1689 -0
- package/dist/lifeops/schema.js.map +1 -0
- package/dist/lifeops/screen-context.d.ts +66 -0
- package/dist/lifeops/screen-context.d.ts.map +1 -0
- package/dist/lifeops/screen-context.js +347 -0
- package/dist/lifeops/screen-context.js.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts +113 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.js +142 -0
- package/dist/lifeops/seed-routine-migration/migrator.js.map +1 -0
- package/dist/lifeops/seed-routines.d.ts +24 -0
- package/dist/lifeops/seed-routines.d.ts.map +1 -0
- package/dist/lifeops/seed-routines.js +140 -0
- package/dist/lifeops/seed-routines.js.map +1 -0
- package/dist/lifeops/send-policy/contract.d.ts +81 -0
- package/dist/lifeops/send-policy/contract.d.ts.map +1 -0
- package/dist/lifeops/send-policy/contract.js +1 -0
- package/dist/lifeops/send-policy/contract.js.map +1 -0
- package/dist/lifeops/send-policy/index.d.ts +3 -0
- package/dist/lifeops/send-policy/index.d.ts.map +1 -0
- package/dist/lifeops/send-policy/index.js +13 -0
- package/dist/lifeops/send-policy/index.js.map +1 -0
- package/dist/lifeops/send-policy/registry.d.ts +7 -0
- package/dist/lifeops/send-policy/registry.d.ts.map +1 -0
- package/dist/lifeops/send-policy/registry.js +62 -0
- package/dist/lifeops/send-policy/registry.js.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts +46 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.js +103 -0
- package/dist/lifeops/sensitive-request-delivery.js.map +1 -0
- package/dist/lifeops/service-constants.d.ts +10 -0
- package/dist/lifeops/service-constants.d.ts.map +1 -0
- package/dist/lifeops/service-constants.js +129 -0
- package/dist/lifeops/service-constants.js.map +1 -0
- package/dist/lifeops/service-helpers-browser.d.ts +41 -0
- package/dist/lifeops/service-helpers-browser.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-browser.js +290 -0
- package/dist/lifeops/service-helpers-browser.js.map +1 -0
- package/dist/lifeops/service-helpers-misc.d.ts +68 -0
- package/dist/lifeops/service-helpers-misc.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-misc.js +531 -0
- package/dist/lifeops/service-helpers-misc.js.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts +23 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.js +257 -0
- package/dist/lifeops/service-helpers-occurrence.js.map +1 -0
- package/dist/lifeops/service-helpers-reminder.d.ts +260 -0
- package/dist/lifeops/service-helpers-reminder.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-reminder.js +1186 -0
- package/dist/lifeops/service-helpers-reminder.js.map +1 -0
- package/dist/lifeops/service-mixin-browser.d.ts +31 -0
- package/dist/lifeops/service-mixin-browser.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-browser.js +975 -0
- package/dist/lifeops/service-mixin-browser.js.map +1 -0
- package/dist/lifeops/service-mixin-calendar.d.ts +53 -0
- package/dist/lifeops/service-mixin-calendar.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-calendar.js +68 -0
- package/dist/lifeops/service-mixin-calendar.js.map +1 -0
- package/dist/lifeops/service-mixin-core.d.ts +51 -0
- package/dist/lifeops/service-mixin-core.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-core.js +500 -0
- package/dist/lifeops/service-mixin-core.js.map +1 -0
- package/dist/lifeops/service-mixin-definitions.d.ts +14 -0
- package/dist/lifeops/service-mixin-definitions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-definitions.js +470 -0
- package/dist/lifeops/service-mixin-definitions.js.map +1 -0
- package/dist/lifeops/service-mixin-discord.d.ts +49 -0
- package/dist/lifeops/service-mixin-discord.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-discord.js +1253 -0
- package/dist/lifeops/service-mixin-discord.js.map +1 -0
- package/dist/lifeops/service-mixin-drive.d.ts +96 -0
- package/dist/lifeops/service-mixin-drive.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-drive.js +213 -0
- package/dist/lifeops/service-mixin-drive.js.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts +23 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js +27 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js.map +1 -0
- package/dist/lifeops/service-mixin-gmail.d.ts +43 -0
- package/dist/lifeops/service-mixin-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-gmail.js +727 -0
- package/dist/lifeops/service-mixin-gmail.js.map +1 -0
- package/dist/lifeops/service-mixin-goals.d.ts +22 -0
- package/dist/lifeops/service-mixin-goals.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-goals.js +884 -0
- package/dist/lifeops/service-mixin-goals.js.map +1 -0
- package/dist/lifeops/service-mixin-google.d.ts +13 -0
- package/dist/lifeops/service-mixin-google.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-google.js +398 -0
- package/dist/lifeops/service-mixin-google.js.map +1 -0
- package/dist/lifeops/service-mixin-health.d.ts +27 -0
- package/dist/lifeops/service-mixin-health.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-health.js +670 -0
- package/dist/lifeops/service-mixin-health.js.map +1 -0
- package/dist/lifeops/service-mixin-imessage.d.ts +106 -0
- package/dist/lifeops/service-mixin-imessage.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-imessage.js +303 -0
- package/dist/lifeops/service-mixin-imessage.js.map +1 -0
- package/dist/lifeops/service-mixin-inbox.d.ts +55 -0
- package/dist/lifeops/service-mixin-inbox.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-inbox.js +597 -0
- package/dist/lifeops/service-mixin-inbox.js.map +1 -0
- package/dist/lifeops/service-mixin-relationships.d.ts +65 -0
- package/dist/lifeops/service-mixin-relationships.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-relationships.js +150 -0
- package/dist/lifeops/service-mixin-relationships.js.map +1 -0
- package/dist/lifeops/service-mixin-reminders.d.ts +62 -0
- package/dist/lifeops/service-mixin-reminders.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-reminders.js +4003 -0
- package/dist/lifeops/service-mixin-reminders.js.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts +53 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.js +405 -0
- package/dist/lifeops/service-mixin-scheduling.js.map +1 -0
- package/dist/lifeops/service-mixin-screentime.d.ts +71 -0
- package/dist/lifeops/service-mixin-screentime.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-screentime.js +530 -0
- package/dist/lifeops/service-mixin-screentime.js.map +1 -0
- package/dist/lifeops/service-mixin-signal.d.ts +74 -0
- package/dist/lifeops/service-mixin-signal.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-signal.js +214 -0
- package/dist/lifeops/service-mixin-signal.js.map +1 -0
- package/dist/lifeops/service-mixin-sleep.d.ts +68 -0
- package/dist/lifeops/service-mixin-sleep.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-sleep.js +43 -0
- package/dist/lifeops/service-mixin-sleep.js.map +1 -0
- package/dist/lifeops/service-mixin-status.d.ts +31 -0
- package/dist/lifeops/service-mixin-status.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-status.js +373 -0
- package/dist/lifeops/service-mixin-status.js.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts +101 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.js +50 -0
- package/dist/lifeops/service-mixin-subscriptions.js.map +1 -0
- package/dist/lifeops/service-mixin-telegram.d.ts +104 -0
- package/dist/lifeops/service-mixin-telegram.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-telegram.js +280 -0
- package/dist/lifeops/service-mixin-telegram.js.map +1 -0
- package/dist/lifeops/service-mixin-travel.d.ts +66 -0
- package/dist/lifeops/service-mixin-travel.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-travel.js +275 -0
- package/dist/lifeops/service-mixin-travel.js.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts +96 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.js +186 -0
- package/dist/lifeops/service-mixin-whatsapp.js.map +1 -0
- package/dist/lifeops/service-mixin-workflows.d.ts +15 -0
- package/dist/lifeops/service-mixin-workflows.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-workflows.js +710 -0
- package/dist/lifeops/service-mixin-workflows.js.map +1 -0
- package/dist/lifeops/service-mixin-x-read.d.ts +31 -0
- package/dist/lifeops/service-mixin-x-read.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x-read.js +267 -0
- package/dist/lifeops/service-mixin-x-read.js.map +1 -0
- package/dist/lifeops/service-mixin-x.d.ts +66 -0
- package/dist/lifeops/service-mixin-x.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x.js +501 -0
- package/dist/lifeops/service-mixin-x.js.map +1 -0
- package/dist/lifeops/service-normalize-connector.d.ts +19 -0
- package/dist/lifeops/service-normalize-connector.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-connector.js +816 -0
- package/dist/lifeops/service-normalize-connector.js.map +1 -0
- package/dist/lifeops/service-normalize-gmail.d.ts +11 -0
- package/dist/lifeops/service-normalize-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-gmail.js +85 -0
- package/dist/lifeops/service-normalize-gmail.js.map +1 -0
- package/dist/lifeops/service-normalize-task.d.ts +9 -0
- package/dist/lifeops/service-normalize-task.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-task.js +567 -0
- package/dist/lifeops/service-normalize-task.js.map +1 -0
- package/dist/lifeops/service-normalize.d.ts +9 -0
- package/dist/lifeops/service-normalize.d.ts.map +1 -0
- package/dist/lifeops/service-normalize.js +53 -0
- package/dist/lifeops/service-normalize.js.map +1 -0
- package/dist/lifeops/service-types.d.ts +75 -0
- package/dist/lifeops/service-types.d.ts.map +1 -0
- package/dist/lifeops/service-types.js +5 -0
- package/dist/lifeops/service-types.js.map +1 -0
- package/dist/lifeops/service.d.ts +482 -0
- package/dist/lifeops/service.d.ts.map +1 -0
- package/dist/lifeops/service.js +62 -0
- package/dist/lifeops/service.js.map +1 -0
- package/dist/lifeops/signal-runtime-config.d.ts +13 -0
- package/dist/lifeops/signal-runtime-config.d.ts.map +1 -0
- package/dist/lifeops/signal-runtime-config.js +44 -0
- package/dist/lifeops/signal-runtime-config.js.map +1 -0
- package/dist/lifeops/signals/bus.d.ts +78 -0
- package/dist/lifeops/signals/bus.d.ts.map +1 -0
- package/dist/lifeops/signals/bus.js +117 -0
- package/dist/lifeops/signals/bus.js.map +1 -0
- package/dist/lifeops/sql.d.ts +65 -0
- package/dist/lifeops/sql.d.ts.map +1 -0
- package/dist/lifeops/sql.js +182 -0
- package/dist/lifeops/sql.js.map +1 -0
- package/dist/lifeops/stretch-decider.d.ts +73 -0
- package/dist/lifeops/stretch-decider.d.ts.map +1 -0
- package/dist/lifeops/stretch-decider.js +49 -0
- package/dist/lifeops/stretch-decider.js.map +1 -0
- package/dist/lifeops/telemetry-mapping.d.ts +14 -0
- package/dist/lifeops/telemetry-mapping.d.ts.map +1 -0
- package/dist/lifeops/telemetry-mapping.js +115 -0
- package/dist/lifeops/telemetry-mapping.js.map +1 -0
- package/dist/lifeops/telemetry-retention.d.ts +21 -0
- package/dist/lifeops/telemetry-retention.d.ts.map +1 -0
- package/dist/lifeops/telemetry-retention.js +13 -0
- package/dist/lifeops/telemetry-retention.js.map +1 -0
- package/dist/lifeops/time/timezone.d.ts +4 -0
- package/dist/lifeops/time/timezone.d.ts.map +1 -0
- package/dist/lifeops/time/timezone.js +154 -0
- package/dist/lifeops/time/timezone.js.map +1 -0
- package/dist/lifeops/time-util.d.ts +10 -0
- package/dist/lifeops/time-util.d.ts.map +1 -0
- package/dist/lifeops/time-util.js +14 -0
- package/dist/lifeops/time-util.js.map +1 -0
- package/dist/lifeops/time.d.ts +17 -0
- package/dist/lifeops/time.d.ts.map +1 -0
- package/dist/lifeops/time.js +152 -0
- package/dist/lifeops/time.js.map +1 -0
- package/dist/lifeops/travel-booking.types.d.ts +46 -0
- package/dist/lifeops/travel-booking.types.d.ts.map +1 -0
- package/dist/lifeops/travel-booking.types.js +1 -0
- package/dist/lifeops/travel-booking.types.js.map +1 -0
- package/dist/lifeops/triggers/schedule-once.d.ts +19 -0
- package/dist/lifeops/triggers/schedule-once.d.ts.map +1 -0
- package/dist/lifeops/triggers/schedule-once.js +99 -0
- package/dist/lifeops/triggers/schedule-once.js.map +1 -0
- package/dist/lifeops/validate/coding-task-request.d.ts +18 -0
- package/dist/lifeops/validate/coding-task-request.d.ts.map +1 -0
- package/dist/lifeops/validate/coding-task-request.js +16 -0
- package/dist/lifeops/validate/coding-task-request.js.map +1 -0
- package/dist/lifeops/voice/grounded-reply.d.ts +41 -0
- package/dist/lifeops/voice/grounded-reply.d.ts.map +1 -0
- package/dist/lifeops/voice/grounded-reply.js +24 -0
- package/dist/lifeops/voice/grounded-reply.js.map +1 -0
- package/dist/lifeops/voice-affect.d.ts +79 -0
- package/dist/lifeops/voice-affect.d.ts.map +1 -0
- package/dist/lifeops/voice-affect.js +253 -0
- package/dist/lifeops/voice-affect.js.map +1 -0
- package/dist/lifeops/wave1-types.d.ts +125 -0
- package/dist/lifeops/wave1-types.d.ts.map +1 -0
- package/dist/lifeops/wave1-types.js +1 -0
- package/dist/lifeops/wave1-types.js.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts +33 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js +226 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js.map +1 -0
- package/dist/lifeops/work-threads/index.d.ts +3 -0
- package/dist/lifeops/work-threads/index.d.ts.map +1 -0
- package/dist/lifeops/work-threads/index.js +7 -0
- package/dist/lifeops/work-threads/index.js.map +1 -0
- package/dist/lifeops/work-threads/store.d.ts +91 -0
- package/dist/lifeops/work-threads/store.d.ts.map +1 -0
- package/dist/lifeops/work-threads/store.js +245 -0
- package/dist/lifeops/work-threads/store.js.map +1 -0
- package/dist/lifeops/work-threads/types.d.ts +58 -0
- package/dist/lifeops/work-threads/types.d.ts.map +1 -0
- package/dist/lifeops/work-threads/types.js +1 -0
- package/dist/lifeops/work-threads/types.js.map +1 -0
- package/dist/platform/host.d.ts +16 -0
- package/dist/platform/host.d.ts.map +1 -0
- package/dist/platform/host.js +22 -0
- package/dist/platform/host.js.map +1 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.d.ts.map +1 -0
- package/dist/platform/index.js +3 -0
- package/dist/platform/index.js.map +1 -0
- package/dist/platform/lifeops-github.d.ts +15 -0
- package/dist/platform/lifeops-github.d.ts.map +1 -0
- package/dist/platform/lifeops-github.js +146 -0
- package/dist/platform/lifeops-github.js.map +1 -0
- package/dist/plugin.d.ts +106 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +989 -0
- package/dist/plugin.js.map +1 -0
- package/dist/provider.d.ts +4 -0
- package/dist/provider.d.ts.map +1 -0
- package/dist/provider.js +108 -0
- package/dist/provider.js.map +1 -0
- package/dist/providers/activity-profile.d.ts +3 -0
- package/dist/providers/activity-profile.d.ts.map +1 -0
- package/dist/providers/activity-profile.js +140 -0
- package/dist/providers/activity-profile.js.map +1 -0
- package/dist/providers/cross-channel-context.d.ts +29 -0
- package/dist/providers/cross-channel-context.d.ts.map +1 -0
- package/dist/providers/cross-channel-context.js +206 -0
- package/dist/providers/cross-channel-context.js.map +1 -0
- package/dist/providers/first-run.d.ts +22 -0
- package/dist/providers/first-run.d.ts.map +1 -0
- package/dist/providers/first-run.js +93 -0
- package/dist/providers/first-run.js.map +1 -0
- package/dist/providers/health.d.ts +2 -0
- package/dist/providers/health.d.ts.map +1 -0
- package/dist/providers/health.js +14 -0
- package/dist/providers/health.js.map +1 -0
- package/dist/providers/inbox-triage.d.ts +3 -0
- package/dist/providers/inbox-triage.d.ts.map +1 -0
- package/dist/providers/inbox-triage.js +134 -0
- package/dist/providers/inbox-triage.js.map +1 -0
- package/dist/providers/lifeops.d.ts +3 -0
- package/dist/providers/lifeops.d.ts.map +1 -0
- package/dist/providers/lifeops.js +548 -0
- package/dist/providers/lifeops.js.map +1 -0
- package/dist/providers/pending-prompts.d.ts +38 -0
- package/dist/providers/pending-prompts.d.ts.map +1 -0
- package/dist/providers/pending-prompts.js +81 -0
- package/dist/providers/pending-prompts.js.map +1 -0
- package/dist/providers/recent-task-states.d.ts +52 -0
- package/dist/providers/recent-task-states.d.ts.map +1 -0
- package/dist/providers/recent-task-states.js +166 -0
- package/dist/providers/recent-task-states.js.map +1 -0
- package/dist/providers/room-policy.d.ts +16 -0
- package/dist/providers/room-policy.d.ts.map +1 -0
- package/dist/providers/room-policy.js +71 -0
- package/dist/providers/room-policy.js.map +1 -0
- package/dist/providers/work-threads.d.ts +3 -0
- package/dist/providers/work-threads.d.ts.map +1 -0
- package/dist/providers/work-threads.js +97 -0
- package/dist/providers/work-threads.js.map +1 -0
- package/dist/public.d.ts +3 -0
- package/dist/public.d.ts.map +1 -0
- package/dist/public.js +17 -0
- package/dist/public.js.map +1 -0
- package/dist/routes/cloud-features-routes.d.ts +9 -0
- package/dist/routes/cloud-features-routes.d.ts.map +1 -0
- package/dist/routes/cloud-features-routes.js +164 -0
- package/dist/routes/cloud-features-routes.js.map +1 -0
- package/dist/routes/entities.d.ts +14 -0
- package/dist/routes/entities.d.ts.map +1 -0
- package/dist/routes/entities.js +203 -0
- package/dist/routes/entities.js.map +1 -0
- package/dist/routes/lifeops-routes.d.ts +20 -0
- package/dist/routes/lifeops-routes.d.ts.map +1 -0
- package/dist/routes/lifeops-routes.js +2337 -0
- package/dist/routes/lifeops-routes.js.map +1 -0
- package/dist/routes/plugin.d.ts +9 -0
- package/dist/routes/plugin.d.ts.map +1 -0
- package/dist/routes/plugin.js +568 -0
- package/dist/routes/plugin.js.map +1 -0
- package/dist/routes/relationships.d.ts +13 -0
- package/dist/routes/relationships.d.ts.map +1 -0
- package/dist/routes/relationships.js +195 -0
- package/dist/routes/relationships.js.map +1 -0
- package/dist/routes/scheduled-tasks.d.ts +102 -0
- package/dist/routes/scheduled-tasks.d.ts.map +1 -0
- package/dist/routes/scheduled-tasks.js +322 -0
- package/dist/routes/scheduled-tasks.js.map +1 -0
- package/dist/routes/sleep-routes.d.ts +3 -0
- package/dist/routes/sleep-routes.d.ts.map +1 -0
- package/dist/routes/sleep-routes.js +33 -0
- package/dist/routes/sleep-routes.js.map +1 -0
- package/dist/routes/travel-provider-relay-routes.d.ts +2 -0
- package/dist/routes/travel-provider-relay-routes.d.ts.map +1 -0
- package/dist/routes/travel-provider-relay-routes.js +7 -0
- package/dist/routes/travel-provider-relay-routes.js.map +1 -0
- package/dist/routes/website-blocker-routes.d.ts +6 -0
- package/dist/routes/website-blocker-routes.d.ts.map +1 -0
- package/dist/routes/website-blocker-routes.js +218 -0
- package/dist/routes/website-blocker-routes.js.map +1 -0
- package/dist/security/action-confirmation.d.ts +12 -0
- package/dist/security/action-confirmation.d.ts.map +1 -0
- package/dist/security/action-confirmation.js +36 -0
- package/dist/security/action-confirmation.js.map +1 -0
- package/dist/service.d.ts +34 -0
- package/dist/service.d.ts.map +1 -0
- package/dist/service.js +111 -0
- package/dist/service.js.map +1 -0
- package/dist/travel-time/calendar-create.d.ts +17 -0
- package/dist/travel-time/calendar-create.d.ts.map +1 -0
- package/dist/travel-time/calendar-create.js +28 -0
- package/dist/travel-time/calendar-create.js.map +1 -0
- package/dist/travel-time/service.d.ts +114 -0
- package/dist/travel-time/service.d.ts.map +1 -0
- package/dist/travel-time/service.js +209 -0
- package/dist/travel-time/service.js.map +1 -0
- package/dist/types/app-blocker-settings-card.d.ts +2 -0
- package/dist/types/app-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/app-blocker-settings-card.js +1 -0
- package/dist/types/app-blocker-settings-card.js.map +1 -0
- package/dist/types/briefing.d.ts +59 -0
- package/dist/types/briefing.d.ts.map +1 -0
- package/dist/types/briefing.js +1 -0
- package/dist/types/briefing.js.map +1 -0
- package/dist/types/document-request.d.ts +41 -0
- package/dist/types/document-request.d.ts.map +1 -0
- package/dist/types/document-request.js +1 -0
- package/dist/types/document-request.js.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/website-blocker-settings-card.d.ts +2 -0
- package/dist/types/website-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/website-blocker-settings-card.js +1 -0
- package/dist/types/website-blocker-settings-card.js.map +1 -0
- package/dist/ui.d.ts +13 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +25 -0
- package/dist/ui.js.map +1 -0
- package/dist/utils/format-duration.d.ts +2 -0
- package/dist/utils/format-duration.d.ts.map +1 -0
- package/dist/utils/format-duration.js +13 -0
- package/dist/utils/format-duration.js.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +3 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/lifeops-url.d.ts +3 -0
- package/dist/utils/lifeops-url.d.ts.map +1 -0
- package/dist/utils/lifeops-url.js +28 -0
- package/dist/utils/lifeops-url.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts +32 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.js +30 -0
- package/dist/website-blocker/chat-integration/block-activator.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts +7 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js +115 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts +39 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js +133 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts +21 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js +230 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts +13 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js +22 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js.map +1 -0
- package/dist/website-blocker/chat-integration/index.d.ts +5 -0
- package/dist/website-blocker/chat-integration/index.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/index.js +26 -0
- package/dist/website-blocker/chat-integration/index.js.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts +75 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.js +154 -0
- package/dist/website-blocker/proactive-block-bridge.js.map +1 -0
- package/dist/website-blocker/public.d.ts +12 -0
- package/dist/website-blocker/public.d.ts.map +1 -0
- package/dist/website-blocker/public.js +51 -0
- package/dist/website-blocker/public.js.map +1 -0
- package/package.json +28 -28
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
import { hasOwnerAccess } from "@elizaos/agent";
|
|
2
|
+
import { logger } from "@elizaos/core";
|
|
3
|
+
import {
|
|
4
|
+
CROSS_CHANNEL_SEARCH_CHANNELS,
|
|
5
|
+
runCrossChannelSearch
|
|
6
|
+
} from "../lifeops/cross-channel-search.js";
|
|
7
|
+
import {
|
|
8
|
+
createLifeOpsEgressContext,
|
|
9
|
+
redactTextForEgress,
|
|
10
|
+
redactUrlForEgress
|
|
11
|
+
} from "../lifeops/privacy-egress.js";
|
|
12
|
+
const EMPTY = {
|
|
13
|
+
text: "",
|
|
14
|
+
values: { crossChannelHits: 0 },
|
|
15
|
+
data: {}
|
|
16
|
+
};
|
|
17
|
+
const DEFAULT_INJECT_LIMIT = 5;
|
|
18
|
+
const DEFAULT_PER_CHANNEL = 4;
|
|
19
|
+
function isRecord(value) {
|
|
20
|
+
return Boolean(value) && typeof value === "object" && !Array.isArray(value);
|
|
21
|
+
}
|
|
22
|
+
function isCrossChannel(value) {
|
|
23
|
+
return typeof value === "string" && CROSS_CHANNEL_SEARCH_CHANNELS.includes(value);
|
|
24
|
+
}
|
|
25
|
+
function pickRequestFromState(state) {
|
|
26
|
+
if (!state || typeof state !== "object") {
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
const stateRecord = state;
|
|
30
|
+
const direct = stateRecord.crossChannelContextRequest;
|
|
31
|
+
if (isRecord(direct) && typeof direct.query === "string") {
|
|
32
|
+
return normalizeRequest(direct);
|
|
33
|
+
}
|
|
34
|
+
const data = isRecord(stateRecord.data) ? stateRecord.data : null;
|
|
35
|
+
if (data && isRecord(data.cross_channel_context_key)) {
|
|
36
|
+
return normalizeRequest(data.cross_channel_context_key);
|
|
37
|
+
}
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
function normalizeRequest(raw) {
|
|
41
|
+
const query = typeof raw.query === "string" ? raw.query.trim() : "";
|
|
42
|
+
if (!query) return null;
|
|
43
|
+
const person = typeof raw.person === "string" && raw.person.trim() ? raw.person.trim() : void 0;
|
|
44
|
+
const primaryEntityId = typeof raw.primaryEntityId === "string" && raw.primaryEntityId.trim() ? raw.primaryEntityId.trim() : void 0;
|
|
45
|
+
const startIso = typeof raw.startIso === "string" && raw.startIso.trim() ? raw.startIso.trim() : void 0;
|
|
46
|
+
const endIso = typeof raw.endIso === "string" && raw.endIso.trim() ? raw.endIso.trim() : void 0;
|
|
47
|
+
const channels = Array.isArray(raw.channels) ? raw.channels.filter(isCrossChannel) : void 0;
|
|
48
|
+
const limit = typeof raw.limit === "number" && Number.isFinite(raw.limit) ? raw.limit : void 0;
|
|
49
|
+
return {
|
|
50
|
+
query,
|
|
51
|
+
person,
|
|
52
|
+
primaryEntityId,
|
|
53
|
+
startIso,
|
|
54
|
+
endIso,
|
|
55
|
+
channels: channels && channels.length > 0 ? channels : void 0,
|
|
56
|
+
limit
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
function compactHit(hit, egressContext) {
|
|
60
|
+
const citation = {
|
|
61
|
+
platform: hit.citation.platform,
|
|
62
|
+
label: hit.citation.label
|
|
63
|
+
};
|
|
64
|
+
const citationUrl = redactUrlForEgress(hit.citation.url, {
|
|
65
|
+
context: egressContext
|
|
66
|
+
});
|
|
67
|
+
if (citationUrl) {
|
|
68
|
+
citation.url = citationUrl;
|
|
69
|
+
}
|
|
70
|
+
return {
|
|
71
|
+
channel: hit.channel,
|
|
72
|
+
id: hit.id,
|
|
73
|
+
sourceRef: hit.sourceRef,
|
|
74
|
+
timestamp: hit.timestamp,
|
|
75
|
+
speaker: hit.speaker,
|
|
76
|
+
...hit.subject ? { subject: hit.subject } : {},
|
|
77
|
+
text: redactTextForEgress(
|
|
78
|
+
hit.text.replace(/\s+/g, " ").trim().slice(0, 180),
|
|
79
|
+
{
|
|
80
|
+
context: egressContext,
|
|
81
|
+
dataClass: "body"
|
|
82
|
+
}
|
|
83
|
+
),
|
|
84
|
+
citation
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
function renderCrossChannelContextJson(args) {
|
|
88
|
+
return JSON.stringify({
|
|
89
|
+
cross_channel_context: {
|
|
90
|
+
query: args.query,
|
|
91
|
+
hitCount: args.hits.length,
|
|
92
|
+
unsupportedCount: args.unsupported.length,
|
|
93
|
+
degradedCount: args.degraded.length,
|
|
94
|
+
channelsWithHits: args.channelsWithHits,
|
|
95
|
+
hits: args.hits.map((hit) => compactHit(hit, args.egressContext))
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
const crossChannelContextProvider = {
|
|
100
|
+
name: "crossChannelContext",
|
|
101
|
+
description: "Injects cross-channel hits (Gmail + agent memory + optional WS3 cluster fan-out) when the turn carries an explicit crossChannelContextRequest signal identifying a query or person. Owner only. Silent on turns without signal.",
|
|
102
|
+
descriptionCompressed: "Top cross-channel hits for a signaled person/topic. Owner only.",
|
|
103
|
+
dynamic: true,
|
|
104
|
+
// After inboxTriage (14) and before escalation (15).
|
|
105
|
+
position: 14.5,
|
|
106
|
+
contexts: ["email", "messaging", "contacts", "memory"],
|
|
107
|
+
contextGate: { anyOf: ["email", "messaging", "contacts", "memory"] },
|
|
108
|
+
cacheScope: "turn",
|
|
109
|
+
roleGate: { minRole: "OWNER" },
|
|
110
|
+
async get(runtime, message, state) {
|
|
111
|
+
if (!await hasOwnerAccess(runtime, message)) {
|
|
112
|
+
return EMPTY;
|
|
113
|
+
}
|
|
114
|
+
const egressContext = createLifeOpsEgressContext({
|
|
115
|
+
isOwner: true,
|
|
116
|
+
agentId: runtime.agentId,
|
|
117
|
+
entityId: message.entityId
|
|
118
|
+
});
|
|
119
|
+
const request = pickRequestFromState(state);
|
|
120
|
+
if (!request) {
|
|
121
|
+
return EMPTY;
|
|
122
|
+
}
|
|
123
|
+
const personRef = (() => {
|
|
124
|
+
if (request.primaryEntityId) {
|
|
125
|
+
return {
|
|
126
|
+
primaryEntityId: request.primaryEntityId,
|
|
127
|
+
displayName: request.person
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
if (request.person) {
|
|
131
|
+
return { displayName: request.person };
|
|
132
|
+
}
|
|
133
|
+
return void 0;
|
|
134
|
+
})();
|
|
135
|
+
const timeWindow = request.startIso || request.endIso ? { startIso: request.startIso, endIso: request.endIso } : void 0;
|
|
136
|
+
const query = {
|
|
137
|
+
query: request.query,
|
|
138
|
+
personRef,
|
|
139
|
+
timeWindow,
|
|
140
|
+
channels: request.channels,
|
|
141
|
+
limit: request.limit ?? DEFAULT_PER_CHANNEL
|
|
142
|
+
};
|
|
143
|
+
try {
|
|
144
|
+
const result = await runCrossChannelSearch(runtime, query);
|
|
145
|
+
const injected = result.hits.slice(
|
|
146
|
+
0,
|
|
147
|
+
request.limit ?? DEFAULT_INJECT_LIMIT
|
|
148
|
+
);
|
|
149
|
+
if (injected.length === 0) {
|
|
150
|
+
return {
|
|
151
|
+
text: "",
|
|
152
|
+
values: {
|
|
153
|
+
crossChannelHits: 0,
|
|
154
|
+
crossChannelUnsupported: result.unsupported.length,
|
|
155
|
+
crossChannelDegraded: result.degraded.length
|
|
156
|
+
},
|
|
157
|
+
data: {
|
|
158
|
+
crossChannelContext: {
|
|
159
|
+
query: result.query,
|
|
160
|
+
hits: [],
|
|
161
|
+
unsupported: result.unsupported,
|
|
162
|
+
degraded: result.degraded
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
return {
|
|
168
|
+
text: renderCrossChannelContextJson({
|
|
169
|
+
query: result.query,
|
|
170
|
+
hits: injected,
|
|
171
|
+
unsupported: result.unsupported,
|
|
172
|
+
degraded: result.degraded,
|
|
173
|
+
channelsWithHits: result.channelsWithHits,
|
|
174
|
+
egressContext
|
|
175
|
+
}),
|
|
176
|
+
values: {
|
|
177
|
+
crossChannelHits: injected.length,
|
|
178
|
+
crossChannelUnsupported: result.unsupported.length,
|
|
179
|
+
crossChannelDegraded: result.degraded.length,
|
|
180
|
+
crossChannelChannels: result.channelsWithHits
|
|
181
|
+
},
|
|
182
|
+
data: {
|
|
183
|
+
crossChannelContext: {
|
|
184
|
+
query: result.query,
|
|
185
|
+
hits: injected.map((hit) => compactHit(hit, egressContext)),
|
|
186
|
+
unsupported: result.unsupported,
|
|
187
|
+
degraded: result.degraded,
|
|
188
|
+
resolvedPerson: result.resolvedPerson ? {
|
|
189
|
+
primaryEntityId: result.resolvedPerson.primaryEntityId,
|
|
190
|
+
displayName: result.resolvedPerson.displayName
|
|
191
|
+
} : null
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
};
|
|
195
|
+
} catch (err) {
|
|
196
|
+
logger.warn(
|
|
197
|
+
`[crossChannelContext] Skipped injection after error: ${err instanceof Error ? err.message : String(err)}`
|
|
198
|
+
);
|
|
199
|
+
return EMPTY;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
};
|
|
203
|
+
export {
|
|
204
|
+
crossChannelContextProvider
|
|
205
|
+
};
|
|
206
|
+
//# sourceMappingURL=cross-channel-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/providers/cross-channel-context.ts"],"sourcesContent":["/**\n * cross-channel-context provider (WS1).\n *\n * When the planner's signal detector flags the current turn as involving\n * a named person or a topic worth pulling prior signal for, this\n * provider injects the top-N cross-channel hits into context. It never\n * fires on empty signal and never silently returns stale data.\n *\n * Signal sources (in priority order):\n * 1. Explicit state key `crossChannelContextRequest` — set by actions\n * or the planner when they already know what to fetch.\n * 2. Structured hint in state.data.cross_channel_context_key.\n *\n * When neither signal is present, the provider returns EMPTY rather\n * than running a speculative search on every turn.\n */\n\nimport { hasOwnerAccess } from \"@elizaos/agent\";\nimport type {\n IAgentRuntime,\n Memory,\n Provider,\n ProviderResult,\n State,\n UUID,\n} from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport {\n CROSS_CHANNEL_SEARCH_CHANNELS,\n type CrossChannelSearchChannel,\n type CrossChannelSearchHit,\n type CrossChannelSearchQuery,\n runCrossChannelSearch,\n} from \"../lifeops/cross-channel-search.js\";\nimport {\n createLifeOpsEgressContext,\n type LifeOpsEgressContext,\n redactTextForEgress,\n redactUrlForEgress,\n} from \"../lifeops/privacy-egress.js\";\n\nconst EMPTY: ProviderResult = {\n text: \"\",\n values: { crossChannelHits: 0 },\n data: {},\n};\n\nconst DEFAULT_INJECT_LIMIT = 5;\nconst DEFAULT_PER_CHANNEL = 4;\n\nexport type CrossChannelContextRequest = {\n query: string;\n person?: string;\n primaryEntityId?: UUID;\n startIso?: string;\n endIso?: string;\n channels?: CrossChannelSearchChannel[];\n limit?: number;\n};\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value) && typeof value === \"object\" && !Array.isArray(value);\n}\n\nfunction isCrossChannel(value: unknown): value is CrossChannelSearchChannel {\n return (\n typeof value === \"string\" &&\n (CROSS_CHANNEL_SEARCH_CHANNELS as readonly string[]).includes(value)\n );\n}\n\nfunction pickRequestFromState(\n state: State | undefined,\n): CrossChannelContextRequest | null {\n if (!state || typeof state !== \"object\") {\n return null;\n }\n\n const stateRecord = state as Record<string, unknown>;\n const direct = stateRecord.crossChannelContextRequest;\n if (isRecord(direct) && typeof direct.query === \"string\") {\n return normalizeRequest(direct);\n }\n\n const data = isRecord(stateRecord.data) ? stateRecord.data : null;\n if (data && isRecord(data.cross_channel_context_key)) {\n return normalizeRequest(data.cross_channel_context_key);\n }\n return null;\n}\n\nfunction normalizeRequest(\n raw: Record<string, unknown>,\n): CrossChannelContextRequest | null {\n const query = typeof raw.query === \"string\" ? raw.query.trim() : \"\";\n if (!query) return null;\n\n const person =\n typeof raw.person === \"string\" && raw.person.trim()\n ? raw.person.trim()\n : undefined;\n const primaryEntityId =\n typeof raw.primaryEntityId === \"string\" && raw.primaryEntityId.trim()\n ? (raw.primaryEntityId.trim() as UUID)\n : undefined;\n const startIso =\n typeof raw.startIso === \"string\" && raw.startIso.trim()\n ? raw.startIso.trim()\n : undefined;\n const endIso =\n typeof raw.endIso === \"string\" && raw.endIso.trim()\n ? raw.endIso.trim()\n : undefined;\n const channels = Array.isArray(raw.channels)\n ? (raw.channels.filter(isCrossChannel) as CrossChannelSearchChannel[])\n : undefined;\n const limit =\n typeof raw.limit === \"number\" && Number.isFinite(raw.limit)\n ? raw.limit\n : undefined;\n\n return {\n query,\n person,\n primaryEntityId,\n startIso,\n endIso,\n channels: channels && channels.length > 0 ? channels : undefined,\n limit,\n };\n}\n\nfunction compactHit(\n hit: CrossChannelSearchHit,\n egressContext: LifeOpsEgressContext,\n) {\n const citation: Record<string, string> = {\n platform: hit.citation.platform,\n label: hit.citation.label,\n };\n const citationUrl = redactUrlForEgress(hit.citation.url, {\n context: egressContext,\n });\n if (citationUrl) {\n citation.url = citationUrl;\n }\n return {\n channel: hit.channel,\n id: hit.id,\n sourceRef: hit.sourceRef,\n timestamp: hit.timestamp,\n speaker: hit.speaker,\n ...(hit.subject ? { subject: hit.subject } : {}),\n text: redactTextForEgress(\n hit.text.replace(/\\s+/g, \" \").trim().slice(0, 180),\n {\n context: egressContext,\n dataClass: \"body\",\n },\n ),\n citation,\n };\n}\n\nfunction renderCrossChannelContextJson(args: {\n query: string;\n hits: CrossChannelSearchHit[];\n unsupported: unknown[];\n degraded: unknown[];\n channelsWithHits: CrossChannelSearchChannel[];\n egressContext: LifeOpsEgressContext;\n}): string {\n return JSON.stringify({\n cross_channel_context: {\n query: args.query,\n hitCount: args.hits.length,\n unsupportedCount: args.unsupported.length,\n degradedCount: args.degraded.length,\n channelsWithHits: args.channelsWithHits,\n hits: args.hits.map((hit) => compactHit(hit, args.egressContext)),\n },\n });\n}\n\nexport const crossChannelContextProvider: Provider = {\n name: \"crossChannelContext\",\n description:\n \"Injects cross-channel hits (Gmail + agent memory + optional WS3 \" +\n \"cluster fan-out) when the turn carries an explicit \" +\n \"crossChannelContextRequest signal identifying a query or person. \" +\n \"Owner only. Silent on turns without signal.\",\n descriptionCompressed:\n \"Top cross-channel hits for a signaled person/topic. Owner only.\",\n dynamic: true,\n // After inboxTriage (14) and before escalation (15).\n position: 14.5,\n contexts: [\"email\", \"messaging\", \"contacts\", \"memory\"],\n contextGate: { anyOf: [\"email\", \"messaging\", \"contacts\", \"memory\"] },\n cacheScope: \"turn\",\n roleGate: { minRole: \"OWNER\" },\n\n async get(\n runtime: IAgentRuntime,\n message: Memory,\n state: State | undefined,\n ): Promise<ProviderResult> {\n if (!(await hasOwnerAccess(runtime, message))) {\n return EMPTY;\n }\n const egressContext = createLifeOpsEgressContext({\n isOwner: true,\n agentId: runtime.agentId,\n entityId: message.entityId,\n });\n\n const request = pickRequestFromState(state);\n if (!request) {\n return EMPTY;\n }\n\n const personRef = (() => {\n if (request.primaryEntityId) {\n return {\n primaryEntityId: request.primaryEntityId,\n displayName: request.person,\n };\n }\n if (request.person) {\n return { displayName: request.person };\n }\n return undefined;\n })();\n\n const timeWindow =\n request.startIso || request.endIso\n ? { startIso: request.startIso, endIso: request.endIso }\n : undefined;\n\n const query: CrossChannelSearchQuery = {\n query: request.query,\n personRef,\n timeWindow,\n channels: request.channels,\n limit: request.limit ?? DEFAULT_PER_CHANNEL,\n };\n\n try {\n const result = await runCrossChannelSearch(runtime, query);\n const injected = result.hits.slice(\n 0,\n request.limit ?? DEFAULT_INJECT_LIMIT,\n );\n\n if (injected.length === 0) {\n return {\n text: \"\",\n values: {\n crossChannelHits: 0,\n crossChannelUnsupported: result.unsupported.length,\n crossChannelDegraded: result.degraded.length,\n },\n data: {\n crossChannelContext: {\n query: result.query,\n hits: [],\n unsupported: result.unsupported,\n degraded: result.degraded,\n },\n },\n };\n }\n\n return {\n text: renderCrossChannelContextJson({\n query: result.query,\n hits: injected,\n unsupported: result.unsupported,\n degraded: result.degraded,\n channelsWithHits: result.channelsWithHits,\n egressContext,\n }),\n values: {\n crossChannelHits: injected.length,\n crossChannelUnsupported: result.unsupported.length,\n crossChannelDegraded: result.degraded.length,\n crossChannelChannels: result.channelsWithHits,\n },\n data: {\n crossChannelContext: {\n query: result.query,\n hits: injected.map((hit) => compactHit(hit, egressContext)),\n unsupported: result.unsupported,\n degraded: result.degraded,\n resolvedPerson: result.resolvedPerson\n ? {\n primaryEntityId: result.resolvedPerson.primaryEntityId,\n displayName: result.resolvedPerson.displayName,\n }\n : null,\n },\n },\n };\n } catch (err) {\n logger.warn(\n `[crossChannelContext] Skipped injection after error: ${\n err instanceof Error ? err.message : String(err)\n }`,\n );\n return EMPTY;\n }\n },\n};\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `firstRunProvider` — surfaces the pending first-run affordance
|
|
3
|
+
* to the planner. Goes silent the moment first-run is `complete`.
|
|
4
|
+
*
|
|
5
|
+
* Affordance shape (frozen — `wave1-interfaces.md` §4.1):
|
|
6
|
+
* { kind: "first_run_pending",
|
|
7
|
+
* oneLine: "...", // ≤ 120 chars
|
|
8
|
+
* suggestedWorkflowKey: "first_run",
|
|
9
|
+
* paths: ["defaults", "customize"] }
|
|
10
|
+
*
|
|
11
|
+
* Position: `-10` so it lands ahead of most context — same convention as
|
|
12
|
+
* `enabled_skills`.
|
|
13
|
+
*/
|
|
14
|
+
import type { Provider } from "@elizaos/core";
|
|
15
|
+
export interface FirstRunAffordance {
|
|
16
|
+
kind: "first_run_pending";
|
|
17
|
+
oneLine: string;
|
|
18
|
+
suggestedWorkflowKey: "first_run";
|
|
19
|
+
paths: ("defaults" | "customize")[];
|
|
20
|
+
}
|
|
21
|
+
export declare const firstRunProvider: Provider;
|
|
22
|
+
//# sourceMappingURL=first-run.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"first-run.d.ts","sourceRoot":"","sources":["../../src/providers/first-run.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAGH,OAAO,KAAK,EAGV,QAAQ,EAGT,MAAM,eAAe,CAAC;AAIvB,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,mBAAmB,CAAC;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,oBAAoB,EAAE,WAAW,CAAC;IAClC,KAAK,EAAE,CAAC,UAAU,GAAG,WAAW,CAAC,EAAE,CAAC;CACrC;AAkDD,eAAO,MAAM,gBAAgB,EAAE,QAiE9B,CAAC"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { hasOwnerAccess } from "@elizaos/agent";
|
|
2
|
+
import { ChannelType, logger } from "@elizaos/core";
|
|
3
|
+
import { createFirstRunStateStore } from "../lifeops/first-run/state.js";
|
|
4
|
+
const QUIET_RESULT = {
|
|
5
|
+
text: "",
|
|
6
|
+
values: { firstRunPending: false },
|
|
7
|
+
data: {}
|
|
8
|
+
};
|
|
9
|
+
const ONE_LINE_MAX = 120;
|
|
10
|
+
const FIRST_RUN_REQUEST_RE = /\b(?:first[-\s]?run|first\s+run\s+setup|onboarding|initial\s+(?:setup|configuration)|setup\s+(?:this\s+)?(?:agent|bot|assistant)|configure\s+(?:this\s+)?(?:agent|bot|assistant)|use\s+defaults|customi[sz]e\s+(?:setup|first[-\s]?run))\b/iu;
|
|
11
|
+
function buildOneLine(inProgress, partialPath) {
|
|
12
|
+
if (inProgress) {
|
|
13
|
+
const where = partialPath === "customize" ? " (customize)" : "";
|
|
14
|
+
return `First-run setup is in progress${where}. Continue the first-run workflow.`.slice(
|
|
15
|
+
0,
|
|
16
|
+
ONE_LINE_MAX
|
|
17
|
+
);
|
|
18
|
+
}
|
|
19
|
+
return "First-run setup hasn't run yet. Ask whether to use defaults or customize.".slice(
|
|
20
|
+
0,
|
|
21
|
+
ONE_LINE_MAX
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
function isPrivateFirstRunSurface(message) {
|
|
25
|
+
const channelType = message.content.channelType;
|
|
26
|
+
return channelType === ChannelType.DM || channelType === ChannelType.VOICE_DM || channelType === ChannelType.SELF || channelType === ChannelType.API;
|
|
27
|
+
}
|
|
28
|
+
function explicitlyRequestsFirstRun(message) {
|
|
29
|
+
const text = typeof message.content.text === "string" ? message.content.text : "";
|
|
30
|
+
return FIRST_RUN_REQUEST_RE.test(text);
|
|
31
|
+
}
|
|
32
|
+
function shouldSurfaceFirstRun(message, inProgress) {
|
|
33
|
+
return inProgress || isPrivateFirstRunSurface(message) || explicitlyRequestsFirstRun(message);
|
|
34
|
+
}
|
|
35
|
+
const firstRunProvider = {
|
|
36
|
+
name: "firstRun",
|
|
37
|
+
description: "Surfaces a dynamic first-run setup affordance on a fresh boot. It does not expose a planner action and goes silent once first-run is complete.",
|
|
38
|
+
descriptionCompressed: "Pending first-run affordance; quiet after completion.",
|
|
39
|
+
dynamic: true,
|
|
40
|
+
// Run very early so the affordance reaches the planner before any
|
|
41
|
+
// capability provider can claim the turn.
|
|
42
|
+
position: -10,
|
|
43
|
+
cacheScope: "turn",
|
|
44
|
+
async get(runtime, message, _state) {
|
|
45
|
+
if (!await hasOwnerAccess(runtime, message)) {
|
|
46
|
+
return QUIET_RESULT;
|
|
47
|
+
}
|
|
48
|
+
let store;
|
|
49
|
+
try {
|
|
50
|
+
store = createFirstRunStateStore(runtime);
|
|
51
|
+
} catch (error) {
|
|
52
|
+
logger.debug(
|
|
53
|
+
"[first-run-provider] state store unavailable:",
|
|
54
|
+
String(error)
|
|
55
|
+
);
|
|
56
|
+
return QUIET_RESULT;
|
|
57
|
+
}
|
|
58
|
+
let record;
|
|
59
|
+
try {
|
|
60
|
+
record = await store.read();
|
|
61
|
+
} catch (error) {
|
|
62
|
+
logger.debug("[first-run-provider] state read failed:", String(error));
|
|
63
|
+
return QUIET_RESULT;
|
|
64
|
+
}
|
|
65
|
+
if (record.status === "complete") {
|
|
66
|
+
return QUIET_RESULT;
|
|
67
|
+
}
|
|
68
|
+
const inProgress = record.status === "in_progress";
|
|
69
|
+
if (!shouldSurfaceFirstRun(message, inProgress)) {
|
|
70
|
+
return QUIET_RESULT;
|
|
71
|
+
}
|
|
72
|
+
const oneLine = buildOneLine(inProgress, record.path);
|
|
73
|
+
const affordance = {
|
|
74
|
+
kind: "first_run_pending",
|
|
75
|
+
oneLine,
|
|
76
|
+
suggestedWorkflowKey: "first_run",
|
|
77
|
+
paths: ["defaults", "customize"]
|
|
78
|
+
};
|
|
79
|
+
return {
|
|
80
|
+
text: oneLine,
|
|
81
|
+
values: {
|
|
82
|
+
firstRunPending: true,
|
|
83
|
+
firstRunStatus: record.status,
|
|
84
|
+
firstRunPath: record.path ?? ""
|
|
85
|
+
},
|
|
86
|
+
data: { affordance }
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
export {
|
|
91
|
+
firstRunProvider
|
|
92
|
+
};
|
|
93
|
+
//# sourceMappingURL=first-run.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/providers/first-run.ts"],"sourcesContent":["/**\n * `firstRunProvider` — surfaces the pending first-run affordance\n * to the planner. Goes silent the moment first-run is `complete`.\n *\n * Affordance shape (frozen — `wave1-interfaces.md` §4.1):\n * { kind: \"first_run_pending\",\n * oneLine: \"...\", // ≤ 120 chars\n * suggestedWorkflowKey: \"first_run\",\n * paths: [\"defaults\", \"customize\"] }\n *\n * Position: `-10` so it lands ahead of most context — same convention as\n * `enabled_skills`.\n */\n\nimport { hasOwnerAccess } from \"@elizaos/agent\";\nimport type {\n IAgentRuntime,\n Memory,\n Provider,\n ProviderResult,\n State,\n} from \"@elizaos/core\";\nimport { ChannelType, logger } from \"@elizaos/core\";\nimport { createFirstRunStateStore } from \"../lifeops/first-run/state.js\";\n\nexport interface FirstRunAffordance {\n kind: \"first_run_pending\";\n oneLine: string;\n suggestedWorkflowKey: \"first_run\";\n paths: (\"defaults\" | \"customize\")[];\n}\n\nconst QUIET_RESULT: ProviderResult = {\n text: \"\",\n values: { firstRunPending: false },\n data: {},\n};\n\nconst ONE_LINE_MAX = 120;\nconst FIRST_RUN_REQUEST_RE =\n /\\b(?:first[-\\s]?run|first\\s+run\\s+setup|onboarding|initial\\s+(?:setup|configuration)|setup\\s+(?:this\\s+)?(?:agent|bot|assistant)|configure\\s+(?:this\\s+)?(?:agent|bot|assistant)|use\\s+defaults|customi[sz]e\\s+(?:setup|first[-\\s]?run))\\b/iu;\n\nfunction buildOneLine(inProgress: boolean, partialPath?: string): string {\n if (inProgress) {\n const where = partialPath === \"customize\" ? \" (customize)\" : \"\";\n return `First-run setup is in progress${where}. Continue the first-run workflow.`.slice(\n 0,\n ONE_LINE_MAX,\n );\n }\n return \"First-run setup hasn't run yet. Ask whether to use defaults or customize.\".slice(\n 0,\n ONE_LINE_MAX,\n );\n}\n\nfunction isPrivateFirstRunSurface(message: Memory): boolean {\n const channelType = message.content.channelType;\n return (\n channelType === ChannelType.DM ||\n channelType === ChannelType.VOICE_DM ||\n channelType === ChannelType.SELF ||\n channelType === ChannelType.API\n );\n}\n\nfunction explicitlyRequestsFirstRun(message: Memory): boolean {\n const text =\n typeof message.content.text === \"string\" ? message.content.text : \"\";\n return FIRST_RUN_REQUEST_RE.test(text);\n}\n\nfunction shouldSurfaceFirstRun(message: Memory, inProgress: boolean): boolean {\n return (\n inProgress ||\n isPrivateFirstRunSurface(message) ||\n explicitlyRequestsFirstRun(message)\n );\n}\n\nexport const firstRunProvider: Provider = {\n name: \"firstRun\",\n description:\n \"Surfaces a dynamic first-run setup affordance on a fresh boot. It does not expose a planner action and goes silent once first-run is complete.\",\n descriptionCompressed:\n \"Pending first-run affordance; quiet after completion.\",\n dynamic: true,\n // Run very early so the affordance reaches the planner before any\n // capability provider can claim the turn.\n position: -10,\n cacheScope: \"turn\",\n\n async get(\n runtime: IAgentRuntime,\n message: Memory,\n _state: State,\n ): Promise<ProviderResult> {\n if (!(await hasOwnerAccess(runtime, message))) {\n return QUIET_RESULT;\n }\n let store: ReturnType<typeof createFirstRunStateStore>;\n try {\n store = createFirstRunStateStore(runtime);\n } catch (error) {\n logger.debug(\n \"[first-run-provider] state store unavailable:\",\n String(error),\n );\n return QUIET_RESULT;\n }\n\n let record: Awaited<ReturnType<typeof store.read>>;\n try {\n record = await store.read();\n } catch (error) {\n logger.debug(\"[first-run-provider] state read failed:\", String(error));\n return QUIET_RESULT;\n }\n\n if (record.status === \"complete\") {\n return QUIET_RESULT;\n }\n\n const inProgress = record.status === \"in_progress\";\n if (!shouldSurfaceFirstRun(message, inProgress)) {\n return QUIET_RESULT;\n }\n\n const oneLine = buildOneLine(inProgress, record.path);\n const affordance: FirstRunAffordance = {\n kind: \"first_run_pending\",\n oneLine,\n suggestedWorkflowKey: \"first_run\",\n paths: [\"defaults\", \"customize\"],\n };\n return {\n text: oneLine,\n values: {\n firstRunPending: true,\n firstRunStatus: record.status,\n firstRunPath: record.path ?? \"\",\n },\n data: { affordance },\n };\n },\n};\n"],"mappings":"AAcA,SAAS,sBAAsB;AAQ/B,SAAS,aAAa,cAAc;AACpC,SAAS,gCAAgC;AASzC,MAAM,eAA+B;AAAA,EACnC,MAAM;AAAA,EACN,QAAQ,EAAE,iBAAiB,MAAM;AAAA,EACjC,MAAM,CAAC;AACT;AAEA,MAAM,eAAe;AACrB,MAAM,uBACJ;AAEF,SAAS,aAAa,YAAqB,aAA8B;AACvE,MAAI,YAAY;AACd,UAAM,QAAQ,gBAAgB,cAAc,iBAAiB;AAC7D,WAAO,iCAAiC,KAAK,qCAAqC;AAAA,MAChF;AAAA,MACA;AAAA,IACF;AAAA,EACF;AACA,SAAO,4EAA4E;AAAA,IACjF;AAAA,IACA;AAAA,EACF;AACF;AAEA,SAAS,yBAAyB,SAA0B;AAC1D,QAAM,cAAc,QAAQ,QAAQ;AACpC,SACE,gBAAgB,YAAY,MAC5B,gBAAgB,YAAY,YAC5B,gBAAgB,YAAY,QAC5B,gBAAgB,YAAY;AAEhC;AAEA,SAAS,2BAA2B,SAA0B;AAC5D,QAAM,OACJ,OAAO,QAAQ,QAAQ,SAAS,WAAW,QAAQ,QAAQ,OAAO;AACpE,SAAO,qBAAqB,KAAK,IAAI;AACvC;AAEA,SAAS,sBAAsB,SAAiB,YAA8B;AAC5E,SACE,cACA,yBAAyB,OAAO,KAChC,2BAA2B,OAAO;AAEtC;AAEO,MAAM,mBAA6B;AAAA,EACxC,MAAM;AAAA,EACN,aACE;AAAA,EACF,uBACE;AAAA,EACF,SAAS;AAAA;AAAA;AAAA,EAGT,UAAU;AAAA,EACV,YAAY;AAAA,EAEZ,MAAM,IACJ,SACA,SACA,QACyB;AACzB,QAAI,CAAE,MAAM,eAAe,SAAS,OAAO,GAAI;AAC7C,aAAO;AAAA,IACT;AACA,QAAI;AACJ,QAAI;AACF,cAAQ,yBAAyB,OAAO;AAAA,IAC1C,SAAS,OAAO;AACd,aAAO;AAAA,QACL;AAAA,QACA,OAAO,KAAK;AAAA,MACd;AACA,aAAO;AAAA,IACT;AAEA,QAAI;AACJ,QAAI;AACF,eAAS,MAAM,MAAM,KAAK;AAAA,IAC5B,SAAS,OAAO;AACd,aAAO,MAAM,2CAA2C,OAAO,KAAK,CAAC;AACrE,aAAO;AAAA,IACT;AAEA,QAAI,OAAO,WAAW,YAAY;AAChC,aAAO;AAAA,IACT;AAEA,UAAM,aAAa,OAAO,WAAW;AACrC,QAAI,CAAC,sBAAsB,SAAS,UAAU,GAAG;AAC/C,aAAO;AAAA,IACT;AAEA,UAAM,UAAU,aAAa,YAAY,OAAO,IAAI;AACpD,UAAM,aAAiC;AAAA,MACrC,MAAM;AAAA,MACN;AAAA,MACA,sBAAsB;AAAA,MACtB,OAAO,CAAC,YAAY,WAAW;AAAA,IACjC;AACA,WAAO;AAAA,MACL,MAAM;AAAA,MACN,QAAQ;AAAA,QACN,iBAAiB;AAAA,QACjB,gBAAgB,OAAO;AAAA,QACvB,cAAc,OAAO,QAAQ;AAAA,MAC/B;AAAA,MACA,MAAM,EAAE,WAAW;AAAA,IACrB;AAAA,EACF;AACF;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.d.ts","sourceRoot":"","sources":["../../src/providers/health.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,cAAc,kCAMzB,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createHealthProvider } from "@elizaos/plugin-health";
|
|
2
|
+
import { hasLifeOpsAccess } from "../lifeops/access.js";
|
|
3
|
+
import { LifeOpsService } from "../lifeops/service.js";
|
|
4
|
+
const healthProvider = createHealthProvider({
|
|
5
|
+
hasAccess: hasLifeOpsAccess,
|
|
6
|
+
getSummary: async (runtime, request) => {
|
|
7
|
+
const service = new LifeOpsService(runtime);
|
|
8
|
+
return service.getHealthSummary(request);
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
export {
|
|
12
|
+
healthProvider
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=health.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/providers/health.ts"],"sourcesContent":["import { createHealthProvider } from \"@elizaos/plugin-health\";\nimport { hasLifeOpsAccess } from \"../lifeops/access.js\";\nimport { LifeOpsService } from \"../lifeops/service.js\";\n\nexport const healthProvider = createHealthProvider({\n hasAccess: hasLifeOpsAccess,\n getSummary: async (runtime, request) => {\n const service = new LifeOpsService(runtime);\n return service.getHealthSummary(request);\n },\n});\n"],"mappings":"AAAA,SAAS,4BAA4B;AACrC,SAAS,wBAAwB;AACjC,SAAS,sBAAsB;AAExB,MAAM,iBAAiB,qBAAqB;AAAA,EACjD,WAAW;AAAA,EACX,YAAY,OAAO,SAAS,YAAY;AACtC,UAAM,UAAU,IAAI,eAAe,OAAO;AAC1C,WAAO,QAAQ,iBAAiB,OAAO;AAAA,EACzC;AACF,CAAC;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inbox-triage.d.ts","sourceRoot":"","sources":["../../src/providers/inbox-triage.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAGV,QAAQ,EAGT,MAAM,eAAe,CAAC;AAkBvB,eAAO,MAAM,mBAAmB,EAAE,QA6GjC,CAAC"}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import { hasOwnerAccess } from "@elizaos/agent";
|
|
2
|
+
import { logger } from "@elizaos/core";
|
|
3
|
+
import { InboxTriageRepository } from "../inbox/repository.js";
|
|
4
|
+
import {
|
|
5
|
+
canEgress,
|
|
6
|
+
createLifeOpsEgressContext,
|
|
7
|
+
redactTextForEgress,
|
|
8
|
+
redactUrlForEgress
|
|
9
|
+
} from "../lifeops/privacy-egress.js";
|
|
10
|
+
const EMPTY = {
|
|
11
|
+
text: "",
|
|
12
|
+
values: { inboxUnresolved: 0, inboxUrgent: 0 },
|
|
13
|
+
data: {}
|
|
14
|
+
};
|
|
15
|
+
const inboxTriageProvider = {
|
|
16
|
+
name: "inboxTriage",
|
|
17
|
+
description: "Injects pending inbox triage items into owner context. Shows urgent messages, items needing reply, and recent auto-replies across all channels including email. Use MESSAGE action=triage/list_inbox/search_inbox/respond/draft_reply/send_draft for cross-channel triage, digest, respond, Gmail search/read, and Gmail draft/send reply workflows. If the request is Gmail-only, MESSAGE should use source=gmail; if it is just 'my inbox', MESSAGE should use the cross-channel path.",
|
|
18
|
+
descriptionCompressed: "Pending inbox triage items across all channels incl email.",
|
|
19
|
+
dynamic: true,
|
|
20
|
+
position: 14,
|
|
21
|
+
// after lifeops (12), before escalation (15)
|
|
22
|
+
contexts: ["email", "messaging", "tasks"],
|
|
23
|
+
contextGate: { anyOf: ["email", "messaging", "tasks"] },
|
|
24
|
+
cacheScope: "turn",
|
|
25
|
+
roleGate: { minRole: "OWNER" },
|
|
26
|
+
async get(runtime, message, _state) {
|
|
27
|
+
if (!await hasOwnerAccess(runtime, message)) {
|
|
28
|
+
return EMPTY;
|
|
29
|
+
}
|
|
30
|
+
const egressContext = createLifeOpsEgressContext({
|
|
31
|
+
isOwner: true,
|
|
32
|
+
agentId: runtime.agentId,
|
|
33
|
+
entityId: message.entityId
|
|
34
|
+
});
|
|
35
|
+
let repo;
|
|
36
|
+
try {
|
|
37
|
+
repo = new InboxTriageRepository(runtime);
|
|
38
|
+
} catch {
|
|
39
|
+
return EMPTY;
|
|
40
|
+
}
|
|
41
|
+
let urgent;
|
|
42
|
+
let needsReply;
|
|
43
|
+
let recentAutoReplies;
|
|
44
|
+
try {
|
|
45
|
+
[urgent, needsReply, recentAutoReplies] = await Promise.all([
|
|
46
|
+
repo.getByClassification("urgent", { limit: 5 }),
|
|
47
|
+
repo.getByClassification("needs_reply", { limit: 10 }),
|
|
48
|
+
repo.getRecentAutoReplies(5)
|
|
49
|
+
]);
|
|
50
|
+
} catch (error) {
|
|
51
|
+
logger.debug(
|
|
52
|
+
"[inbox-triage-provider] DB query failed (schema may not exist yet):",
|
|
53
|
+
String(error)
|
|
54
|
+
);
|
|
55
|
+
return EMPTY;
|
|
56
|
+
}
|
|
57
|
+
const unresolved = urgent.length + needsReply.length;
|
|
58
|
+
if (unresolved === 0 && recentAutoReplies.length === 0) {
|
|
59
|
+
return EMPTY;
|
|
60
|
+
}
|
|
61
|
+
const lines = [`# Inbox: ${unresolved} items pending`];
|
|
62
|
+
if (urgent.length > 0) {
|
|
63
|
+
lines.push("\n## Urgent");
|
|
64
|
+
for (const item of urgent.slice(0, 3)) {
|
|
65
|
+
lines.push(formatEntry(item, egressContext));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
if (needsReply.length > 0) {
|
|
69
|
+
lines.push("\n## Needs Reply");
|
|
70
|
+
for (const item of needsReply.slice(0, 5)) {
|
|
71
|
+
lines.push(formatEntry(item, egressContext));
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
if (recentAutoReplies.length > 0) {
|
|
75
|
+
lines.push("\n## Recent Auto-Replies");
|
|
76
|
+
for (const item of recentAutoReplies) {
|
|
77
|
+
const draftPreview = canEgress(egressContext, "drafts") && item.draftResponse ? `"${item.draftResponse.slice(0, 60)}..."` : "(no draft)";
|
|
78
|
+
lines.push(`- Sent to ${item.channelName}: ${draftPreview}`);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
lines.push("\nSay 'respond to [name/channel]' to draft and send replies.");
|
|
82
|
+
return {
|
|
83
|
+
text: lines.join("\n"),
|
|
84
|
+
values: {
|
|
85
|
+
inboxUnresolved: unresolved,
|
|
86
|
+
inboxUrgent: urgent.length,
|
|
87
|
+
inboxNeedsReply: needsReply.length
|
|
88
|
+
},
|
|
89
|
+
data: {
|
|
90
|
+
urgentItems: urgent.map(
|
|
91
|
+
(entry) => filterTriageEntryForEgress(entry, egressContext)
|
|
92
|
+
),
|
|
93
|
+
needsReplyItems: needsReply.map(
|
|
94
|
+
(entry) => filterTriageEntryForEgress(entry, egressContext)
|
|
95
|
+
),
|
|
96
|
+
recentAutoReplies: recentAutoReplies.map(
|
|
97
|
+
(entry) => filterTriageEntryForEgress(entry, egressContext)
|
|
98
|
+
)
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
function formatEntry(entry, egressContext) {
|
|
104
|
+
const senderInfo = entry.senderName ? ` from ${entry.senderName}` : "";
|
|
105
|
+
const deepLink = redactUrlForEgress(entry.deepLink, {
|
|
106
|
+
context: egressContext
|
|
107
|
+
});
|
|
108
|
+
const link = deepLink ? `
|
|
109
|
+
${deepLink}` : "";
|
|
110
|
+
const snippet = redactTextForEgress(entry.snippet.slice(0, 80), {
|
|
111
|
+
context: egressContext,
|
|
112
|
+
dataClass: "snippet"
|
|
113
|
+
});
|
|
114
|
+
return `- **${entry.channelName}**${senderInfo} (${entry.source}): "${snippet}"` + link;
|
|
115
|
+
}
|
|
116
|
+
function filterTriageEntryForEgress(entry, egressContext) {
|
|
117
|
+
return {
|
|
118
|
+
...entry,
|
|
119
|
+
deepLink: redactUrlForEgress(entry.deepLink, {
|
|
120
|
+
context: egressContext
|
|
121
|
+
}),
|
|
122
|
+
snippet: redactTextForEgress(entry.snippet, {
|
|
123
|
+
context: egressContext,
|
|
124
|
+
dataClass: "snippet"
|
|
125
|
+
}),
|
|
126
|
+
threadContext: canEgress(egressContext, "body") ? entry.threadContext : null,
|
|
127
|
+
suggestedResponse: canEgress(egressContext, "drafts") ? entry.suggestedResponse : null,
|
|
128
|
+
draftResponse: canEgress(egressContext, "drafts") ? entry.draftResponse : null
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
export {
|
|
132
|
+
inboxTriageProvider
|
|
133
|
+
};
|
|
134
|
+
//# sourceMappingURL=inbox-triage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/providers/inbox-triage.ts"],"sourcesContent":["import { hasOwnerAccess } from \"@elizaos/agent\";\nimport type {\n IAgentRuntime,\n Memory,\n Provider,\n ProviderResult,\n State,\n} from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport { InboxTriageRepository } from \"../inbox/repository.js\";\nimport type { TriageEntry } from \"../inbox/types.js\";\nimport {\n canEgress,\n createLifeOpsEgressContext,\n type LifeOpsEgressContext,\n redactTextForEgress,\n redactUrlForEgress,\n} from \"../lifeops/privacy-egress.js\";\n\nconst EMPTY: ProviderResult = {\n text: \"\",\n values: { inboxUnresolved: 0, inboxUrgent: 0 },\n data: {},\n};\n\nexport const inboxTriageProvider: Provider = {\n name: \"inboxTriage\",\n description:\n \"Injects pending inbox triage items into owner context. Shows urgent messages, \" +\n \"items needing reply, and recent auto-replies across all channels including email. \" +\n \"Use MESSAGE action=triage/list_inbox/search_inbox/respond/draft_reply/send_draft for cross-channel triage, digest, respond, Gmail search/read, and Gmail draft/send reply workflows. \" +\n \"If the request is Gmail-only, MESSAGE should use source=gmail; if it is just 'my inbox', MESSAGE should use the cross-channel path.\",\n descriptionCompressed:\n \"Pending inbox triage items across all channels incl email.\",\n dynamic: true,\n position: 14, // after lifeops (12), before escalation (15)\n contexts: [\"email\", \"messaging\", \"tasks\"],\n contextGate: { anyOf: [\"email\", \"messaging\", \"tasks\"] },\n cacheScope: \"turn\",\n roleGate: { minRole: \"OWNER\" },\n\n async get(\n runtime: IAgentRuntime,\n message: Memory,\n _state: State,\n ): Promise<ProviderResult> {\n if (!(await hasOwnerAccess(runtime, message))) {\n return EMPTY;\n }\n const egressContext = createLifeOpsEgressContext({\n isOwner: true,\n agentId: runtime.agentId,\n entityId: message.entityId,\n });\n\n let repo: InboxTriageRepository;\n try {\n repo = new InboxTriageRepository(runtime);\n } catch {\n return EMPTY;\n }\n\n let urgent: TriageEntry[];\n let needsReply: TriageEntry[];\n let recentAutoReplies: TriageEntry[];\n\n try {\n [urgent, needsReply, recentAutoReplies] = await Promise.all([\n repo.getByClassification(\"urgent\", { limit: 5 }),\n repo.getByClassification(\"needs_reply\", { limit: 10 }),\n repo.getRecentAutoReplies(5),\n ]);\n } catch (error) {\n logger.debug(\n \"[inbox-triage-provider] DB query failed (schema may not exist yet):\",\n String(error),\n );\n return EMPTY;\n }\n\n const unresolved = urgent.length + needsReply.length;\n if (unresolved === 0 && recentAutoReplies.length === 0) {\n return EMPTY;\n }\n\n const lines: string[] = [`# Inbox: ${unresolved} items pending`];\n\n if (urgent.length > 0) {\n lines.push(\"\\n## Urgent\");\n for (const item of urgent.slice(0, 3)) {\n lines.push(formatEntry(item, egressContext));\n }\n }\n\n if (needsReply.length > 0) {\n lines.push(\"\\n## Needs Reply\");\n for (const item of needsReply.slice(0, 5)) {\n lines.push(formatEntry(item, egressContext));\n }\n }\n\n if (recentAutoReplies.length > 0) {\n lines.push(\"\\n## Recent Auto-Replies\");\n for (const item of recentAutoReplies) {\n const draftPreview =\n canEgress(egressContext, \"drafts\") && item.draftResponse\n ? `\"${item.draftResponse.slice(0, 60)}...\"`\n : \"(no draft)\";\n lines.push(`- Sent to ${item.channelName}: ${draftPreview}`);\n }\n }\n\n lines.push(\"\\nSay 'respond to [name/channel]' to draft and send replies.\");\n\n return {\n text: lines.join(\"\\n\"),\n values: {\n inboxUnresolved: unresolved,\n inboxUrgent: urgent.length,\n inboxNeedsReply: needsReply.length,\n },\n data: {\n urgentItems: urgent.map((entry) =>\n filterTriageEntryForEgress(entry, egressContext),\n ),\n needsReplyItems: needsReply.map((entry) =>\n filterTriageEntryForEgress(entry, egressContext),\n ),\n recentAutoReplies: recentAutoReplies.map((entry) =>\n filterTriageEntryForEgress(entry, egressContext),\n ),\n },\n };\n },\n};\n\nfunction formatEntry(\n entry: TriageEntry,\n egressContext: LifeOpsEgressContext,\n): string {\n const senderInfo = entry.senderName ? ` from ${entry.senderName}` : \"\";\n const deepLink = redactUrlForEgress(entry.deepLink, {\n context: egressContext,\n });\n const link = deepLink ? `\\n ${deepLink}` : \"\";\n const snippet = redactTextForEgress(entry.snippet.slice(0, 80), {\n context: egressContext,\n dataClass: \"snippet\",\n });\n return (\n `- **${entry.channelName}**${senderInfo} (${entry.source}): \"${snippet}\"` +\n link\n );\n}\n\nfunction filterTriageEntryForEgress(\n entry: TriageEntry,\n egressContext: LifeOpsEgressContext,\n): TriageEntry {\n return {\n ...entry,\n deepLink: redactUrlForEgress(entry.deepLink, {\n context: egressContext,\n }),\n snippet: redactTextForEgress(entry.snippet, {\n context: egressContext,\n dataClass: \"snippet\",\n }),\n threadContext: canEgress(egressContext, \"body\")\n ? entry.threadContext\n : null,\n suggestedResponse: canEgress(egressContext, \"drafts\")\n ? entry.suggestedResponse\n : null,\n draftResponse: canEgress(egressContext, \"drafts\")\n ? entry.draftResponse\n : null,\n };\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lifeops.d.ts","sourceRoot":"","sources":["../../src/providers/lifeops.ts"],"names":[],"mappings":"AAAA,OAAO,EAML,KAAK,QAAQ,EAGd,MAAM,eAAe,CAAC;AAoOvB,eAAO,MAAM,eAAe,EAAE,QAga7B,CAAC"}
|