@elizaos/plugin-personal-assistant 2.0.3-beta.5 → 2.0.3-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/app-block.d.ts +15 -0
- package/dist/actions/app-block.d.ts.map +1 -0
- package/dist/actions/app-block.js +349 -0
- package/dist/actions/app-block.js.map +1 -0
- package/dist/actions/autofill.d.ts +20 -0
- package/dist/actions/autofill.d.ts.map +1 -0
- package/dist/actions/autofill.js +370 -0
- package/dist/actions/autofill.js.map +1 -0
- package/dist/actions/block.d.ts +30 -0
- package/dist/actions/block.d.ts.map +1 -0
- package/dist/actions/block.js +326 -0
- package/dist/actions/block.js.map +1 -0
- package/dist/actions/book-travel.d.ts +10 -0
- package/dist/actions/book-travel.d.ts.map +1 -0
- package/dist/actions/book-travel.js +467 -0
- package/dist/actions/book-travel.js.map +1 -0
- package/dist/actions/brief.d.ts +60 -0
- package/dist/actions/brief.d.ts.map +1 -0
- package/dist/actions/brief.js +485 -0
- package/dist/actions/brief.js.map +1 -0
- package/dist/actions/calendar.d.ts +22 -0
- package/dist/actions/calendar.d.ts.map +1 -0
- package/dist/actions/calendar.js +832 -0
- package/dist/actions/calendar.js.map +1 -0
- package/dist/actions/conflict-detect.d.ts +67 -0
- package/dist/actions/conflict-detect.d.ts.map +1 -0
- package/dist/actions/conflict-detect.js +310 -0
- package/dist/actions/conflict-detect.js.map +1 -0
- package/dist/actions/connector.d.ts +5 -0
- package/dist/actions/connector.d.ts.map +1 -0
- package/dist/actions/connector.js +1354 -0
- package/dist/actions/connector.js.map +1 -0
- package/dist/actions/credentials.d.ts +14 -0
- package/dist/actions/credentials.d.ts.map +1 -0
- package/dist/actions/credentials.js +191 -0
- package/dist/actions/credentials.js.map +1 -0
- package/dist/actions/document.d.ts +36 -0
- package/dist/actions/document.d.ts.map +1 -0
- package/dist/actions/document.js +613 -0
- package/dist/actions/document.js.map +1 -0
- package/dist/actions/entity.d.ts +20 -0
- package/dist/actions/entity.d.ts.map +1 -0
- package/dist/actions/entity.js +785 -0
- package/dist/actions/entity.js.map +1 -0
- package/dist/actions/health.d.ts +4 -0
- package/dist/actions/health.d.ts.map +1 -0
- package/dist/actions/health.js +37 -0
- package/dist/actions/health.js.map +1 -0
- package/dist/actions/inbox.d.ts +12 -0
- package/dist/actions/inbox.d.ts.map +1 -0
- package/dist/actions/inbox.js +13 -0
- package/dist/actions/inbox.js.map +1 -0
- package/dist/actions/lib/calendly-handler.d.ts +3 -0
- package/dist/actions/lib/calendly-handler.d.ts.map +1 -0
- package/dist/actions/lib/calendly-handler.js +506 -0
- package/dist/actions/lib/calendly-handler.js.map +1 -0
- package/dist/actions/lib/extract-goal-plan.d.ts +69 -0
- package/dist/actions/lib/extract-goal-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-goal-plan.js +488 -0
- package/dist/actions/lib/extract-goal-plan.js.map +1 -0
- package/dist/actions/lib/extract-life-operation.d.ts +18 -0
- package/dist/actions/lib/extract-life-operation.d.ts.map +1 -0
- package/dist/actions/lib/extract-life-operation.js +318 -0
- package/dist/actions/lib/extract-life-operation.js.map +1 -0
- package/dist/actions/lib/extract-task-plan.d.ts +78 -0
- package/dist/actions/lib/extract-task-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-task-plan.js +355 -0
- package/dist/actions/lib/extract-task-plan.js.map +1 -0
- package/dist/actions/lib/extract-update-fields.d.ts +27 -0
- package/dist/actions/lib/extract-update-fields.d.ts.map +1 -0
- package/dist/actions/lib/extract-update-fields.js +172 -0
- package/dist/actions/lib/extract-update-fields.js.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts +68 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.js +315 -0
- package/dist/actions/lib/lifeops-deferred-draft.js.map +1 -0
- package/dist/actions/lib/messaging-helpers.d.ts +20 -0
- package/dist/actions/lib/messaging-helpers.d.ts.map +1 -0
- package/dist/actions/lib/messaging-helpers.js +103 -0
- package/dist/actions/lib/messaging-helpers.js.map +1 -0
- package/dist/actions/lib/owner-policy-writes.d.ts +49 -0
- package/dist/actions/lib/owner-policy-writes.d.ts.map +1 -0
- package/dist/actions/lib/owner-policy-writes.js +157 -0
- package/dist/actions/lib/owner-policy-writes.js.map +1 -0
- package/dist/actions/lib/prompt-format.d.ts +3 -0
- package/dist/actions/lib/prompt-format.d.ts.map +1 -0
- package/dist/actions/lib/prompt-format.js +42 -0
- package/dist/actions/lib/prompt-format.js.map +1 -0
- package/dist/actions/lib/scheduling-handler.d.ts +93 -0
- package/dist/actions/lib/scheduling-handler.d.ts.map +1 -0
- package/dist/actions/lib/scheduling-handler.js +868 -0
- package/dist/actions/lib/scheduling-handler.js.map +1 -0
- package/dist/actions/life.d.ts +13 -0
- package/dist/actions/life.d.ts.map +1 -0
- package/dist/actions/life.js +2524 -0
- package/dist/actions/life.js.map +1 -0
- package/dist/actions/money.d.ts +24 -0
- package/dist/actions/money.d.ts.map +1 -0
- package/dist/actions/money.js +41 -0
- package/dist/actions/money.js.map +1 -0
- package/dist/actions/owner-surfaces.d.ts +11 -0
- package/dist/actions/owner-surfaces.d.ts.map +1 -0
- package/dist/actions/owner-surfaces.js +493 -0
- package/dist/actions/owner-surfaces.js.map +1 -0
- package/dist/actions/password-manager.d.ts +10 -0
- package/dist/actions/password-manager.d.ts.map +1 -0
- package/dist/actions/password-manager.js +195 -0
- package/dist/actions/password-manager.js.map +1 -0
- package/dist/actions/payments.d.ts +10 -0
- package/dist/actions/payments.d.ts.map +1 -0
- package/dist/actions/payments.js +5 -0
- package/dist/actions/payments.js.map +1 -0
- package/dist/actions/prioritize.d.ts +49 -0
- package/dist/actions/prioritize.d.ts.map +1 -0
- package/dist/actions/prioritize.js +313 -0
- package/dist/actions/prioritize.js.map +1 -0
- package/dist/actions/remote-desktop.d.ts +13 -0
- package/dist/actions/remote-desktop.d.ts.map +1 -0
- package/dist/actions/remote-desktop.js +11 -0
- package/dist/actions/remote-desktop.js.map +1 -0
- package/dist/actions/resolve-request.d.ts +12 -0
- package/dist/actions/resolve-request.d.ts.map +1 -0
- package/dist/actions/resolve-request.js +427 -0
- package/dist/actions/resolve-request.js.map +1 -0
- package/dist/actions/schedule.d.ts +10 -0
- package/dist/actions/schedule.d.ts.map +1 -0
- package/dist/actions/schedule.js +113 -0
- package/dist/actions/schedule.js.map +1 -0
- package/dist/actions/scheduled-task.d.ts +32 -0
- package/dist/actions/scheduled-task.d.ts.map +1 -0
- package/dist/actions/scheduled-task.js +661 -0
- package/dist/actions/scheduled-task.js.map +1 -0
- package/dist/actions/screen-time.d.ts +4 -0
- package/dist/actions/screen-time.d.ts.map +1 -0
- package/dist/actions/screen-time.js +47 -0
- package/dist/actions/screen-time.js.map +1 -0
- package/dist/actions/subscriptions.d.ts +8 -0
- package/dist/actions/subscriptions.d.ts.map +1 -0
- package/dist/actions/subscriptions.js +327 -0
- package/dist/actions/subscriptions.js.map +1 -0
- package/dist/actions/voice-call.d.ts +16 -0
- package/dist/actions/voice-call.d.ts.map +1 -0
- package/dist/actions/voice-call.js +756 -0
- package/dist/actions/voice-call.js.map +1 -0
- package/dist/actions/website-block.d.ts +15 -0
- package/dist/actions/website-block.d.ts.map +1 -0
- package/dist/actions/website-block.js +719 -0
- package/dist/actions/website-block.js.map +1 -0
- package/dist/actions/work-thread.d.ts +5 -0
- package/dist/actions/work-thread.d.ts.map +1 -0
- package/dist/actions/work-thread.js +556 -0
- package/dist/actions/work-thread.js.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts +28 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.js +61 -0
- package/dist/activity-profile/activity-tracker-repo.js.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts +52 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.js +119 -0
- package/dist/activity-profile/activity-tracker-reporting.js.map +1 -0
- package/dist/activity-profile/activity-tracker-service.d.ts +36 -0
- package/dist/activity-profile/activity-tracker-service.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-service.js +187 -0
- package/dist/activity-profile/activity-tracker-service.js.map +1 -0
- package/dist/activity-profile/analyzer.d.ts +23 -0
- package/dist/activity-profile/analyzer.d.ts.map +1 -0
- package/dist/activity-profile/analyzer.js +485 -0
- package/dist/activity-profile/analyzer.js.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts +14 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.js +159 -0
- package/dist/activity-profile/presence-signal-bridge-service.js.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts +3 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.js +21 -0
- package/dist/activity-profile/proactive-inbox-digest.js.map +1 -0
- package/dist/activity-profile/proactive-planner.d.ts +150 -0
- package/dist/activity-profile/proactive-planner.d.ts.map +1 -0
- package/dist/activity-profile/proactive-planner.js +529 -0
- package/dist/activity-profile/proactive-planner.js.map +1 -0
- package/dist/activity-profile/proactive-worker.d.ts +33 -0
- package/dist/activity-profile/proactive-worker.d.ts.map +1 -0
- package/dist/activity-profile/proactive-worker.js +779 -0
- package/dist/activity-profile/proactive-worker.js.map +1 -0
- package/dist/activity-profile/profile-metadata.d.ts +10 -0
- package/dist/activity-profile/profile-metadata.d.ts.map +1 -0
- package/dist/activity-profile/profile-metadata.js +16 -0
- package/dist/activity-profile/profile-metadata.js.map +1 -0
- package/dist/activity-profile/redactor.d.ts +15 -0
- package/dist/activity-profile/redactor.d.ts.map +1 -0
- package/dist/activity-profile/redactor.js +22 -0
- package/dist/activity-profile/redactor.js.map +1 -0
- package/dist/activity-profile/service.d.ts +11 -0
- package/dist/activity-profile/service.d.ts.map +1 -0
- package/dist/activity-profile/service.js +272 -0
- package/dist/activity-profile/service.js.map +1 -0
- package/dist/activity-profile/types.d.ts +97 -0
- package/dist/activity-profile/types.d.ts.map +1 -0
- package/dist/activity-profile/types.js +36 -0
- package/dist/activity-profile/types.js.map +1 -0
- package/dist/agent-lifeops.d.ts +2 -0
- package/dist/agent-lifeops.d.ts.map +1 -0
- package/dist/agent-lifeops.js +2 -0
- package/dist/agent-lifeops.js.map +1 -0
- package/dist/api/client-lifeops.d.ts +319 -0
- package/dist/api/client-lifeops.d.ts.map +1 -0
- package/dist/api/client-lifeops.js +794 -0
- package/dist/api/client-lifeops.js.map +1 -0
- package/dist/automation-node-contributor.d.ts +2 -0
- package/dist/automation-node-contributor.d.ts.map +1 -0
- package/dist/automation-node-contributor.js +184 -0
- package/dist/automation-node-contributor.js.map +1 -0
- package/dist/client.d.ts +16 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +18 -0
- package/dist/client.js.map +1 -0
- package/dist/components/AppBlockerSettingsCard.d.ts +3 -0
- package/dist/components/AppBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/AppBlockerSettingsCard.js +538 -0
- package/dist/components/AppBlockerSettingsCard.js.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts +3 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.js +148 -0
- package/dist/components/WebsiteBlockerSettingsCard.js.map +1 -0
- package/dist/contracts/index.d.ts +2 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/index.js +2 -0
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/lifeops.d.ts +2 -0
- package/dist/contracts/lifeops.d.ts.map +1 -0
- package/dist/contracts/lifeops.js +2 -0
- package/dist/contracts/lifeops.js.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts +17 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.js +56 -0
- package/dist/default-packs/autofill-whitelist-pack.js.map +1 -0
- package/dist/default-packs/consolidation-policies.d.ts +14 -0
- package/dist/default-packs/consolidation-policies.d.ts.map +1 -0
- package/dist/default-packs/consolidation-policies.js +17 -0
- package/dist/default-packs/consolidation-policies.js.map +1 -0
- package/dist/default-packs/contract-types.d.ts +200 -0
- package/dist/default-packs/contract-types.d.ts.map +1 -0
- package/dist/default-packs/contract-types.js +1 -0
- package/dist/default-packs/contract-types.js.map +1 -0
- package/dist/default-packs/daily-rhythm.d.ts +28 -0
- package/dist/default-packs/daily-rhythm.d.ts.map +1 -0
- package/dist/default-packs/daily-rhythm.js +136 -0
- package/dist/default-packs/daily-rhythm.js.map +1 -0
- package/dist/default-packs/escalation-ladders.d.ts +18 -0
- package/dist/default-packs/escalation-ladders.d.ts.map +1 -0
- package/dist/default-packs/escalation-ladders.js +17 -0
- package/dist/default-packs/escalation-ladders.js.map +1 -0
- package/dist/default-packs/executive-assistant.d.ts +50 -0
- package/dist/default-packs/executive-assistant.d.ts.map +1 -0
- package/dist/default-packs/executive-assistant.js +745 -0
- package/dist/default-packs/executive-assistant.js.map +1 -0
- package/dist/default-packs/followup-starter.d.ts +49 -0
- package/dist/default-packs/followup-starter.d.ts.map +1 -0
- package/dist/default-packs/followup-starter.js +104 -0
- package/dist/default-packs/followup-starter.js.map +1 -0
- package/dist/default-packs/habit-starters.d.ts +37 -0
- package/dist/default-packs/habit-starters.d.ts.map +1 -0
- package/dist/default-packs/habit-starters.js +255 -0
- package/dist/default-packs/habit-starters.js.map +1 -0
- package/dist/default-packs/inbox-triage-starter.d.ts +23 -0
- package/dist/default-packs/inbox-triage-starter.d.ts.map +1 -0
- package/dist/default-packs/inbox-triage-starter.js +61 -0
- package/dist/default-packs/inbox-triage-starter.js.map +1 -0
- package/dist/default-packs/index.d.ts +54 -0
- package/dist/default-packs/index.d.ts.map +1 -0
- package/dist/default-packs/index.js +150 -0
- package/dist/default-packs/index.js.map +1 -0
- package/dist/default-packs/lint.d.ts +62 -0
- package/dist/default-packs/lint.d.ts.map +1 -0
- package/dist/default-packs/lint.js +161 -0
- package/dist/default-packs/lint.js.map +1 -0
- package/dist/default-packs/morning-brief.d.ts +44 -0
- package/dist/default-packs/morning-brief.d.ts.map +1 -0
- package/dist/default-packs/morning-brief.js +69 -0
- package/dist/default-packs/morning-brief.js.map +1 -0
- package/dist/default-packs/quiet-user-watcher.d.ts +49 -0
- package/dist/default-packs/quiet-user-watcher.d.ts.map +1 -0
- package/dist/default-packs/quiet-user-watcher.js +92 -0
- package/dist/default-packs/quiet-user-watcher.js.map +1 -0
- package/dist/default-packs/registry-types.d.ts +51 -0
- package/dist/default-packs/registry-types.d.ts.map +1 -0
- package/dist/default-packs/registry-types.js +1 -0
- package/dist/default-packs/registry-types.js.map +1 -0
- package/dist/default-packs/task-definitions.d.ts +88 -0
- package/dist/default-packs/task-definitions.d.ts.map +1 -0
- package/dist/default-packs/task-definitions.js +87 -0
- package/dist/default-packs/task-definitions.js.map +1 -0
- package/dist/events/index.d.ts +34 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +30 -0
- package/dist/events/index.js.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts +3 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.js +90 -0
- package/dist/followup/actions/listOverdueFollowups.js.map +1 -0
- package/dist/followup/actions/markFollowupDone.d.ts +3 -0
- package/dist/followup/actions/markFollowupDone.d.ts.map +1 -0
- package/dist/followup/actions/markFollowupDone.js +171 -0
- package/dist/followup/actions/markFollowupDone.js.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts +3 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.js +171 -0
- package/dist/followup/actions/setFollowupThreshold.js.map +1 -0
- package/dist/followup/followup-tracker.d.ts +83 -0
- package/dist/followup/followup-tracker.d.ts.map +1 -0
- package/dist/followup/followup-tracker.js +311 -0
- package/dist/followup/followup-tracker.js.map +1 -0
- package/dist/followup/index.d.ts +5 -0
- package/dist/followup/index.d.ts.map +1 -0
- package/dist/followup/index.js +39 -0
- package/dist/followup/index.js.map +1 -0
- package/dist/hooks/connector-error.d.ts +2 -0
- package/dist/hooks/connector-error.d.ts.map +1 -0
- package/dist/hooks/connector-error.js +13 -0
- package/dist/hooks/connector-error.js.map +1 -0
- package/dist/hooks/useDiscordConnector.d.ts +11 -0
- package/dist/hooks/useDiscordConnector.d.ts.map +1 -0
- package/dist/hooks/useDiscordConnector.js +95 -0
- package/dist/hooks/useDiscordConnector.js.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts +23 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js +630 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js.map +1 -0
- package/dist/hooks/useIMessageConnector.d.ts +10 -0
- package/dist/hooks/useIMessageConnector.d.ts.map +1 -0
- package/dist/hooks/useIMessageConnector.js +57 -0
- package/dist/hooks/useIMessageConnector.js.map +1 -0
- package/dist/hooks/useInbox.d.ts +36 -0
- package/dist/hooks/useInbox.d.ts.map +1 -0
- package/dist/hooks/useInbox.js +96 -0
- package/dist/hooks/useInbox.js.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts +2 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.js +358 -0
- package/dist/hooks/useLifeOpsActivitySignals.js.map +1 -0
- package/dist/hooks/useLifeOpsAppState.d.ts +9 -0
- package/dist/hooks/useLifeOpsAppState.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsAppState.js +79 -0
- package/dist/hooks/useLifeOpsAppState.js.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts +8 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js +60 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts +11 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.js +92 -0
- package/dist/hooks/useLifeOpsXConnector.js.map +1 -0
- package/dist/hooks/useSignalConnector.d.ts +14 -0
- package/dist/hooks/useSignalConnector.d.ts.map +1 -0
- package/dist/hooks/useSignalConnector.js +89 -0
- package/dist/hooks/useSignalConnector.js.map +1 -0
- package/dist/hooks/useTelegramConnector.d.ts +14 -0
- package/dist/hooks/useTelegramConnector.d.ts.map +1 -0
- package/dist/hooks/useTelegramConnector.js +97 -0
- package/dist/hooks/useTelegramConnector.js.map +1 -0
- package/dist/hooks/useWhatsAppConnector.d.ts +8 -0
- package/dist/hooks/useWhatsAppConnector.d.ts.map +1 -0
- package/dist/hooks/useWhatsAppConnector.js +62 -0
- package/dist/hooks/useWhatsAppConnector.js.map +1 -0
- package/dist/inbox/message-fetcher.d.ts +11 -0
- package/dist/inbox/message-fetcher.d.ts.map +1 -0
- package/dist/inbox/message-fetcher.js +13 -0
- package/dist/inbox/message-fetcher.js.map +1 -0
- package/dist/inbox/repository.d.ts +11 -0
- package/dist/inbox/repository.d.ts.map +1 -0
- package/dist/inbox/repository.js +5 -0
- package/dist/inbox/repository.js.map +1 -0
- package/dist/inbox/types.d.ts +10 -0
- package/dist/inbox/types.d.ts.map +1 -0
- package/dist/inbox/types.js +2 -0
- package/dist/inbox/types.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +188 -0
- package/dist/index.js.map +1 -0
- package/dist/lifeops/access.d.ts +29 -0
- package/dist/lifeops/access.d.ts.map +1 -0
- package/dist/lifeops/access.js +56 -0
- package/dist/lifeops/access.js.map +1 -0
- package/dist/lifeops/app-state.d.ts +22 -0
- package/dist/lifeops/app-state.d.ts.map +1 -0
- package/dist/lifeops/app-state.js +67 -0
- package/dist/lifeops/app-state.js.map +1 -0
- package/dist/lifeops/apple-reminders.d.ts +67 -0
- package/dist/lifeops/apple-reminders.d.ts.map +1 -0
- package/dist/lifeops/apple-reminders.js +396 -0
- package/dist/lifeops/apple-reminders.js.map +1 -0
- package/dist/lifeops/approval-queue.d.ts +38 -0
- package/dist/lifeops/approval-queue.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.js +575 -0
- package/dist/lifeops/approval-queue.js.map +1 -0
- package/dist/lifeops/approval-queue.types.d.ts +172 -0
- package/dist/lifeops/approval-queue.types.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.types.js +27 -0
- package/dist/lifeops/approval-queue.types.js.map +1 -0
- package/dist/lifeops/autofill-whitelist.d.ts +20 -0
- package/dist/lifeops/autofill-whitelist.d.ts.map +1 -0
- package/dist/lifeops/autofill-whitelist.js +59 -0
- package/dist/lifeops/autofill-whitelist.js.map +1 -0
- package/dist/lifeops/background-planner-dispatch.d.ts +60 -0
- package/dist/lifeops/background-planner-dispatch.d.ts.map +1 -0
- package/dist/lifeops/background-planner-dispatch.js +113 -0
- package/dist/lifeops/background-planner-dispatch.js.map +1 -0
- package/dist/lifeops/background-planner.d.ts +140 -0
- package/dist/lifeops/background-planner.d.ts.map +1 -0
- package/dist/lifeops/background-planner.js +359 -0
- package/dist/lifeops/background-planner.js.map +1 -0
- package/dist/lifeops/bill-extraction.d.ts +46 -0
- package/dist/lifeops/bill-extraction.d.ts.map +1 -0
- package/dist/lifeops/bill-extraction.js +325 -0
- package/dist/lifeops/bill-extraction.js.map +1 -0
- package/dist/lifeops/browser-constants.d.ts +4 -0
- package/dist/lifeops/browser-constants.d.ts.map +1 -0
- package/dist/lifeops/browser-constants.js +27 -0
- package/dist/lifeops/browser-constants.js.map +1 -0
- package/dist/lifeops/browser-extension-store.d.ts +61 -0
- package/dist/lifeops/browser-extension-store.d.ts.map +1 -0
- package/dist/lifeops/browser-extension-store.js +176 -0
- package/dist/lifeops/browser-extension-store.js.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts +57 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.js +308 -0
- package/dist/lifeops/browser-session-lifecycle.js.map +1 -0
- package/dist/lifeops/bulk-review.d.ts +333 -0
- package/dist/lifeops/bulk-review.d.ts.map +1 -0
- package/dist/lifeops/bulk-review.js +1120 -0
- package/dist/lifeops/bulk-review.js.map +1 -0
- package/dist/lifeops/calendar-gate.d.ts +20 -0
- package/dist/lifeops/calendar-gate.d.ts.map +1 -0
- package/dist/lifeops/calendar-gate.js +30 -0
- package/dist/lifeops/calendar-gate.js.map +1 -0
- package/dist/lifeops/channels/contract.d.ts +47 -0
- package/dist/lifeops/channels/contract.d.ts.map +1 -0
- package/dist/lifeops/channels/contract.js +1 -0
- package/dist/lifeops/channels/contract.js.map +1 -0
- package/dist/lifeops/channels/default-pack.d.ts +26 -0
- package/dist/lifeops/channels/default-pack.d.ts.map +1 -0
- package/dist/lifeops/channels/default-pack.js +243 -0
- package/dist/lifeops/channels/default-pack.js.map +1 -0
- package/dist/lifeops/channels/index.d.ts +5 -0
- package/dist/lifeops/channels/index.d.ts.map +1 -0
- package/dist/lifeops/channels/index.js +23 -0
- package/dist/lifeops/channels/index.js.map +1 -0
- package/dist/lifeops/channels/priority-posture.d.ts +36 -0
- package/dist/lifeops/channels/priority-posture.d.ts.map +1 -0
- package/dist/lifeops/channels/priority-posture.js +27 -0
- package/dist/lifeops/channels/priority-posture.js.map +1 -0
- package/dist/lifeops/channels/registry.d.ts +7 -0
- package/dist/lifeops/channels/registry.d.ts.map +1 -0
- package/dist/lifeops/channels/registry.js +49 -0
- package/dist/lifeops/channels/registry.js.map +1 -0
- package/dist/lifeops/checkin/checkin-service.d.ts +66 -0
- package/dist/lifeops/checkin/checkin-service.d.ts.map +1 -0
- package/dist/lifeops/checkin/checkin-service.js +1084 -0
- package/dist/lifeops/checkin/checkin-service.js.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts +17 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.js +26 -0
- package/dist/lifeops/checkin/schedule-resolver.js.map +1 -0
- package/dist/lifeops/checkin/types.d.ts +106 -0
- package/dist/lifeops/checkin/types.d.ts.map +1 -0
- package/dist/lifeops/checkin/types.js +1 -0
- package/dist/lifeops/checkin/types.js.map +1 -0
- package/dist/lifeops/connectors/_helpers.d.ts +51 -0
- package/dist/lifeops/connectors/_helpers.d.ts.map +1 -0
- package/dist/lifeops/connectors/_helpers.js +104 -0
- package/dist/lifeops/connectors/_helpers.js.map +1 -0
- package/dist/lifeops/connectors/calendly.d.ts +11 -0
- package/dist/lifeops/connectors/calendly.d.ts.map +1 -0
- package/dist/lifeops/connectors/calendly.js +61 -0
- package/dist/lifeops/connectors/calendly.js.map +1 -0
- package/dist/lifeops/connectors/contract.d.ts +88 -0
- package/dist/lifeops/connectors/contract.d.ts.map +1 -0
- package/dist/lifeops/connectors/contract.js +1 -0
- package/dist/lifeops/connectors/contract.js.map +1 -0
- package/dist/lifeops/connectors/default-pack.d.ts +35 -0
- package/dist/lifeops/connectors/default-pack.d.ts.map +1 -0
- package/dist/lifeops/connectors/default-pack.js +37 -0
- package/dist/lifeops/connectors/default-pack.js.map +1 -0
- package/dist/lifeops/connectors/discord.d.ts +8 -0
- package/dist/lifeops/connectors/discord.d.ts.map +1 -0
- package/dist/lifeops/connectors/discord.js +53 -0
- package/dist/lifeops/connectors/discord.js.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts +75 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.js +35 -0
- package/dist/lifeops/connectors/dispatch-policy.js.map +1 -0
- package/dist/lifeops/connectors/duffel.d.ts +11 -0
- package/dist/lifeops/connectors/duffel.d.ts.map +1 -0
- package/dist/lifeops/connectors/duffel.js +74 -0
- package/dist/lifeops/connectors/duffel.js.map +1 -0
- package/dist/lifeops/connectors/google.d.ts +27 -0
- package/dist/lifeops/connectors/google.d.ts.map +1 -0
- package/dist/lifeops/connectors/google.js +80 -0
- package/dist/lifeops/connectors/google.js.map +1 -0
- package/dist/lifeops/connectors/imessage.d.ts +11 -0
- package/dist/lifeops/connectors/imessage.d.ts.map +1 -0
- package/dist/lifeops/connectors/imessage.js +55 -0
- package/dist/lifeops/connectors/imessage.js.map +1 -0
- package/dist/lifeops/connectors/index.d.ts +5 -0
- package/dist/lifeops/connectors/index.d.ts.map +1 -0
- package/dist/lifeops/connectors/index.js +23 -0
- package/dist/lifeops/connectors/index.js.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts +54 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.js +71 -0
- package/dist/lifeops/connectors/mockoon-redirect.js.map +1 -0
- package/dist/lifeops/connectors/registry.d.ts +7 -0
- package/dist/lifeops/connectors/registry.d.ts.map +1 -0
- package/dist/lifeops/connectors/registry.js +55 -0
- package/dist/lifeops/connectors/registry.js.map +1 -0
- package/dist/lifeops/connectors/signal.d.ts +8 -0
- package/dist/lifeops/connectors/signal.d.ts.map +1 -0
- package/dist/lifeops/connectors/signal.js +60 -0
- package/dist/lifeops/connectors/signal.js.map +1 -0
- package/dist/lifeops/connectors/telegram.d.ts +12 -0
- package/dist/lifeops/connectors/telegram.d.ts.map +1 -0
- package/dist/lifeops/connectors/telegram.js +65 -0
- package/dist/lifeops/connectors/telegram.js.map +1 -0
- package/dist/lifeops/connectors/twilio.d.ts +15 -0
- package/dist/lifeops/connectors/twilio.d.ts.map +1 -0
- package/dist/lifeops/connectors/twilio.js +126 -0
- package/dist/lifeops/connectors/twilio.js.map +1 -0
- package/dist/lifeops/connectors/whatsapp.d.ts +10 -0
- package/dist/lifeops/connectors/whatsapp.d.ts.map +1 -0
- package/dist/lifeops/connectors/whatsapp.js +56 -0
- package/dist/lifeops/connectors/whatsapp.js.map +1 -0
- package/dist/lifeops/connectors/x.d.ts +8 -0
- package/dist/lifeops/connectors/x.d.ts.map +1 -0
- package/dist/lifeops/connectors/x.js +62 -0
- package/dist/lifeops/connectors/x.js.map +1 -0
- package/dist/lifeops/contact-route-policy.d.ts +27 -0
- package/dist/lifeops/contact-route-policy.d.ts.map +1 -0
- package/dist/lifeops/contact-route-policy.js +153 -0
- package/dist/lifeops/contact-route-policy.js.map +1 -0
- package/dist/lifeops/continuity-probe.d.ts +49 -0
- package/dist/lifeops/continuity-probe.d.ts.map +1 -0
- package/dist/lifeops/continuity-probe.js +161 -0
- package/dist/lifeops/continuity-probe.js.map +1 -0
- package/dist/lifeops/cross-channel-search.d.ts +108 -0
- package/dist/lifeops/cross-channel-search.d.ts.map +1 -0
- package/dist/lifeops/cross-channel-search.js +888 -0
- package/dist/lifeops/cross-channel-search.js.map +1 -0
- package/dist/lifeops/defaults.d.ts +30 -0
- package/dist/lifeops/defaults.d.ts.map +1 -0
- package/dist/lifeops/defaults.js +206 -0
- package/dist/lifeops/defaults.js.map +1 -0
- package/dist/lifeops/device-bus-service.d.ts +16 -0
- package/dist/lifeops/device-bus-service.d.ts.map +1 -0
- package/dist/lifeops/device-bus-service.js +20 -0
- package/dist/lifeops/device-bus-service.js.map +1 -0
- package/dist/lifeops/device-identity.d.ts +31 -0
- package/dist/lifeops/device-identity.d.ts.map +1 -0
- package/dist/lifeops/device-identity.js +94 -0
- package/dist/lifeops/device-identity.js.map +1 -0
- package/dist/lifeops/document-review.d.ts +264 -0
- package/dist/lifeops/document-review.d.ts.map +1 -0
- package/dist/lifeops/document-review.js +925 -0
- package/dist/lifeops/document-review.js.map +1 -0
- package/dist/lifeops/email-classifier.d.ts +9 -0
- package/dist/lifeops/email-classifier.d.ts.map +1 -0
- package/dist/lifeops/email-classifier.js +15 -0
- package/dist/lifeops/email-classifier.js.map +1 -0
- package/dist/lifeops/email-curation.d.ts +13 -0
- package/dist/lifeops/email-curation.d.ts.map +1 -0
- package/dist/lifeops/email-curation.js +2 -0
- package/dist/lifeops/email-curation.js.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts +7 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.js +1 -0
- package/dist/lifeops/email-unsubscribe-types.js.map +1 -0
- package/dist/lifeops/enforcement-windows.d.ts +34 -0
- package/dist/lifeops/enforcement-windows.d.ts.map +1 -0
- package/dist/lifeops/enforcement-windows.js +80 -0
- package/dist/lifeops/enforcement-windows.js.map +1 -0
- package/dist/lifeops/engine.d.ts +8 -0
- package/dist/lifeops/engine.d.ts.map +1 -0
- package/dist/lifeops/engine.js +540 -0
- package/dist/lifeops/engine.js.map +1 -0
- package/dist/lifeops/entities/index.d.ts +4 -0
- package/dist/lifeops/entities/index.d.ts.map +1 -0
- package/dist/lifeops/entities/index.js +29 -0
- package/dist/lifeops/entities/index.js.map +1 -0
- package/dist/lifeops/entities/merge.d.ts +9 -0
- package/dist/lifeops/entities/merge.d.ts.map +1 -0
- package/dist/lifeops/entities/merge.js +17 -0
- package/dist/lifeops/entities/merge.js.map +1 -0
- package/dist/lifeops/entities/store.d.ts +13 -0
- package/dist/lifeops/entities/store.d.ts.map +1 -0
- package/dist/lifeops/entities/store.js +7 -0
- package/dist/lifeops/entities/store.js.map +1 -0
- package/dist/lifeops/entities/types.d.ts +9 -0
- package/dist/lifeops/entities/types.d.ts.map +1 -0
- package/dist/lifeops/entities/types.js +13 -0
- package/dist/lifeops/entities/types.js.map +1 -0
- package/dist/lifeops/entities/voice-attribution.d.ts +70 -0
- package/dist/lifeops/entities/voice-attribution.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-attribution.js +121 -0
- package/dist/lifeops/entities/voice-attribution.js.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts +32 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.js +68 -0
- package/dist/lifeops/entities/voice-observer-bridge.js.map +1 -0
- package/dist/lifeops/entities/voice-observer.d.ts +72 -0
- package/dist/lifeops/entities/voice-observer.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer.js +97 -0
- package/dist/lifeops/entities/voice-observer.js.map +1 -0
- package/dist/lifeops/escalation-ladders.d.ts +28 -0
- package/dist/lifeops/escalation-ladders.d.ts.map +1 -0
- package/dist/lifeops/escalation-ladders.js +17 -0
- package/dist/lifeops/escalation-ladders.js.map +1 -0
- package/dist/lifeops/fda-probe.d.ts +23 -0
- package/dist/lifeops/fda-probe.d.ts.map +1 -0
- package/dist/lifeops/fda-probe.js +59 -0
- package/dist/lifeops/fda-probe.js.map +1 -0
- package/dist/lifeops/feature-flags.d.ts +24 -0
- package/dist/lifeops/feature-flags.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.js +261 -0
- package/dist/lifeops/feature-flags.js.map +1 -0
- package/dist/lifeops/feature-flags.types.d.ts +156 -0
- package/dist/lifeops/feature-flags.types.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.types.js +129 -0
- package/dist/lifeops/feature-flags.types.js.map +1 -0
- package/dist/lifeops/first-run/defaults.d.ts +57 -0
- package/dist/lifeops/first-run/defaults.d.ts.map +1 -0
- package/dist/lifeops/first-run/defaults.js +159 -0
- package/dist/lifeops/first-run/defaults.js.map +1 -0
- package/dist/lifeops/first-run/questions.d.ts +74 -0
- package/dist/lifeops/first-run/questions.d.ts.map +1 -0
- package/dist/lifeops/first-run/questions.js +184 -0
- package/dist/lifeops/first-run/questions.js.map +1 -0
- package/dist/lifeops/first-run/replay.d.ts +41 -0
- package/dist/lifeops/first-run/replay.d.ts.map +1 -0
- package/dist/lifeops/first-run/replay.js +34 -0
- package/dist/lifeops/first-run/replay.js.map +1 -0
- package/dist/lifeops/first-run/service.d.ts +147 -0
- package/dist/lifeops/first-run/service.d.ts.map +1 -0
- package/dist/lifeops/first-run/service.js +455 -0
- package/dist/lifeops/first-run/service.js.map +1 -0
- package/dist/lifeops/first-run/state.d.ts +36 -0
- package/dist/lifeops/first-run/state.d.ts.map +1 -0
- package/dist/lifeops/first-run/state.js +128 -0
- package/dist/lifeops/first-run/state.js.map +1 -0
- package/dist/lifeops/global-pause/store.d.ts +22 -0
- package/dist/lifeops/global-pause/store.d.ts.map +1 -0
- package/dist/lifeops/global-pause/store.js +18 -0
- package/dist/lifeops/global-pause/store.js.map +1 -0
- package/dist/lifeops/goal-grounding.d.ts +9 -0
- package/dist/lifeops/goal-grounding.d.ts.map +1 -0
- package/dist/lifeops/goal-grounding.js +19 -0
- package/dist/lifeops/goal-grounding.js.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts +8 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.js +7 -0
- package/dist/lifeops/goal-semantic-evaluator.js.map +1 -0
- package/dist/lifeops/google/format-helpers.d.ts +63 -0
- package/dist/lifeops/google/format-helpers.d.ts.map +1 -0
- package/dist/lifeops/google/format-helpers.js +597 -0
- package/dist/lifeops/google/format-helpers.js.map +1 -0
- package/dist/lifeops/google-plugin-delegates.d.ts +59 -0
- package/dist/lifeops/google-plugin-delegates.d.ts.map +1 -0
- package/dist/lifeops/google-plugin-delegates.js +408 -0
- package/dist/lifeops/google-plugin-delegates.js.map +1 -0
- package/dist/lifeops/google-scopes.d.ts +15 -0
- package/dist/lifeops/google-scopes.d.ts.map +1 -0
- package/dist/lifeops/google-scopes.js +118 -0
- package/dist/lifeops/google-scopes.js.map +1 -0
- package/dist/lifeops/handoff/store.d.ts +23 -0
- package/dist/lifeops/handoff/store.d.ts.map +1 -0
- package/dist/lifeops/handoff/store.js +20 -0
- package/dist/lifeops/handoff/store.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts +16 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.js +33 -0
- package/dist/lifeops/i18n/localized-examples-provider.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts +32 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js +28 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts +64 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.js +283 -0
- package/dist/lifeops/i18n/prompt-registry.js.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts +7 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.js +81 -0
- package/dist/lifeops/imessage-outbound-probe.js.map +1 -0
- package/dist/lifeops/index.d.ts +24 -0
- package/dist/lifeops/index.d.ts.map +1 -0
- package/dist/lifeops/index.js +24 -0
- package/dist/lifeops/index.js.map +1 -0
- package/dist/lifeops/intent-sync.d.ts +64 -0
- package/dist/lifeops/intent-sync.d.ts.map +1 -0
- package/dist/lifeops/intent-sync.js +321 -0
- package/dist/lifeops/intent-sync.js.map +1 -0
- package/dist/lifeops/messaging/index.d.ts +2 -0
- package/dist/lifeops/messaging/index.d.ts.map +1 -0
- package/dist/lifeops/messaging/index.js +5 -0
- package/dist/lifeops/messaging/index.js.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts +3 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.js +83 -0
- package/dist/lifeops/messaging/owner-send-policy.js.map +1 -0
- package/dist/lifeops/notifications-push.d.ts +37 -0
- package/dist/lifeops/notifications-push.d.ts.map +1 -0
- package/dist/lifeops/notifications-push.js +95 -0
- package/dist/lifeops/notifications-push.js.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts +5 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.js +48 -0
- package/dist/lifeops/optimized-prompt-instructions.js.map +1 -0
- package/dist/lifeops/owner/fact-store.d.ts +143 -0
- package/dist/lifeops/owner/fact-store.d.ts.map +1 -0
- package/dist/lifeops/owner/fact-store.js +446 -0
- package/dist/lifeops/owner/fact-store.js.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts +3 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js +241 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js.map +1 -0
- package/dist/lifeops/owner-profile.d.ts +61 -0
- package/dist/lifeops/owner-profile.d.ts.map +1 -0
- package/dist/lifeops/owner-profile.js +407 -0
- package/dist/lifeops/owner-profile.js.map +1 -0
- package/dist/lifeops/pending-prompts/store.d.ts +23 -0
- package/dist/lifeops/pending-prompts/store.d.ts.map +1 -0
- package/dist/lifeops/pending-prompts/store.js +16 -0
- package/dist/lifeops/pending-prompts/store.js.map +1 -0
- package/dist/lifeops/policy-memory.d.ts +190 -0
- package/dist/lifeops/policy-memory.d.ts.map +1 -0
- package/dist/lifeops/policy-memory.js +1026 -0
- package/dist/lifeops/policy-memory.js.map +1 -0
- package/dist/lifeops/priority-scoring.d.ts +51 -0
- package/dist/lifeops/priority-scoring.d.ts.map +1 -0
- package/dist/lifeops/priority-scoring.js +305 -0
- package/dist/lifeops/priority-scoring.js.map +1 -0
- package/dist/lifeops/privacy-egress.d.ts +92 -0
- package/dist/lifeops/privacy-egress.d.ts.map +1 -0
- package/dist/lifeops/privacy-egress.js +230 -0
- package/dist/lifeops/privacy-egress.js.map +1 -0
- package/dist/lifeops/privacy.d.ts +49 -0
- package/dist/lifeops/privacy.d.ts.map +1 -0
- package/dist/lifeops/privacy.js +66 -0
- package/dist/lifeops/privacy.js.map +1 -0
- package/dist/lifeops/redact-sensitive-data.d.ts +32 -0
- package/dist/lifeops/redact-sensitive-data.d.ts.map +1 -0
- package/dist/lifeops/redact-sensitive-data.js +98 -0
- package/dist/lifeops/redact-sensitive-data.js.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts +13 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.js +73 -0
- package/dist/lifeops/registries/app-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/blocker-registry.d.ts +76 -0
- package/dist/lifeops/registries/blocker-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/blocker-registry.js +40 -0
- package/dist/lifeops/registries/blocker-registry.js.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts +57 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.js +82 -0
- package/dist/lifeops/registries/event-kind-registry.js.map +1 -0
- package/dist/lifeops/registries/family-registry.d.ts +72 -0
- package/dist/lifeops/registries/family-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/family-registry.js +98 -0
- package/dist/lifeops/registries/family-registry.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts +32 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js +36 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts +76 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.js +68 -0
- package/dist/lifeops/registries/feature-flag-registry.js.map +1 -0
- package/dist/lifeops/registries/index.d.ts +24 -0
- package/dist/lifeops/registries/index.d.ts.map +1 -0
- package/dist/lifeops/registries/index.js +115 -0
- package/dist/lifeops/registries/index.js.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts +21 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.js +76 -0
- package/dist/lifeops/registries/website-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts +30 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js +315 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts +101 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.js +56 -0
- package/dist/lifeops/registries/workflow-step-registry.js.map +1 -0
- package/dist/lifeops/relationships/extraction.d.ts +77 -0
- package/dist/lifeops/relationships/extraction.d.ts.map +1 -0
- package/dist/lifeops/relationships/extraction.js +146 -0
- package/dist/lifeops/relationships/extraction.js.map +1 -0
- package/dist/lifeops/relationships/index.d.ts +4 -0
- package/dist/lifeops/relationships/index.d.ts.map +1 -0
- package/dist/lifeops/relationships/index.js +19 -0
- package/dist/lifeops/relationships/index.js.map +1 -0
- package/dist/lifeops/relationships/mapping.d.ts +34 -0
- package/dist/lifeops/relationships/mapping.d.ts.map +1 -0
- package/dist/lifeops/relationships/mapping.js +87 -0
- package/dist/lifeops/relationships/mapping.js.map +1 -0
- package/dist/lifeops/relationships/store.d.ts +12 -0
- package/dist/lifeops/relationships/store.d.ts.map +1 -0
- package/dist/lifeops/relationships/store.js +5 -0
- package/dist/lifeops/relationships/store.js.map +1 -0
- package/dist/lifeops/relationships/types.d.ts +9 -0
- package/dist/lifeops/relationships/types.d.ts.map +1 -0
- package/dist/lifeops/relationships/types.js +11 -0
- package/dist/lifeops/relationships/types.js.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts +13 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.js +107 -0
- package/dist/lifeops/relative-schedule-resolver.js.map +1 -0
- package/dist/lifeops/relative-time.d.ts +15 -0
- package/dist/lifeops/relative-time.d.ts.map +1 -0
- package/dist/lifeops/relative-time.js +191 -0
- package/dist/lifeops/relative-time.js.map +1 -0
- package/dist/lifeops/repository.d.ts +638 -0
- package/dist/lifeops/repository.d.ts.map +1 -0
- package/dist/lifeops/repository.js +6289 -0
- package/dist/lifeops/repository.js.map +1 -0
- package/dist/lifeops/runtime-cache.d.ts +4 -0
- package/dist/lifeops/runtime-cache.d.ts.map +1 -0
- package/dist/lifeops/runtime-cache.js +7 -0
- package/dist/lifeops/runtime-cache.js.map +1 -0
- package/dist/lifeops/runtime-service-delegates.d.ts +236 -0
- package/dist/lifeops/runtime-service-delegates.d.ts.map +1 -0
- package/dist/lifeops/runtime-service-delegates.js +839 -0
- package/dist/lifeops/runtime-service-delegates.js.map +1 -0
- package/dist/lifeops/runtime.d.ts +13 -0
- package/dist/lifeops/runtime.d.ts.map +1 -0
- package/dist/lifeops/runtime.js +104 -0
- package/dist/lifeops/runtime.js.map +1 -0
- package/dist/lifeops/schedule-insight.d.ts +133 -0
- package/dist/lifeops/schedule-insight.d.ts.map +1 -0
- package/dist/lifeops/schedule-insight.js +726 -0
- package/dist/lifeops/schedule-insight.js.map +1 -0
- package/dist/lifeops/schedule-state.d.ts +39 -0
- package/dist/lifeops/schedule-state.d.ts.map +1 -0
- package/dist/lifeops/schedule-state.js +671 -0
- package/dist/lifeops/schedule-state.js.map +1 -0
- package/dist/lifeops/schedule-sync-config.d.ts +3 -0
- package/dist/lifeops/schedule-sync-config.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-config.js +23 -0
- package/dist/lifeops/schedule-sync-config.js.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts +2 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.js +2 -0
- package/dist/lifeops/schedule-sync-contracts.js.map +1 -0
- package/dist/lifeops/scheduled-task/index.d.ts +13 -0
- package/dist/lifeops/scheduled-task/index.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/index.js +14 -0
- package/dist/lifeops/scheduled-task/index.js.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts +33 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js +334 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts +28 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.js +202 -0
- package/dist/lifeops/scheduled-task/scheduler.js.map +1 -0
- package/dist/lifeops/scheduled-task/service.d.ts +61 -0
- package/dist/lifeops/scheduled-task/service.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/service.js +64 -0
- package/dist/lifeops/scheduled-task/service.js.map +1 -0
- package/dist/lifeops/scheduler-task.d.ts +19 -0
- package/dist/lifeops/scheduler-task.d.ts.map +1 -0
- package/dist/lifeops/scheduler-task.js +201 -0
- package/dist/lifeops/scheduler-task.js.map +1 -0
- package/dist/lifeops/schema.d.ts +28068 -0
- package/dist/lifeops/schema.d.ts.map +1 -0
- package/dist/lifeops/schema.js +1689 -0
- package/dist/lifeops/schema.js.map +1 -0
- package/dist/lifeops/screen-context.d.ts +66 -0
- package/dist/lifeops/screen-context.d.ts.map +1 -0
- package/dist/lifeops/screen-context.js +347 -0
- package/dist/lifeops/screen-context.js.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts +113 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.js +142 -0
- package/dist/lifeops/seed-routine-migration/migrator.js.map +1 -0
- package/dist/lifeops/seed-routines.d.ts +24 -0
- package/dist/lifeops/seed-routines.d.ts.map +1 -0
- package/dist/lifeops/seed-routines.js +140 -0
- package/dist/lifeops/seed-routines.js.map +1 -0
- package/dist/lifeops/send-policy/contract.d.ts +81 -0
- package/dist/lifeops/send-policy/contract.d.ts.map +1 -0
- package/dist/lifeops/send-policy/contract.js +1 -0
- package/dist/lifeops/send-policy/contract.js.map +1 -0
- package/dist/lifeops/send-policy/index.d.ts +3 -0
- package/dist/lifeops/send-policy/index.d.ts.map +1 -0
- package/dist/lifeops/send-policy/index.js +13 -0
- package/dist/lifeops/send-policy/index.js.map +1 -0
- package/dist/lifeops/send-policy/registry.d.ts +7 -0
- package/dist/lifeops/send-policy/registry.d.ts.map +1 -0
- package/dist/lifeops/send-policy/registry.js +62 -0
- package/dist/lifeops/send-policy/registry.js.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts +46 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.js +103 -0
- package/dist/lifeops/sensitive-request-delivery.js.map +1 -0
- package/dist/lifeops/service-constants.d.ts +10 -0
- package/dist/lifeops/service-constants.d.ts.map +1 -0
- package/dist/lifeops/service-constants.js +129 -0
- package/dist/lifeops/service-constants.js.map +1 -0
- package/dist/lifeops/service-helpers-browser.d.ts +41 -0
- package/dist/lifeops/service-helpers-browser.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-browser.js +290 -0
- package/dist/lifeops/service-helpers-browser.js.map +1 -0
- package/dist/lifeops/service-helpers-misc.d.ts +68 -0
- package/dist/lifeops/service-helpers-misc.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-misc.js +531 -0
- package/dist/lifeops/service-helpers-misc.js.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts +23 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.js +257 -0
- package/dist/lifeops/service-helpers-occurrence.js.map +1 -0
- package/dist/lifeops/service-helpers-reminder.d.ts +260 -0
- package/dist/lifeops/service-helpers-reminder.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-reminder.js +1186 -0
- package/dist/lifeops/service-helpers-reminder.js.map +1 -0
- package/dist/lifeops/service-mixin-browser.d.ts +31 -0
- package/dist/lifeops/service-mixin-browser.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-browser.js +975 -0
- package/dist/lifeops/service-mixin-browser.js.map +1 -0
- package/dist/lifeops/service-mixin-calendar.d.ts +53 -0
- package/dist/lifeops/service-mixin-calendar.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-calendar.js +68 -0
- package/dist/lifeops/service-mixin-calendar.js.map +1 -0
- package/dist/lifeops/service-mixin-core.d.ts +51 -0
- package/dist/lifeops/service-mixin-core.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-core.js +500 -0
- package/dist/lifeops/service-mixin-core.js.map +1 -0
- package/dist/lifeops/service-mixin-definitions.d.ts +14 -0
- package/dist/lifeops/service-mixin-definitions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-definitions.js +470 -0
- package/dist/lifeops/service-mixin-definitions.js.map +1 -0
- package/dist/lifeops/service-mixin-discord.d.ts +49 -0
- package/dist/lifeops/service-mixin-discord.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-discord.js +1253 -0
- package/dist/lifeops/service-mixin-discord.js.map +1 -0
- package/dist/lifeops/service-mixin-drive.d.ts +96 -0
- package/dist/lifeops/service-mixin-drive.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-drive.js +213 -0
- package/dist/lifeops/service-mixin-drive.js.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts +23 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js +27 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js.map +1 -0
- package/dist/lifeops/service-mixin-gmail.d.ts +43 -0
- package/dist/lifeops/service-mixin-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-gmail.js +727 -0
- package/dist/lifeops/service-mixin-gmail.js.map +1 -0
- package/dist/lifeops/service-mixin-goals.d.ts +22 -0
- package/dist/lifeops/service-mixin-goals.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-goals.js +884 -0
- package/dist/lifeops/service-mixin-goals.js.map +1 -0
- package/dist/lifeops/service-mixin-google.d.ts +13 -0
- package/dist/lifeops/service-mixin-google.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-google.js +398 -0
- package/dist/lifeops/service-mixin-google.js.map +1 -0
- package/dist/lifeops/service-mixin-health.d.ts +27 -0
- package/dist/lifeops/service-mixin-health.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-health.js +670 -0
- package/dist/lifeops/service-mixin-health.js.map +1 -0
- package/dist/lifeops/service-mixin-imessage.d.ts +106 -0
- package/dist/lifeops/service-mixin-imessage.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-imessage.js +303 -0
- package/dist/lifeops/service-mixin-imessage.js.map +1 -0
- package/dist/lifeops/service-mixin-inbox.d.ts +55 -0
- package/dist/lifeops/service-mixin-inbox.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-inbox.js +597 -0
- package/dist/lifeops/service-mixin-inbox.js.map +1 -0
- package/dist/lifeops/service-mixin-relationships.d.ts +65 -0
- package/dist/lifeops/service-mixin-relationships.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-relationships.js +150 -0
- package/dist/lifeops/service-mixin-relationships.js.map +1 -0
- package/dist/lifeops/service-mixin-reminders.d.ts +62 -0
- package/dist/lifeops/service-mixin-reminders.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-reminders.js +4003 -0
- package/dist/lifeops/service-mixin-reminders.js.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts +53 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.js +405 -0
- package/dist/lifeops/service-mixin-scheduling.js.map +1 -0
- package/dist/lifeops/service-mixin-screentime.d.ts +71 -0
- package/dist/lifeops/service-mixin-screentime.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-screentime.js +530 -0
- package/dist/lifeops/service-mixin-screentime.js.map +1 -0
- package/dist/lifeops/service-mixin-signal.d.ts +74 -0
- package/dist/lifeops/service-mixin-signal.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-signal.js +214 -0
- package/dist/lifeops/service-mixin-signal.js.map +1 -0
- package/dist/lifeops/service-mixin-sleep.d.ts +68 -0
- package/dist/lifeops/service-mixin-sleep.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-sleep.js +43 -0
- package/dist/lifeops/service-mixin-sleep.js.map +1 -0
- package/dist/lifeops/service-mixin-status.d.ts +31 -0
- package/dist/lifeops/service-mixin-status.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-status.js +373 -0
- package/dist/lifeops/service-mixin-status.js.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts +101 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.js +50 -0
- package/dist/lifeops/service-mixin-subscriptions.js.map +1 -0
- package/dist/lifeops/service-mixin-telegram.d.ts +104 -0
- package/dist/lifeops/service-mixin-telegram.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-telegram.js +280 -0
- package/dist/lifeops/service-mixin-telegram.js.map +1 -0
- package/dist/lifeops/service-mixin-travel.d.ts +66 -0
- package/dist/lifeops/service-mixin-travel.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-travel.js +275 -0
- package/dist/lifeops/service-mixin-travel.js.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts +96 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.js +186 -0
- package/dist/lifeops/service-mixin-whatsapp.js.map +1 -0
- package/dist/lifeops/service-mixin-workflows.d.ts +15 -0
- package/dist/lifeops/service-mixin-workflows.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-workflows.js +710 -0
- package/dist/lifeops/service-mixin-workflows.js.map +1 -0
- package/dist/lifeops/service-mixin-x-read.d.ts +31 -0
- package/dist/lifeops/service-mixin-x-read.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x-read.js +267 -0
- package/dist/lifeops/service-mixin-x-read.js.map +1 -0
- package/dist/lifeops/service-mixin-x.d.ts +66 -0
- package/dist/lifeops/service-mixin-x.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x.js +501 -0
- package/dist/lifeops/service-mixin-x.js.map +1 -0
- package/dist/lifeops/service-normalize-connector.d.ts +19 -0
- package/dist/lifeops/service-normalize-connector.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-connector.js +816 -0
- package/dist/lifeops/service-normalize-connector.js.map +1 -0
- package/dist/lifeops/service-normalize-gmail.d.ts +11 -0
- package/dist/lifeops/service-normalize-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-gmail.js +85 -0
- package/dist/lifeops/service-normalize-gmail.js.map +1 -0
- package/dist/lifeops/service-normalize-task.d.ts +9 -0
- package/dist/lifeops/service-normalize-task.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-task.js +567 -0
- package/dist/lifeops/service-normalize-task.js.map +1 -0
- package/dist/lifeops/service-normalize.d.ts +9 -0
- package/dist/lifeops/service-normalize.d.ts.map +1 -0
- package/dist/lifeops/service-normalize.js +53 -0
- package/dist/lifeops/service-normalize.js.map +1 -0
- package/dist/lifeops/service-types.d.ts +75 -0
- package/dist/lifeops/service-types.d.ts.map +1 -0
- package/dist/lifeops/service-types.js +5 -0
- package/dist/lifeops/service-types.js.map +1 -0
- package/dist/lifeops/service.d.ts +482 -0
- package/dist/lifeops/service.d.ts.map +1 -0
- package/dist/lifeops/service.js +62 -0
- package/dist/lifeops/service.js.map +1 -0
- package/dist/lifeops/signal-runtime-config.d.ts +13 -0
- package/dist/lifeops/signal-runtime-config.d.ts.map +1 -0
- package/dist/lifeops/signal-runtime-config.js +44 -0
- package/dist/lifeops/signal-runtime-config.js.map +1 -0
- package/dist/lifeops/signals/bus.d.ts +78 -0
- package/dist/lifeops/signals/bus.d.ts.map +1 -0
- package/dist/lifeops/signals/bus.js +117 -0
- package/dist/lifeops/signals/bus.js.map +1 -0
- package/dist/lifeops/sql.d.ts +65 -0
- package/dist/lifeops/sql.d.ts.map +1 -0
- package/dist/lifeops/sql.js +182 -0
- package/dist/lifeops/sql.js.map +1 -0
- package/dist/lifeops/stretch-decider.d.ts +73 -0
- package/dist/lifeops/stretch-decider.d.ts.map +1 -0
- package/dist/lifeops/stretch-decider.js +49 -0
- package/dist/lifeops/stretch-decider.js.map +1 -0
- package/dist/lifeops/telemetry-mapping.d.ts +14 -0
- package/dist/lifeops/telemetry-mapping.d.ts.map +1 -0
- package/dist/lifeops/telemetry-mapping.js +115 -0
- package/dist/lifeops/telemetry-mapping.js.map +1 -0
- package/dist/lifeops/telemetry-retention.d.ts +21 -0
- package/dist/lifeops/telemetry-retention.d.ts.map +1 -0
- package/dist/lifeops/telemetry-retention.js +13 -0
- package/dist/lifeops/telemetry-retention.js.map +1 -0
- package/dist/lifeops/time/timezone.d.ts +4 -0
- package/dist/lifeops/time/timezone.d.ts.map +1 -0
- package/dist/lifeops/time/timezone.js +154 -0
- package/dist/lifeops/time/timezone.js.map +1 -0
- package/dist/lifeops/time-util.d.ts +10 -0
- package/dist/lifeops/time-util.d.ts.map +1 -0
- package/dist/lifeops/time-util.js +14 -0
- package/dist/lifeops/time-util.js.map +1 -0
- package/dist/lifeops/time.d.ts +17 -0
- package/dist/lifeops/time.d.ts.map +1 -0
- package/dist/lifeops/time.js +152 -0
- package/dist/lifeops/time.js.map +1 -0
- package/dist/lifeops/travel-booking.types.d.ts +46 -0
- package/dist/lifeops/travel-booking.types.d.ts.map +1 -0
- package/dist/lifeops/travel-booking.types.js +1 -0
- package/dist/lifeops/travel-booking.types.js.map +1 -0
- package/dist/lifeops/triggers/schedule-once.d.ts +19 -0
- package/dist/lifeops/triggers/schedule-once.d.ts.map +1 -0
- package/dist/lifeops/triggers/schedule-once.js +99 -0
- package/dist/lifeops/triggers/schedule-once.js.map +1 -0
- package/dist/lifeops/validate/coding-task-request.d.ts +18 -0
- package/dist/lifeops/validate/coding-task-request.d.ts.map +1 -0
- package/dist/lifeops/validate/coding-task-request.js +16 -0
- package/dist/lifeops/validate/coding-task-request.js.map +1 -0
- package/dist/lifeops/voice/grounded-reply.d.ts +41 -0
- package/dist/lifeops/voice/grounded-reply.d.ts.map +1 -0
- package/dist/lifeops/voice/grounded-reply.js +24 -0
- package/dist/lifeops/voice/grounded-reply.js.map +1 -0
- package/dist/lifeops/voice-affect.d.ts +79 -0
- package/dist/lifeops/voice-affect.d.ts.map +1 -0
- package/dist/lifeops/voice-affect.js +253 -0
- package/dist/lifeops/voice-affect.js.map +1 -0
- package/dist/lifeops/wave1-types.d.ts +125 -0
- package/dist/lifeops/wave1-types.d.ts.map +1 -0
- package/dist/lifeops/wave1-types.js +1 -0
- package/dist/lifeops/wave1-types.js.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts +33 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js +226 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js.map +1 -0
- package/dist/lifeops/work-threads/index.d.ts +3 -0
- package/dist/lifeops/work-threads/index.d.ts.map +1 -0
- package/dist/lifeops/work-threads/index.js +7 -0
- package/dist/lifeops/work-threads/index.js.map +1 -0
- package/dist/lifeops/work-threads/store.d.ts +91 -0
- package/dist/lifeops/work-threads/store.d.ts.map +1 -0
- package/dist/lifeops/work-threads/store.js +245 -0
- package/dist/lifeops/work-threads/store.js.map +1 -0
- package/dist/lifeops/work-threads/types.d.ts +58 -0
- package/dist/lifeops/work-threads/types.d.ts.map +1 -0
- package/dist/lifeops/work-threads/types.js +1 -0
- package/dist/lifeops/work-threads/types.js.map +1 -0
- package/dist/platform/host.d.ts +16 -0
- package/dist/platform/host.d.ts.map +1 -0
- package/dist/platform/host.js +22 -0
- package/dist/platform/host.js.map +1 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.d.ts.map +1 -0
- package/dist/platform/index.js +3 -0
- package/dist/platform/index.js.map +1 -0
- package/dist/platform/lifeops-github.d.ts +15 -0
- package/dist/platform/lifeops-github.d.ts.map +1 -0
- package/dist/platform/lifeops-github.js +146 -0
- package/dist/platform/lifeops-github.js.map +1 -0
- package/dist/plugin.d.ts +106 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +989 -0
- package/dist/plugin.js.map +1 -0
- package/dist/provider.d.ts +4 -0
- package/dist/provider.d.ts.map +1 -0
- package/dist/provider.js +108 -0
- package/dist/provider.js.map +1 -0
- package/dist/providers/activity-profile.d.ts +3 -0
- package/dist/providers/activity-profile.d.ts.map +1 -0
- package/dist/providers/activity-profile.js +140 -0
- package/dist/providers/activity-profile.js.map +1 -0
- package/dist/providers/cross-channel-context.d.ts +29 -0
- package/dist/providers/cross-channel-context.d.ts.map +1 -0
- package/dist/providers/cross-channel-context.js +206 -0
- package/dist/providers/cross-channel-context.js.map +1 -0
- package/dist/providers/first-run.d.ts +22 -0
- package/dist/providers/first-run.d.ts.map +1 -0
- package/dist/providers/first-run.js +93 -0
- package/dist/providers/first-run.js.map +1 -0
- package/dist/providers/health.d.ts +2 -0
- package/dist/providers/health.d.ts.map +1 -0
- package/dist/providers/health.js +14 -0
- package/dist/providers/health.js.map +1 -0
- package/dist/providers/inbox-triage.d.ts +3 -0
- package/dist/providers/inbox-triage.d.ts.map +1 -0
- package/dist/providers/inbox-triage.js +134 -0
- package/dist/providers/inbox-triage.js.map +1 -0
- package/dist/providers/lifeops.d.ts +3 -0
- package/dist/providers/lifeops.d.ts.map +1 -0
- package/dist/providers/lifeops.js +548 -0
- package/dist/providers/lifeops.js.map +1 -0
- package/dist/providers/pending-prompts.d.ts +38 -0
- package/dist/providers/pending-prompts.d.ts.map +1 -0
- package/dist/providers/pending-prompts.js +81 -0
- package/dist/providers/pending-prompts.js.map +1 -0
- package/dist/providers/recent-task-states.d.ts +52 -0
- package/dist/providers/recent-task-states.d.ts.map +1 -0
- package/dist/providers/recent-task-states.js +166 -0
- package/dist/providers/recent-task-states.js.map +1 -0
- package/dist/providers/room-policy.d.ts +16 -0
- package/dist/providers/room-policy.d.ts.map +1 -0
- package/dist/providers/room-policy.js +71 -0
- package/dist/providers/room-policy.js.map +1 -0
- package/dist/providers/work-threads.d.ts +3 -0
- package/dist/providers/work-threads.d.ts.map +1 -0
- package/dist/providers/work-threads.js +97 -0
- package/dist/providers/work-threads.js.map +1 -0
- package/dist/public.d.ts +3 -0
- package/dist/public.d.ts.map +1 -0
- package/dist/public.js +17 -0
- package/dist/public.js.map +1 -0
- package/dist/routes/cloud-features-routes.d.ts +9 -0
- package/dist/routes/cloud-features-routes.d.ts.map +1 -0
- package/dist/routes/cloud-features-routes.js +164 -0
- package/dist/routes/cloud-features-routes.js.map +1 -0
- package/dist/routes/entities.d.ts +14 -0
- package/dist/routes/entities.d.ts.map +1 -0
- package/dist/routes/entities.js +203 -0
- package/dist/routes/entities.js.map +1 -0
- package/dist/routes/lifeops-routes.d.ts +20 -0
- package/dist/routes/lifeops-routes.d.ts.map +1 -0
- package/dist/routes/lifeops-routes.js +2337 -0
- package/dist/routes/lifeops-routes.js.map +1 -0
- package/dist/routes/plugin.d.ts +9 -0
- package/dist/routes/plugin.d.ts.map +1 -0
- package/dist/routes/plugin.js +568 -0
- package/dist/routes/plugin.js.map +1 -0
- package/dist/routes/relationships.d.ts +13 -0
- package/dist/routes/relationships.d.ts.map +1 -0
- package/dist/routes/relationships.js +195 -0
- package/dist/routes/relationships.js.map +1 -0
- package/dist/routes/scheduled-tasks.d.ts +102 -0
- package/dist/routes/scheduled-tasks.d.ts.map +1 -0
- package/dist/routes/scheduled-tasks.js +322 -0
- package/dist/routes/scheduled-tasks.js.map +1 -0
- package/dist/routes/sleep-routes.d.ts +3 -0
- package/dist/routes/sleep-routes.d.ts.map +1 -0
- package/dist/routes/sleep-routes.js +33 -0
- package/dist/routes/sleep-routes.js.map +1 -0
- package/dist/routes/travel-provider-relay-routes.d.ts +2 -0
- package/dist/routes/travel-provider-relay-routes.d.ts.map +1 -0
- package/dist/routes/travel-provider-relay-routes.js +7 -0
- package/dist/routes/travel-provider-relay-routes.js.map +1 -0
- package/dist/routes/website-blocker-routes.d.ts +6 -0
- package/dist/routes/website-blocker-routes.d.ts.map +1 -0
- package/dist/routes/website-blocker-routes.js +218 -0
- package/dist/routes/website-blocker-routes.js.map +1 -0
- package/dist/security/action-confirmation.d.ts +12 -0
- package/dist/security/action-confirmation.d.ts.map +1 -0
- package/dist/security/action-confirmation.js +36 -0
- package/dist/security/action-confirmation.js.map +1 -0
- package/dist/service.d.ts +34 -0
- package/dist/service.d.ts.map +1 -0
- package/dist/service.js +111 -0
- package/dist/service.js.map +1 -0
- package/dist/travel-time/calendar-create.d.ts +17 -0
- package/dist/travel-time/calendar-create.d.ts.map +1 -0
- package/dist/travel-time/calendar-create.js +28 -0
- package/dist/travel-time/calendar-create.js.map +1 -0
- package/dist/travel-time/service.d.ts +114 -0
- package/dist/travel-time/service.d.ts.map +1 -0
- package/dist/travel-time/service.js +209 -0
- package/dist/travel-time/service.js.map +1 -0
- package/dist/types/app-blocker-settings-card.d.ts +2 -0
- package/dist/types/app-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/app-blocker-settings-card.js +1 -0
- package/dist/types/app-blocker-settings-card.js.map +1 -0
- package/dist/types/briefing.d.ts +59 -0
- package/dist/types/briefing.d.ts.map +1 -0
- package/dist/types/briefing.js +1 -0
- package/dist/types/briefing.js.map +1 -0
- package/dist/types/document-request.d.ts +41 -0
- package/dist/types/document-request.d.ts.map +1 -0
- package/dist/types/document-request.js +1 -0
- package/dist/types/document-request.js.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/website-blocker-settings-card.d.ts +2 -0
- package/dist/types/website-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/website-blocker-settings-card.js +1 -0
- package/dist/types/website-blocker-settings-card.js.map +1 -0
- package/dist/ui.d.ts +13 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +25 -0
- package/dist/ui.js.map +1 -0
- package/dist/utils/format-duration.d.ts +2 -0
- package/dist/utils/format-duration.d.ts.map +1 -0
- package/dist/utils/format-duration.js +13 -0
- package/dist/utils/format-duration.js.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +3 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/lifeops-url.d.ts +3 -0
- package/dist/utils/lifeops-url.d.ts.map +1 -0
- package/dist/utils/lifeops-url.js +28 -0
- package/dist/utils/lifeops-url.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts +32 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.js +30 -0
- package/dist/website-blocker/chat-integration/block-activator.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts +7 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js +115 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts +39 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js +133 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts +21 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js +230 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts +13 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js +22 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js.map +1 -0
- package/dist/website-blocker/chat-integration/index.d.ts +5 -0
- package/dist/website-blocker/chat-integration/index.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/index.js +26 -0
- package/dist/website-blocker/chat-integration/index.js.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts +75 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.js +154 -0
- package/dist/website-blocker/proactive-block-bridge.js.map +1 -0
- package/dist/website-blocker/public.d.ts +12 -0
- package/dist/website-blocker/public.d.ts.map +1 -0
- package/dist/website-blocker/public.js +51 -0
- package/dist/website-blocker/public.js.map +1 -0
- package/package.json +28 -28
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import type { TravelBookingPayloadFields } from "./travel-booking.types.js";
|
|
2
|
+
export type ApprovalRequestState = "pending" | "approved" | "executing" | "done" | "rejected" | "expired";
|
|
3
|
+
export type ApprovalAction = "send_message" | "send_email" | "schedule_event" | "modify_event" | "cancel_event" | "book_travel" | "make_call" | "sign_document" | "execute_workflow" | "spend_money";
|
|
4
|
+
export type ApprovalChannel = "telegram" | "discord" | "slack" | "imessage" | "sms" | "x_dm" | "email" | "google_calendar" | "browser" | "phone" | "internal";
|
|
5
|
+
export type ApprovalPayload = {
|
|
6
|
+
action: "send_message";
|
|
7
|
+
recipient: string;
|
|
8
|
+
body: string;
|
|
9
|
+
replyToMessageId: string | null;
|
|
10
|
+
} | {
|
|
11
|
+
action: "send_email";
|
|
12
|
+
to: ReadonlyArray<string>;
|
|
13
|
+
cc: ReadonlyArray<string>;
|
|
14
|
+
bcc: ReadonlyArray<string>;
|
|
15
|
+
subject: string;
|
|
16
|
+
body: string;
|
|
17
|
+
threadId: string | null;
|
|
18
|
+
replyToMessageId?: string | null;
|
|
19
|
+
} | {
|
|
20
|
+
action: "schedule_event";
|
|
21
|
+
calendarId: string;
|
|
22
|
+
title: string;
|
|
23
|
+
startsAtMs: number;
|
|
24
|
+
endsAtMs: number;
|
|
25
|
+
attendees: ReadonlyArray<string>;
|
|
26
|
+
location: string | null;
|
|
27
|
+
description: string | null;
|
|
28
|
+
} | {
|
|
29
|
+
action: "modify_event";
|
|
30
|
+
calendarId: string;
|
|
31
|
+
eventId: string;
|
|
32
|
+
patch: {
|
|
33
|
+
title: string | null;
|
|
34
|
+
startsAtMs: number | null;
|
|
35
|
+
endsAtMs: number | null;
|
|
36
|
+
attendees: ReadonlyArray<string> | null;
|
|
37
|
+
location: string | null;
|
|
38
|
+
description: string | null;
|
|
39
|
+
};
|
|
40
|
+
} | {
|
|
41
|
+
action: "cancel_event";
|
|
42
|
+
calendarId: string;
|
|
43
|
+
eventId: string;
|
|
44
|
+
notifyAttendees: boolean;
|
|
45
|
+
} | {
|
|
46
|
+
action: "book_travel";
|
|
47
|
+
kind: TravelBookingPayloadFields["kind"];
|
|
48
|
+
provider: string;
|
|
49
|
+
itineraryRef: string;
|
|
50
|
+
totalCents: number;
|
|
51
|
+
currency: string;
|
|
52
|
+
offerId?: string | null;
|
|
53
|
+
offerRequestId?: string | null;
|
|
54
|
+
orderType?: "hold" | "instant" | null;
|
|
55
|
+
search?: TravelBookingPayloadFields["search"];
|
|
56
|
+
passengers?: TravelBookingPayloadFields["passengers"];
|
|
57
|
+
calendarSync?: TravelBookingPayloadFields["calendarSync"];
|
|
58
|
+
summary?: string | null;
|
|
59
|
+
/** Server-side cost breakdown surfaced to the user alongside any
|
|
60
|
+
* payment-required prompt. Mirrors `DuffelCallCost`; held as a
|
|
61
|
+
* loose record here so the approval-queue type doesn't have to
|
|
62
|
+
* depend on the travel-adapter package. */
|
|
63
|
+
cost?: {
|
|
64
|
+
readonly totalUsd: number;
|
|
65
|
+
readonly creatorMarkupUsd: number;
|
|
66
|
+
readonly platformFeeUsd: number;
|
|
67
|
+
readonly markupPercent: number | null;
|
|
68
|
+
} | null;
|
|
69
|
+
/** Set when an x402 PaymentRequiredError fired before the booking
|
|
70
|
+
* could be quoted. The user sees both the booking intent and the
|
|
71
|
+
* top-up prompt in a single approval entry. */
|
|
72
|
+
paymentRequired?: {
|
|
73
|
+
readonly amount: string;
|
|
74
|
+
readonly asset: string;
|
|
75
|
+
readonly network: string;
|
|
76
|
+
readonly payTo: string;
|
|
77
|
+
readonly scheme: string;
|
|
78
|
+
readonly expiresAt: string | null;
|
|
79
|
+
readonly description: string | null;
|
|
80
|
+
} | null;
|
|
81
|
+
} | {
|
|
82
|
+
action: "make_call";
|
|
83
|
+
to: string;
|
|
84
|
+
script: string;
|
|
85
|
+
maxDurationSeconds: number;
|
|
86
|
+
} | {
|
|
87
|
+
action: "sign_document";
|
|
88
|
+
documentId: string;
|
|
89
|
+
documentName: string;
|
|
90
|
+
signatureUrl: string;
|
|
91
|
+
deadline: string;
|
|
92
|
+
} | {
|
|
93
|
+
action: "execute_workflow";
|
|
94
|
+
workflowId: string;
|
|
95
|
+
input: Readonly<Record<string, string | number | boolean>>;
|
|
96
|
+
} | {
|
|
97
|
+
action: "spend_money";
|
|
98
|
+
vendor: string;
|
|
99
|
+
amountCents: number;
|
|
100
|
+
currency: string;
|
|
101
|
+
memo: string;
|
|
102
|
+
};
|
|
103
|
+
/** Persisted approval request. */
|
|
104
|
+
export interface ApprovalRequest {
|
|
105
|
+
readonly id: string;
|
|
106
|
+
readonly createdAt: Date;
|
|
107
|
+
readonly updatedAt: Date;
|
|
108
|
+
readonly state: ApprovalRequestState;
|
|
109
|
+
readonly requestedBy: string;
|
|
110
|
+
readonly subjectUserId: string;
|
|
111
|
+
readonly action: ApprovalAction;
|
|
112
|
+
readonly payload: ApprovalPayload;
|
|
113
|
+
readonly channel: ApprovalChannel;
|
|
114
|
+
readonly reason: string;
|
|
115
|
+
readonly expiresAt: Date;
|
|
116
|
+
readonly resolvedAt: Date | null;
|
|
117
|
+
readonly resolvedBy: string | null;
|
|
118
|
+
readonly resolutionReason: string | null;
|
|
119
|
+
}
|
|
120
|
+
/** Input to `enqueue` — server fills in id, timestamps, and initial state. */
|
|
121
|
+
export interface ApprovalEnqueueInput {
|
|
122
|
+
readonly requestedBy: string;
|
|
123
|
+
readonly subjectUserId: string;
|
|
124
|
+
readonly action: ApprovalAction;
|
|
125
|
+
readonly payload: ApprovalPayload;
|
|
126
|
+
readonly channel: ApprovalChannel;
|
|
127
|
+
readonly reason: string;
|
|
128
|
+
readonly expiresAt: Date;
|
|
129
|
+
}
|
|
130
|
+
/** Filter for `list`. All fields combine with AND. */
|
|
131
|
+
export interface ApprovalListFilter {
|
|
132
|
+
readonly subjectUserId: string | null;
|
|
133
|
+
readonly state: ApprovalRequestState | null;
|
|
134
|
+
readonly action: ApprovalAction | null;
|
|
135
|
+
readonly limit: number;
|
|
136
|
+
}
|
|
137
|
+
/** Resolution input for `approve` / `reject`. */
|
|
138
|
+
export interface ApprovalResolution {
|
|
139
|
+
readonly resolvedBy: string;
|
|
140
|
+
readonly resolutionReason: string;
|
|
141
|
+
}
|
|
142
|
+
/** Thrown when a state transition is invalid. */
|
|
143
|
+
export declare class ApprovalStateTransitionError extends Error {
|
|
144
|
+
readonly requestId: string;
|
|
145
|
+
readonly from: ApprovalRequestState;
|
|
146
|
+
readonly to: ApprovalRequestState;
|
|
147
|
+
constructor(requestId: string, from: ApprovalRequestState, to: ApprovalRequestState);
|
|
148
|
+
}
|
|
149
|
+
/** Thrown when an operation references an unknown request id. */
|
|
150
|
+
export declare class ApprovalNotFoundError extends Error {
|
|
151
|
+
readonly requestId: string;
|
|
152
|
+
constructor(requestId: string);
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Queue interface. Implementations must:
|
|
156
|
+
* - Reject invalid state transitions by throwing `ApprovalStateTransitionError`.
|
|
157
|
+
* - Reject unknown ids by throwing `ApprovalNotFoundError`.
|
|
158
|
+
* - Use the structured logger only (no `console.*`).
|
|
159
|
+
* - Treat `purgeExpired` as idempotent.
|
|
160
|
+
*/
|
|
161
|
+
export interface ApprovalQueue {
|
|
162
|
+
enqueue(input: ApprovalEnqueueInput): Promise<ApprovalRequest>;
|
|
163
|
+
list(filter: ApprovalListFilter): Promise<ReadonlyArray<ApprovalRequest>>;
|
|
164
|
+
byId(id: string): Promise<ApprovalRequest | null>;
|
|
165
|
+
approve(id: string, resolution: ApprovalResolution): Promise<ApprovalRequest>;
|
|
166
|
+
reject(id: string, resolution: ApprovalResolution): Promise<ApprovalRequest>;
|
|
167
|
+
markExecuting(id: string): Promise<ApprovalRequest>;
|
|
168
|
+
markDone(id: string): Promise<ApprovalRequest>;
|
|
169
|
+
markExpired(id: string): Promise<ApprovalRequest>;
|
|
170
|
+
purgeExpired(now: Date): Promise<ReadonlyArray<string>>;
|
|
171
|
+
}
|
|
172
|
+
//# sourceMappingURL=approval-queue.types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"approval-queue.types.d.ts","sourceRoot":"","sources":["../../src/lifeops/approval-queue.types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
class ApprovalStateTransitionError extends Error {
|
|
2
|
+
requestId;
|
|
3
|
+
from;
|
|
4
|
+
to;
|
|
5
|
+
constructor(requestId, from, to) {
|
|
6
|
+
super(
|
|
7
|
+
`[ApprovalQueue] invalid transition for request ${requestId}: ${from} -> ${to}`
|
|
8
|
+
);
|
|
9
|
+
this.name = "ApprovalStateTransitionError";
|
|
10
|
+
this.requestId = requestId;
|
|
11
|
+
this.from = from;
|
|
12
|
+
this.to = to;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
class ApprovalNotFoundError extends Error {
|
|
16
|
+
requestId;
|
|
17
|
+
constructor(requestId) {
|
|
18
|
+
super(`[ApprovalQueue] request not found: ${requestId}`);
|
|
19
|
+
this.name = "ApprovalNotFoundError";
|
|
20
|
+
this.requestId = requestId;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
export {
|
|
24
|
+
ApprovalNotFoundError,
|
|
25
|
+
ApprovalStateTransitionError
|
|
26
|
+
};
|
|
27
|
+
//# sourceMappingURL=approval-queue.types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/approval-queue.types.ts"],"sourcesContent":["import type { TravelBookingPayloadFields } from \"./travel-booking.types.js\";\n\nexport type ApprovalRequestState =\n | \"pending\"\n | \"approved\"\n | \"executing\"\n | \"done\"\n | \"rejected\"\n | \"expired\";\n\nexport type ApprovalAction =\n | \"send_message\"\n | \"send_email\"\n | \"schedule_event\"\n | \"modify_event\"\n | \"cancel_event\"\n | \"book_travel\"\n | \"make_call\"\n | \"sign_document\"\n | \"execute_workflow\"\n | \"spend_money\";\n\nexport type ApprovalChannel =\n | \"telegram\"\n | \"discord\"\n | \"slack\"\n | \"imessage\"\n | \"sms\"\n | \"x_dm\"\n | \"email\"\n | \"google_calendar\"\n | \"browser\"\n | \"phone\"\n | \"internal\";\n\nexport type ApprovalPayload =\n | {\n action: \"send_message\";\n recipient: string;\n body: string;\n replyToMessageId: string | null;\n }\n | {\n action: \"send_email\";\n to: ReadonlyArray<string>;\n cc: ReadonlyArray<string>;\n bcc: ReadonlyArray<string>;\n subject: string;\n body: string;\n threadId: string | null;\n replyToMessageId?: string | null;\n }\n | {\n action: \"schedule_event\";\n calendarId: string;\n title: string;\n startsAtMs: number;\n endsAtMs: number;\n attendees: ReadonlyArray<string>;\n location: string | null;\n description: string | null;\n }\n | {\n action: \"modify_event\";\n calendarId: string;\n eventId: string;\n patch: {\n title: string | null;\n startsAtMs: number | null;\n endsAtMs: number | null;\n attendees: ReadonlyArray<string> | null;\n location: string | null;\n description: string | null;\n };\n }\n | {\n action: \"cancel_event\";\n calendarId: string;\n eventId: string;\n notifyAttendees: boolean;\n }\n | {\n action: \"book_travel\";\n kind: TravelBookingPayloadFields[\"kind\"];\n provider: string;\n itineraryRef: string;\n totalCents: number;\n currency: string;\n offerId?: string | null;\n offerRequestId?: string | null;\n orderType?: \"hold\" | \"instant\" | null;\n search?: TravelBookingPayloadFields[\"search\"];\n passengers?: TravelBookingPayloadFields[\"passengers\"];\n calendarSync?: TravelBookingPayloadFields[\"calendarSync\"];\n summary?: string | null;\n /** Server-side cost breakdown surfaced to the user alongside any\n * payment-required prompt. Mirrors `DuffelCallCost`; held as a\n * loose record here so the approval-queue type doesn't have to\n * depend on the travel-adapter package. */\n cost?: {\n readonly totalUsd: number;\n readonly creatorMarkupUsd: number;\n readonly platformFeeUsd: number;\n readonly markupPercent: number | null;\n } | null;\n /** Set when an x402 PaymentRequiredError fired before the booking\n * could be quoted. The user sees both the booking intent and the\n * top-up prompt in a single approval entry. */\n paymentRequired?: {\n readonly amount: string;\n readonly asset: string;\n readonly network: string;\n readonly payTo: string;\n readonly scheme: string;\n readonly expiresAt: string | null;\n readonly description: string | null;\n } | null;\n }\n | {\n action: \"make_call\";\n to: string;\n script: string;\n maxDurationSeconds: number;\n }\n | {\n action: \"sign_document\";\n documentId: string;\n documentName: string;\n signatureUrl: string;\n deadline: string;\n }\n | {\n action: \"execute_workflow\";\n workflowId: string;\n input: Readonly<Record<string, string | number | boolean>>;\n }\n | {\n action: \"spend_money\";\n vendor: string;\n amountCents: number;\n currency: string;\n memo: string;\n };\n\n/** Persisted approval request. */\nexport interface ApprovalRequest {\n readonly id: string;\n readonly createdAt: Date;\n readonly updatedAt: Date;\n readonly state: ApprovalRequestState;\n readonly requestedBy: string;\n readonly subjectUserId: string;\n readonly action: ApprovalAction;\n readonly payload: ApprovalPayload;\n readonly channel: ApprovalChannel;\n readonly reason: string;\n readonly expiresAt: Date;\n readonly resolvedAt: Date | null;\n readonly resolvedBy: string | null;\n readonly resolutionReason: string | null;\n}\n\n/** Input to `enqueue` — server fills in id, timestamps, and initial state. */\nexport interface ApprovalEnqueueInput {\n readonly requestedBy: string;\n readonly subjectUserId: string;\n readonly action: ApprovalAction;\n readonly payload: ApprovalPayload;\n readonly channel: ApprovalChannel;\n readonly reason: string;\n readonly expiresAt: Date;\n}\n\n/** Filter for `list`. All fields combine with AND. */\nexport interface ApprovalListFilter {\n readonly subjectUserId: string | null;\n readonly state: ApprovalRequestState | null;\n readonly action: ApprovalAction | null;\n readonly limit: number;\n}\n\n/** Resolution input for `approve` / `reject`. */\nexport interface ApprovalResolution {\n readonly resolvedBy: string;\n readonly resolutionReason: string;\n}\n\n/** Thrown when a state transition is invalid. */\nexport class ApprovalStateTransitionError extends Error {\n public readonly requestId: string;\n public readonly from: ApprovalRequestState;\n public readonly to: ApprovalRequestState;\n\n constructor(\n requestId: string,\n from: ApprovalRequestState,\n to: ApprovalRequestState,\n ) {\n super(\n `[ApprovalQueue] invalid transition for request ${requestId}: ${from} -> ${to}`,\n );\n this.name = \"ApprovalStateTransitionError\";\n this.requestId = requestId;\n this.from = from;\n this.to = to;\n }\n}\n\n/** Thrown when an operation references an unknown request id. */\nexport class ApprovalNotFoundError extends Error {\n public readonly requestId: string;\n\n constructor(requestId: string) {\n super(`[ApprovalQueue] request not found: ${requestId}`);\n this.name = \"ApprovalNotFoundError\";\n this.requestId = requestId;\n }\n}\n\n/**\n * Queue interface. Implementations must:\n * - Reject invalid state transitions by throwing `ApprovalStateTransitionError`.\n * - Reject unknown ids by throwing `ApprovalNotFoundError`.\n * - Use the structured logger only (no `console.*`).\n * - Treat `purgeExpired` as idempotent.\n */\nexport interface ApprovalQueue {\n enqueue(input: ApprovalEnqueueInput): Promise<ApprovalRequest>;\n list(filter: ApprovalListFilter): Promise<ReadonlyArray<ApprovalRequest>>;\n byId(id: string): Promise<ApprovalRequest | null>;\n approve(id: string, resolution: ApprovalResolution): Promise<ApprovalRequest>;\n reject(id: string, resolution: ApprovalResolution): Promise<ApprovalRequest>;\n markExecuting(id: string): Promise<ApprovalRequest>;\n markDone(id: string): Promise<ApprovalRequest>;\n markExpired(id: string): Promise<ApprovalRequest>;\n purgeExpired(now: Date): Promise<ReadonlyArray<string>>;\n}\n"],"mappings":"AA4LO,MAAM,qCAAqC,MAAM;AAAA,EACtC;AAAA,EACA;AAAA,EACA;AAAA,EAEhB,YACE,WACA,MACA,IACA;AACA;AAAA,MACE,kDAAkD,SAAS,KAAK,IAAI,OAAO,EAAE;AAAA,IAC/E;AACA,SAAK,OAAO;AACZ,SAAK,YAAY;AACjB,SAAK,OAAO;AACZ,SAAK,KAAK;AAAA,EACZ;AACF;AAGO,MAAM,8BAA8B,MAAM;AAAA,EAC/B;AAAA,EAEhB,YAAY,WAAmB;AAC7B,UAAM,sCAAsC,SAAS,EAAE;AACvD,SAAK,OAAO;AACZ,SAAK,YAAY;AAAA,EACnB;AACF;","names":[]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent-side autofill refusal list. This is the first gate before a request is
|
|
3
|
+
* sent to the browser companion, so unsafe domains are rejected even if the
|
|
4
|
+
* companion is unreachable.
|
|
5
|
+
*
|
|
6
|
+
* The default brand domains live in
|
|
7
|
+
* `src/default-packs/autofill-whitelist-pack.ts`. This module re-exports them
|
|
8
|
+
* as `DEFAULT_AUTOFILL_WHITELIST` so callers don't need to know about the pack
|
|
9
|
+
* — adding a default domain is a literal-edit in the pack file.
|
|
10
|
+
*/
|
|
11
|
+
export declare const DEFAULT_AUTOFILL_WHITELIST: readonly string[];
|
|
12
|
+
export declare function extractRegistrableDomain(input: string): string | null;
|
|
13
|
+
export declare function normalizeAutofillDomain(input: string): string | null;
|
|
14
|
+
export interface WhitelistCheckResult {
|
|
15
|
+
readonly allowed: boolean;
|
|
16
|
+
readonly registrableDomain: string | null;
|
|
17
|
+
readonly matched: string | null;
|
|
18
|
+
}
|
|
19
|
+
export declare function isUrlWhitelisted(url: string, domains: readonly string[]): WhitelistCheckResult;
|
|
20
|
+
//# sourceMappingURL=autofill-whitelist.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"autofill-whitelist.d.ts","sourceRoot":"","sources":["../../src/lifeops/autofill-whitelist.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH,eAAO,MAAM,0BAA0B,EAAE,SAAS,MAAM,EACzB,CAAC;AAEhC,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAsBrE;AAED,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAEpE;AAED,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1C,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;CACjC;AAED,wBAAgB,gBAAgB,CAC9B,GAAG,EAAE,MAAM,EACX,OAAO,EAAE,SAAS,MAAM,EAAE,GACzB,oBAAoB,CAuBtB"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { getDefaultAutofillWhitelist } from "../default-packs/autofill-whitelist-pack.js";
|
|
2
|
+
const DEFAULT_AUTOFILL_WHITELIST = getDefaultAutofillWhitelist();
|
|
3
|
+
function extractRegistrableDomain(input) {
|
|
4
|
+
if (typeof input !== "string") return null;
|
|
5
|
+
const trimmed = input.trim();
|
|
6
|
+
if (trimmed.length === 0) return null;
|
|
7
|
+
let host;
|
|
8
|
+
if (/^[a-z]+:\/\//i.test(trimmed)) {
|
|
9
|
+
try {
|
|
10
|
+
host = new URL(trimmed).hostname;
|
|
11
|
+
} catch {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
} else {
|
|
15
|
+
host = trimmed.replace(/^\/+/, "").split("/")[0] ?? "";
|
|
16
|
+
}
|
|
17
|
+
host = host.toLowerCase().replace(/\.$/, "");
|
|
18
|
+
if (host.length === 0) return null;
|
|
19
|
+
if (host === "localhost") return null;
|
|
20
|
+
if (/^\d+\.\d+\.\d+\.\d+$/.test(host)) return null;
|
|
21
|
+
if (host.startsWith("[") && host.endsWith("]")) return null;
|
|
22
|
+
const labels = host.split(".").filter((l) => l.length > 0);
|
|
23
|
+
if (labels.length < 2) return null;
|
|
24
|
+
return labels.slice(-2).join(".");
|
|
25
|
+
}
|
|
26
|
+
function normalizeAutofillDomain(input) {
|
|
27
|
+
return extractRegistrableDomain(input);
|
|
28
|
+
}
|
|
29
|
+
function isUrlWhitelisted(url, domains) {
|
|
30
|
+
const registrable = extractRegistrableDomain(url);
|
|
31
|
+
if (registrable === null) {
|
|
32
|
+
return { allowed: false, registrableDomain: null, matched: null };
|
|
33
|
+
}
|
|
34
|
+
let host = registrable;
|
|
35
|
+
if (/^[a-z]+:\/\//i.test(url)) {
|
|
36
|
+
try {
|
|
37
|
+
host = new URL(url).hostname.toLowerCase().replace(/\.$/, "");
|
|
38
|
+
} catch {
|
|
39
|
+
return { allowed: false, registrableDomain: null, matched: null };
|
|
40
|
+
}
|
|
41
|
+
} else {
|
|
42
|
+
host = url.trim().toLowerCase().split("/")[0] ?? registrable;
|
|
43
|
+
}
|
|
44
|
+
for (const raw of domains) {
|
|
45
|
+
const entry = normalizeAutofillDomain(raw);
|
|
46
|
+
if (!entry) continue;
|
|
47
|
+
if (host === entry || host.endsWith(`.${entry}`)) {
|
|
48
|
+
return { allowed: true, registrableDomain: registrable, matched: entry };
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return { allowed: false, registrableDomain: registrable, matched: null };
|
|
52
|
+
}
|
|
53
|
+
export {
|
|
54
|
+
DEFAULT_AUTOFILL_WHITELIST,
|
|
55
|
+
extractRegistrableDomain,
|
|
56
|
+
isUrlWhitelisted,
|
|
57
|
+
normalizeAutofillDomain
|
|
58
|
+
};
|
|
59
|
+
//# sourceMappingURL=autofill-whitelist.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/autofill-whitelist.ts"],"sourcesContent":["/**\n * Agent-side autofill refusal list. This is the first gate before a request is\n * sent to the browser companion, so unsafe domains are rejected even if the\n * companion is unreachable.\n *\n * The default brand domains live in\n * `src/default-packs/autofill-whitelist-pack.ts`. This module re-exports them\n * as `DEFAULT_AUTOFILL_WHITELIST` so callers don't need to know about the pack\n * — adding a default domain is a literal-edit in the pack file.\n */\n\nimport { getDefaultAutofillWhitelist } from \"../default-packs/autofill-whitelist-pack.js\";\n\nexport const DEFAULT_AUTOFILL_WHITELIST: readonly string[] =\n getDefaultAutofillWhitelist();\n\nexport function extractRegistrableDomain(input: string): string | null {\n if (typeof input !== \"string\") return null;\n const trimmed = input.trim();\n if (trimmed.length === 0) return null;\n let host: string;\n if (/^[a-z]+:\\/\\//i.test(trimmed)) {\n try {\n host = new URL(trimmed).hostname;\n } catch {\n return null;\n }\n } else {\n host = trimmed.replace(/^\\/+/, \"\").split(\"/\")[0] ?? \"\";\n }\n host = host.toLowerCase().replace(/\\.$/, \"\");\n if (host.length === 0) return null;\n if (host === \"localhost\") return null;\n if (/^\\d+\\.\\d+\\.\\d+\\.\\d+$/.test(host)) return null;\n if (host.startsWith(\"[\") && host.endsWith(\"]\")) return null;\n const labels = host.split(\".\").filter((l) => l.length > 0);\n if (labels.length < 2) return null;\n return labels.slice(-2).join(\".\");\n}\n\nexport function normalizeAutofillDomain(input: string): string | null {\n return extractRegistrableDomain(input);\n}\n\nexport interface WhitelistCheckResult {\n readonly allowed: boolean;\n readonly registrableDomain: string | null;\n readonly matched: string | null;\n}\n\nexport function isUrlWhitelisted(\n url: string,\n domains: readonly string[],\n): WhitelistCheckResult {\n const registrable = extractRegistrableDomain(url);\n if (registrable === null) {\n return { allowed: false, registrableDomain: null, matched: null };\n }\n let host: string = registrable;\n if (/^[a-z]+:\\/\\//i.test(url)) {\n try {\n host = new URL(url).hostname.toLowerCase().replace(/\\.$/, \"\");\n } catch {\n return { allowed: false, registrableDomain: null, matched: null };\n }\n } else {\n host = url.trim().toLowerCase().split(\"/\")[0] ?? registrable;\n }\n for (const raw of domains) {\n const entry = normalizeAutofillDomain(raw);\n if (!entry) continue;\n if (host === entry || host.endsWith(`.${entry}`)) {\n return { allowed: true, registrableDomain: registrable, matched: entry };\n }\n }\n return { allowed: false, registrableDomain: registrable, matched: null };\n}\n"],"mappings":"AAWA,SAAS,mCAAmC;AAErC,MAAM,6BACX,4BAA4B;AAEvB,SAAS,yBAAyB,OAA8B;AACrE,MAAI,OAAO,UAAU,SAAU,QAAO;AACtC,QAAM,UAAU,MAAM,KAAK;AAC3B,MAAI,QAAQ,WAAW,EAAG,QAAO;AACjC,MAAI;AACJ,MAAI,gBAAgB,KAAK,OAAO,GAAG;AACjC,QAAI;AACF,aAAO,IAAI,IAAI,OAAO,EAAE;AAAA,IAC1B,QAAQ;AACN,aAAO;AAAA,IACT;AAAA,EACF,OAAO;AACL,WAAO,QAAQ,QAAQ,QAAQ,EAAE,EAAE,MAAM,GAAG,EAAE,CAAC,KAAK;AAAA,EACtD;AACA,SAAO,KAAK,YAAY,EAAE,QAAQ,OAAO,EAAE;AAC3C,MAAI,KAAK,WAAW,EAAG,QAAO;AAC9B,MAAI,SAAS,YAAa,QAAO;AACjC,MAAI,uBAAuB,KAAK,IAAI,EAAG,QAAO;AAC9C,MAAI,KAAK,WAAW,GAAG,KAAK,KAAK,SAAS,GAAG,EAAG,QAAO;AACvD,QAAM,SAAS,KAAK,MAAM,GAAG,EAAE,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC;AACzD,MAAI,OAAO,SAAS,EAAG,QAAO;AAC9B,SAAO,OAAO,MAAM,EAAE,EAAE,KAAK,GAAG;AAClC;AAEO,SAAS,wBAAwB,OAA8B;AACpE,SAAO,yBAAyB,KAAK;AACvC;AAQO,SAAS,iBACd,KACA,SACsB;AACtB,QAAM,cAAc,yBAAyB,GAAG;AAChD,MAAI,gBAAgB,MAAM;AACxB,WAAO,EAAE,SAAS,OAAO,mBAAmB,MAAM,SAAS,KAAK;AAAA,EAClE;AACA,MAAI,OAAe;AACnB,MAAI,gBAAgB,KAAK,GAAG,GAAG;AAC7B,QAAI;AACF,aAAO,IAAI,IAAI,GAAG,EAAE,SAAS,YAAY,EAAE,QAAQ,OAAO,EAAE;AAAA,IAC9D,QAAQ;AACN,aAAO,EAAE,SAAS,OAAO,mBAAmB,MAAM,SAAS,KAAK;AAAA,IAClE;AAAA,EACF,OAAO;AACL,WAAO,IAAI,KAAK,EAAE,YAAY,EAAE,MAAM,GAAG,EAAE,CAAC,KAAK;AAAA,EACnD;AACA,aAAW,OAAO,SAAS;AACzB,UAAM,QAAQ,wBAAwB,GAAG;AACzC,QAAI,CAAC,MAAO;AACZ,QAAI,SAAS,SAAS,KAAK,SAAS,IAAI,KAAK,EAAE,GAAG;AAChD,aAAO,EAAE,SAAS,MAAM,mBAAmB,aAAa,SAAS,MAAM;AAAA,IACzE;AAAA,EACF;AACA,SAAO,EAAE,SAAS,OAAO,mBAAmB,aAAa,SAAS,KAAK;AACzE;","names":[]}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WS5 — glue between {@link planJob} and the WS6 approval queue.
|
|
3
|
+
*
|
|
4
|
+
* Every background job calls {@link planJob} and passes the result here.
|
|
5
|
+
* Sensitive actions (`requiresApproval === true` with a usable payload)
|
|
6
|
+
* are enqueued via the queue exposed by the runtime as service
|
|
7
|
+
* "APPROVAL_QUEUE". Non-sensitive actions and noops are recorded for
|
|
8
|
+
* observability and returned.
|
|
9
|
+
*
|
|
10
|
+
* No side-effects other than enqueue + logger. No try/catch swallow: a
|
|
11
|
+
* missing queue is a typed error that surfaces to the caller.
|
|
12
|
+
*/
|
|
13
|
+
import type { IAgentRuntime } from "@elizaos/core";
|
|
14
|
+
import type { ApprovalRequest } from "./approval-queue.types.js";
|
|
15
|
+
import type { BackgroundJobContext, TypedJobPlan } from "./background-planner.js";
|
|
16
|
+
export declare const APPROVAL_QUEUE_SERVICE_NAME: "APPROVAL_QUEUE";
|
|
17
|
+
/** Default expiry window for queued background-job approvals: 24 hours. */
|
|
18
|
+
export declare const DEFAULT_BACKGROUND_APPROVAL_EXPIRY_MS: number;
|
|
19
|
+
/**
|
|
20
|
+
* Raised when a sensitive plan cannot be enqueued because the WS6 queue is
|
|
21
|
+
* not registered on the runtime. We surface this loudly so the bug cannot
|
|
22
|
+
* hide as a silent skip.
|
|
23
|
+
*/
|
|
24
|
+
export declare class ApprovalQueueUnavailableError extends Error {
|
|
25
|
+
readonly jobKind: string;
|
|
26
|
+
constructor(jobKind: string);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Result returned from {@link enqueueIfSensitive} so callers and tests can
|
|
30
|
+
* introspect what the planner decided for this tick.
|
|
31
|
+
*/
|
|
32
|
+
export interface PlannerDispatchResult {
|
|
33
|
+
readonly jobKind: string;
|
|
34
|
+
readonly plan: TypedJobPlan;
|
|
35
|
+
/** Non-null when a request was enqueued. */
|
|
36
|
+
readonly approvalRequest: ApprovalRequest | null;
|
|
37
|
+
/** True when the plan was a noop or purely internal (no enqueue). */
|
|
38
|
+
readonly skipped: boolean;
|
|
39
|
+
/** When skipped=true, the reason. */
|
|
40
|
+
readonly skipReason: string | null;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* If the plan is sensitive AND has a usable payload, enqueue it in the WS6
|
|
44
|
+
* approval queue. Otherwise, return a skipped result. Always records the
|
|
45
|
+
* decision to the runtime-scoped observability log via
|
|
46
|
+
* {@link recordPlannerDispatch} so the contract test can introspect.
|
|
47
|
+
*/
|
|
48
|
+
export declare function enqueueIfSensitive(runtime: IAgentRuntime, jobContext: BackgroundJobContext, plan: TypedJobPlan, now?: Date): Promise<PlannerDispatchResult>;
|
|
49
|
+
/**
|
|
50
|
+
* Record a planner dispatch decision on the runtime object so the contract
|
|
51
|
+
* test can inspect every invocation without racing against the real
|
|
52
|
+
* approval queue or LLM. Bounded to DISPATCH_LOG_MAX_ENTRIES to prevent the
|
|
53
|
+
* log from growing unbounded on long-lived runtimes.
|
|
54
|
+
*/
|
|
55
|
+
export declare function recordPlannerDispatch(runtime: IAgentRuntime, result: PlannerDispatchResult): void;
|
|
56
|
+
/** Test-only: read the in-memory dispatch log for a runtime. */
|
|
57
|
+
export declare function readPlannerDispatchLog(runtime: IAgentRuntime): ReadonlyArray<PlannerDispatchResult>;
|
|
58
|
+
/** Test-only: clear the dispatch log between runs. */
|
|
59
|
+
export declare function resetPlannerDispatchLog(runtime: IAgentRuntime): void;
|
|
60
|
+
//# sourceMappingURL=background-planner-dispatch.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"background-planner-dispatch.d.ts","sourceRoot":"","sources":["../../src/lifeops/background-planner-dispatch.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAEnD,OAAO,KAAK,EAGV,eAAe,EAChB,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EACV,oBAAoB,EACpB,YAAY,EACb,MAAM,yBAAyB,CAAC;AAEjC,eAAO,MAAM,2BAA2B,EAAG,gBAAyB,CAAC;AAErE,2EAA2E;AAC3E,eAAO,MAAM,qCAAqC,QAAsB,CAAC;AAEzE;;;;GAIG;AACH,qBAAa,6BAA8B,SAAQ,KAAK;IACtD,SAAgB,OAAO,EAAE,MAAM,CAAC;gBACpB,OAAO,EAAE,MAAM;CAO5B;AAYD;;;GAGG;AACH,MAAM,WAAW,qBAAqB;IACpC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAC;IAC5B,4CAA4C;IAC5C,QAAQ,CAAC,eAAe,EAAE,eAAe,GAAG,IAAI,CAAC;IACjD,qEAAqE;IACrE,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,qCAAqC;IACrC,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;CACpC;AAED;;;;;GAKG;AACH,wBAAsB,kBAAkB,CACtC,OAAO,EAAE,aAAa,EACtB,UAAU,EAAE,oBAAoB,EAChC,IAAI,EAAE,YAAY,EAClB,GAAG,GAAE,IAAiB,GACrB,OAAO,CAAC,qBAAqB,CAAC,CAoEhC;AAaD;;;;;GAKG;AACH,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,aAAa,EACtB,MAAM,EAAE,qBAAqB,GAC5B,IAAI,CAQN;AAED,gEAAgE;AAChE,wBAAgB,sBAAsB,CACpC,OAAO,EAAE,aAAa,GACrB,aAAa,CAAC,qBAAqB,CAAC,CAGtC;AAED,sDAAsD;AACtD,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI,CAGpE"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { logger } from "@elizaos/core";
|
|
2
|
+
const APPROVAL_QUEUE_SERVICE_NAME = "APPROVAL_QUEUE";
|
|
3
|
+
const DEFAULT_BACKGROUND_APPROVAL_EXPIRY_MS = 24 * 60 * 60 * 1e3;
|
|
4
|
+
class ApprovalQueueUnavailableError extends Error {
|
|
5
|
+
jobKind;
|
|
6
|
+
constructor(jobKind) {
|
|
7
|
+
super(
|
|
8
|
+
`[BackgroundPlanner:${jobKind}] approval queue service '${APPROVAL_QUEUE_SERVICE_NAME}' is not registered`
|
|
9
|
+
);
|
|
10
|
+
this.name = "ApprovalQueueUnavailableError";
|
|
11
|
+
this.jobKind = jobKind;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
function getApprovalQueue(runtime) {
|
|
15
|
+
const service = runtime.getService(APPROVAL_QUEUE_SERVICE_NAME);
|
|
16
|
+
if (!service) return null;
|
|
17
|
+
if (typeof service !== "object") return null;
|
|
18
|
+
const candidate = service;
|
|
19
|
+
return typeof candidate.enqueue === "function" ? candidate : null;
|
|
20
|
+
}
|
|
21
|
+
async function enqueueIfSensitive(runtime, jobContext, plan, now = /* @__PURE__ */ new Date()) {
|
|
22
|
+
if (plan.action === null) {
|
|
23
|
+
const result2 = {
|
|
24
|
+
jobKind: jobContext.jobKind,
|
|
25
|
+
plan,
|
|
26
|
+
approvalRequest: null,
|
|
27
|
+
skipped: true,
|
|
28
|
+
skipReason: "planner returned noop"
|
|
29
|
+
};
|
|
30
|
+
recordPlannerDispatch(runtime, result2);
|
|
31
|
+
return result2;
|
|
32
|
+
}
|
|
33
|
+
if (!plan.requiresApproval) {
|
|
34
|
+
const result2 = {
|
|
35
|
+
jobKind: jobContext.jobKind,
|
|
36
|
+
plan,
|
|
37
|
+
approvalRequest: null,
|
|
38
|
+
skipped: true,
|
|
39
|
+
skipReason: "planner marked requiresApproval=false"
|
|
40
|
+
};
|
|
41
|
+
recordPlannerDispatch(runtime, result2);
|
|
42
|
+
return result2;
|
|
43
|
+
}
|
|
44
|
+
if (plan.payload === null) {
|
|
45
|
+
const result2 = {
|
|
46
|
+
jobKind: jobContext.jobKind,
|
|
47
|
+
plan,
|
|
48
|
+
approvalRequest: null,
|
|
49
|
+
skipped: true,
|
|
50
|
+
skipReason: "planner produced sensitive action without usable payload"
|
|
51
|
+
};
|
|
52
|
+
recordPlannerDispatch(runtime, result2);
|
|
53
|
+
logger.warn(
|
|
54
|
+
`[BackgroundPlanner:${jobContext.jobKind}] sensitive action ${plan.action} skipped \u2014 no payload`
|
|
55
|
+
);
|
|
56
|
+
return result2;
|
|
57
|
+
}
|
|
58
|
+
const queue = getApprovalQueue(runtime);
|
|
59
|
+
if (!queue) {
|
|
60
|
+
throw new ApprovalQueueUnavailableError(jobContext.jobKind);
|
|
61
|
+
}
|
|
62
|
+
const input = {
|
|
63
|
+
requestedBy: `background-job:${jobContext.jobKind}`,
|
|
64
|
+
subjectUserId: jobContext.subjectUserId,
|
|
65
|
+
action: plan.action,
|
|
66
|
+
payload: plan.payload,
|
|
67
|
+
channel: plan.channel,
|
|
68
|
+
reason: plan.reason,
|
|
69
|
+
expiresAt: new Date(now.getTime() + DEFAULT_BACKGROUND_APPROVAL_EXPIRY_MS)
|
|
70
|
+
};
|
|
71
|
+
const approvalRequest = await queue.enqueue(input);
|
|
72
|
+
const result = {
|
|
73
|
+
jobKind: jobContext.jobKind,
|
|
74
|
+
plan,
|
|
75
|
+
approvalRequest,
|
|
76
|
+
skipped: false,
|
|
77
|
+
skipReason: null
|
|
78
|
+
};
|
|
79
|
+
recordPlannerDispatch(runtime, result);
|
|
80
|
+
logger.info(
|
|
81
|
+
`[BackgroundPlanner:${jobContext.jobKind}] enqueued approval ${approvalRequest.id} (${plan.action} on ${plan.channel})`
|
|
82
|
+
);
|
|
83
|
+
return result;
|
|
84
|
+
}
|
|
85
|
+
const DISPATCH_LOG_KEY = /* @__PURE__ */ Symbol.for("eliza.lifeops.background-planner.log");
|
|
86
|
+
const DISPATCH_LOG_MAX_ENTRIES = 200;
|
|
87
|
+
function recordPlannerDispatch(runtime, result) {
|
|
88
|
+
const holder = runtime;
|
|
89
|
+
const log = holder[DISPATCH_LOG_KEY] ?? [];
|
|
90
|
+
log.push(result);
|
|
91
|
+
if (log.length > DISPATCH_LOG_MAX_ENTRIES) {
|
|
92
|
+
log.splice(0, log.length - DISPATCH_LOG_MAX_ENTRIES);
|
|
93
|
+
}
|
|
94
|
+
holder[DISPATCH_LOG_KEY] = log;
|
|
95
|
+
}
|
|
96
|
+
function readPlannerDispatchLog(runtime) {
|
|
97
|
+
const holder = runtime;
|
|
98
|
+
return holder[DISPATCH_LOG_KEY] ?? [];
|
|
99
|
+
}
|
|
100
|
+
function resetPlannerDispatchLog(runtime) {
|
|
101
|
+
const holder = runtime;
|
|
102
|
+
holder[DISPATCH_LOG_KEY] = [];
|
|
103
|
+
}
|
|
104
|
+
export {
|
|
105
|
+
APPROVAL_QUEUE_SERVICE_NAME,
|
|
106
|
+
ApprovalQueueUnavailableError,
|
|
107
|
+
DEFAULT_BACKGROUND_APPROVAL_EXPIRY_MS,
|
|
108
|
+
enqueueIfSensitive,
|
|
109
|
+
readPlannerDispatchLog,
|
|
110
|
+
recordPlannerDispatch,
|
|
111
|
+
resetPlannerDispatchLog
|
|
112
|
+
};
|
|
113
|
+
//# sourceMappingURL=background-planner-dispatch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/background-planner-dispatch.ts"],"sourcesContent":["/**\n * WS5 — glue between {@link planJob} and the WS6 approval queue.\n *\n * Every background job calls {@link planJob} and passes the result here.\n * Sensitive actions (`requiresApproval === true` with a usable payload)\n * are enqueued via the queue exposed by the runtime as service\n * \"APPROVAL_QUEUE\". Non-sensitive actions and noops are recorded for\n * observability and returned.\n *\n * No side-effects other than enqueue + logger. No try/catch swallow: a\n * missing queue is a typed error that surfaces to the caller.\n */\n\nimport type { IAgentRuntime } from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport type {\n ApprovalEnqueueInput,\n ApprovalQueue,\n ApprovalRequest,\n} from \"./approval-queue.types.js\";\nimport type {\n BackgroundJobContext,\n TypedJobPlan,\n} from \"./background-planner.js\";\n\nexport const APPROVAL_QUEUE_SERVICE_NAME = \"APPROVAL_QUEUE\" as const;\n\n/** Default expiry window for queued background-job approvals: 24 hours. */\nexport const DEFAULT_BACKGROUND_APPROVAL_EXPIRY_MS = 24 * 60 * 60 * 1000;\n\n/**\n * Raised when a sensitive plan cannot be enqueued because the WS6 queue is\n * not registered on the runtime. We surface this loudly so the bug cannot\n * hide as a silent skip.\n */\nexport class ApprovalQueueUnavailableError extends Error {\n public readonly jobKind: string;\n constructor(jobKind: string) {\n super(\n `[BackgroundPlanner:${jobKind}] approval queue service '${APPROVAL_QUEUE_SERVICE_NAME}' is not registered`,\n );\n this.name = \"ApprovalQueueUnavailableError\";\n this.jobKind = jobKind;\n }\n}\n\nfunction getApprovalQueue(runtime: IAgentRuntime): ApprovalQueue | null {\n const service = runtime.getService(APPROVAL_QUEUE_SERVICE_NAME);\n if (!service) return null;\n if (typeof service !== \"object\") return null;\n const candidate = service as Partial<ApprovalQueue>;\n return typeof candidate.enqueue === \"function\"\n ? (candidate as ApprovalQueue)\n : null;\n}\n\n/**\n * Result returned from {@link enqueueIfSensitive} so callers and tests can\n * introspect what the planner decided for this tick.\n */\nexport interface PlannerDispatchResult {\n readonly jobKind: string;\n readonly plan: TypedJobPlan;\n /** Non-null when a request was enqueued. */\n readonly approvalRequest: ApprovalRequest | null;\n /** True when the plan was a noop or purely internal (no enqueue). */\n readonly skipped: boolean;\n /** When skipped=true, the reason. */\n readonly skipReason: string | null;\n}\n\n/**\n * If the plan is sensitive AND has a usable payload, enqueue it in the WS6\n * approval queue. Otherwise, return a skipped result. Always records the\n * decision to the runtime-scoped observability log via\n * {@link recordPlannerDispatch} so the contract test can introspect.\n */\nexport async function enqueueIfSensitive(\n runtime: IAgentRuntime,\n jobContext: BackgroundJobContext,\n plan: TypedJobPlan,\n now: Date = new Date(),\n): Promise<PlannerDispatchResult> {\n if (plan.action === null) {\n const result: PlannerDispatchResult = {\n jobKind: jobContext.jobKind,\n plan,\n approvalRequest: null,\n skipped: true,\n skipReason: \"planner returned noop\",\n };\n recordPlannerDispatch(runtime, result);\n return result;\n }\n\n if (!plan.requiresApproval) {\n const result: PlannerDispatchResult = {\n jobKind: jobContext.jobKind,\n plan,\n approvalRequest: null,\n skipped: true,\n skipReason: \"planner marked requiresApproval=false\",\n };\n recordPlannerDispatch(runtime, result);\n return result;\n }\n\n if (plan.payload === null) {\n const result: PlannerDispatchResult = {\n jobKind: jobContext.jobKind,\n plan,\n approvalRequest: null,\n skipped: true,\n skipReason: \"planner produced sensitive action without usable payload\",\n };\n recordPlannerDispatch(runtime, result);\n logger.warn(\n `[BackgroundPlanner:${jobContext.jobKind}] sensitive action ${plan.action} skipped — no payload`,\n );\n return result;\n }\n\n const queue = getApprovalQueue(runtime);\n if (!queue) {\n throw new ApprovalQueueUnavailableError(jobContext.jobKind);\n }\n\n const input: ApprovalEnqueueInput = {\n requestedBy: `background-job:${jobContext.jobKind}`,\n subjectUserId: jobContext.subjectUserId,\n action: plan.action,\n payload: plan.payload,\n channel: plan.channel,\n reason: plan.reason,\n expiresAt: new Date(now.getTime() + DEFAULT_BACKGROUND_APPROVAL_EXPIRY_MS),\n };\n\n const approvalRequest = await queue.enqueue(input);\n const result: PlannerDispatchResult = {\n jobKind: jobContext.jobKind,\n plan,\n approvalRequest,\n skipped: false,\n skipReason: null,\n };\n recordPlannerDispatch(runtime, result);\n logger.info(\n `[BackgroundPlanner:${jobContext.jobKind}] enqueued approval ${approvalRequest.id} (${plan.action} on ${plan.channel})`,\n );\n return result;\n}\n\n// ---------------------------------------------------------------------------\n// Test observability\n// ---------------------------------------------------------------------------\n\nconst DISPATCH_LOG_KEY = Symbol.for(\"eliza.lifeops.background-planner.log\");\nconst DISPATCH_LOG_MAX_ENTRIES = 200;\n\ninterface DispatchLogHolder extends IAgentRuntime {\n [DISPATCH_LOG_KEY]?: PlannerDispatchResult[];\n}\n\n/**\n * Record a planner dispatch decision on the runtime object so the contract\n * test can inspect every invocation without racing against the real\n * approval queue or LLM. Bounded to DISPATCH_LOG_MAX_ENTRIES to prevent the\n * log from growing unbounded on long-lived runtimes.\n */\nexport function recordPlannerDispatch(\n runtime: IAgentRuntime,\n result: PlannerDispatchResult,\n): void {\n const holder = runtime as DispatchLogHolder;\n const log = holder[DISPATCH_LOG_KEY] ?? [];\n log.push(result);\n if (log.length > DISPATCH_LOG_MAX_ENTRIES) {\n log.splice(0, log.length - DISPATCH_LOG_MAX_ENTRIES);\n }\n holder[DISPATCH_LOG_KEY] = log;\n}\n\n/** Test-only: read the in-memory dispatch log for a runtime. */\nexport function readPlannerDispatchLog(\n runtime: IAgentRuntime,\n): ReadonlyArray<PlannerDispatchResult> {\n const holder = runtime as DispatchLogHolder;\n return holder[DISPATCH_LOG_KEY] ?? [];\n}\n\n/** Test-only: clear the dispatch log between runs. */\nexport function resetPlannerDispatchLog(runtime: IAgentRuntime): void {\n const holder = runtime as DispatchLogHolder;\n holder[DISPATCH_LOG_KEY] = [];\n}\n"],"mappings":"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","names":["result"]}
|