@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,53 @@
|
|
|
1
|
+
import { type LifeOpsSchedulingNegotiation, type LifeOpsSchedulingProposal } from "@elizaos/shared";
|
|
2
|
+
import { type LifeOpsScheduleInspection, type LifeOpsScheduleSummary } from "./schedule-insight.js";
|
|
3
|
+
import type { Constructor, LifeOpsServiceBase, MixinClass } from "./service-mixin-core.js";
|
|
4
|
+
/**
|
|
5
|
+
* Channels that a negotiation dispatch can be delivered on, resolved from
|
|
6
|
+
* the linked relationship's contact info. Ordered so that richer / more
|
|
7
|
+
* reliable channels are preferred when `primaryChannel` is ambiguous.
|
|
8
|
+
*/
|
|
9
|
+
declare const SCHEDULING_DISPATCH_CHANNELS: readonly ["email", "telegram", "discord", "signal", "whatsapp", "imessage", "sms"];
|
|
10
|
+
type SchedulingDispatchChannel = (typeof SCHEDULING_DISPATCH_CHANNELS)[number];
|
|
11
|
+
type CounterpartyTarget = {
|
|
12
|
+
channel: SchedulingDispatchChannel;
|
|
13
|
+
target: string;
|
|
14
|
+
name: string;
|
|
15
|
+
};
|
|
16
|
+
export interface LifeOpsSchedulingService {
|
|
17
|
+
inspectSchedule(args: {
|
|
18
|
+
timezone: string;
|
|
19
|
+
now?: Date;
|
|
20
|
+
}): Promise<LifeOpsScheduleInspection>;
|
|
21
|
+
readScheduleSummary(args: {
|
|
22
|
+
timezone: string;
|
|
23
|
+
now?: Date;
|
|
24
|
+
}): Promise<LifeOpsScheduleSummary>;
|
|
25
|
+
resolveCounterpartyTarget(negotiation: LifeOpsSchedulingNegotiation): Promise<CounterpartyTarget | null>;
|
|
26
|
+
dispatchSchedulingMessage(negotiation: LifeOpsSchedulingNegotiation, body: string, subject: string): Promise<CounterpartyTarget>;
|
|
27
|
+
startNegotiation(input: {
|
|
28
|
+
subject: string;
|
|
29
|
+
relationshipId?: string | null;
|
|
30
|
+
durationMinutes?: number;
|
|
31
|
+
timezone?: string;
|
|
32
|
+
metadata?: Record<string, unknown>;
|
|
33
|
+
}): Promise<LifeOpsSchedulingNegotiation>;
|
|
34
|
+
getNegotiation(id: string): Promise<LifeOpsSchedulingNegotiation | null>;
|
|
35
|
+
listActiveNegotiations(opts?: {
|
|
36
|
+
limit?: number;
|
|
37
|
+
}): Promise<LifeOpsSchedulingNegotiation[]>;
|
|
38
|
+
proposeTime(input: {
|
|
39
|
+
negotiationId: string;
|
|
40
|
+
startAt: string;
|
|
41
|
+
endAt: string;
|
|
42
|
+
proposedBy: "agent" | "owner" | "counterparty";
|
|
43
|
+
metadata?: Record<string, unknown>;
|
|
44
|
+
}): Promise<LifeOpsSchedulingProposal>;
|
|
45
|
+
respondToProposal(proposalId: string, status: "accepted" | "declined" | "expired"): Promise<LifeOpsSchedulingProposal>;
|
|
46
|
+
finalizeNegotiation(id: string, acceptedProposalId: string): Promise<LifeOpsSchedulingNegotiation>;
|
|
47
|
+
cancelNegotiation(id: string, reason?: string): Promise<void>;
|
|
48
|
+
listProposals(negotiationId: string): Promise<LifeOpsSchedulingProposal[]>;
|
|
49
|
+
}
|
|
50
|
+
/** @internal */
|
|
51
|
+
export declare function withScheduling<TBase extends Constructor<LifeOpsServiceBase>>(Base: TBase): MixinClass<TBase, LifeOpsSchedulingService>;
|
|
52
|
+
export {};
|
|
53
|
+
//# sourceMappingURL=service-mixin-scheduling.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-mixin-scheduling.d.ts","sourceRoot":"","sources":["../../src/lifeops/service-mixin-scheduling.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,405 @@
|
|
|
1
|
+
import crypto from "node:crypto";
|
|
2
|
+
import {
|
|
3
|
+
LIFEOPS_NEGOTIATION_STATES
|
|
4
|
+
} from "@elizaos/shared";
|
|
5
|
+
import {
|
|
6
|
+
contactEdgeId,
|
|
7
|
+
lifeOpsRelationshipFromEntity
|
|
8
|
+
} from "./relationships/mapping.js";
|
|
9
|
+
import {
|
|
10
|
+
inspectLifeOpsSchedule,
|
|
11
|
+
readScheduleSummary
|
|
12
|
+
} from "./schedule-insight.js";
|
|
13
|
+
import { fail } from "./service-normalize.js";
|
|
14
|
+
function isoNow() {
|
|
15
|
+
return (/* @__PURE__ */ new Date()).toISOString();
|
|
16
|
+
}
|
|
17
|
+
const SCHEDULING_DISPATCH_CHANNELS = [
|
|
18
|
+
"email",
|
|
19
|
+
"telegram",
|
|
20
|
+
"discord",
|
|
21
|
+
"signal",
|
|
22
|
+
"whatsapp",
|
|
23
|
+
"imessage",
|
|
24
|
+
"sms"
|
|
25
|
+
];
|
|
26
|
+
function normalizeChannel(value) {
|
|
27
|
+
if (typeof value !== "string") return null;
|
|
28
|
+
const trimmed = value.trim().toLowerCase();
|
|
29
|
+
return SCHEDULING_DISPATCH_CHANNELS.includes(trimmed) ? trimmed : null;
|
|
30
|
+
}
|
|
31
|
+
function withScheduling(Base) {
|
|
32
|
+
const SchedulingBase = Base;
|
|
33
|
+
class LifeOpsSchedulingServiceMixin extends SchedulingBase {
|
|
34
|
+
async inspectSchedule(args) {
|
|
35
|
+
return await inspectLifeOpsSchedule({
|
|
36
|
+
runtime: this.runtime,
|
|
37
|
+
repository: this.repository,
|
|
38
|
+
agentId: this.agentId(),
|
|
39
|
+
timezone: args.timezone,
|
|
40
|
+
now: args.now
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Read-only schedule summary for UI surfaces. Pulls the last persisted
|
|
45
|
+
* merged state + last 7 days of sleep episodes without triggering any
|
|
46
|
+
* probes. Use this instead of {@link inspectSchedule} from the UI.
|
|
47
|
+
*/
|
|
48
|
+
async readScheduleSummary(args) {
|
|
49
|
+
return await readScheduleSummary({
|
|
50
|
+
repository: this.repository,
|
|
51
|
+
agentId: this.agentId(),
|
|
52
|
+
timezone: args.timezone,
|
|
53
|
+
now: args.now
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Resolve the counterparty's channel + target from the relationship
|
|
58
|
+
* linked to the negotiation. Returns null if no linked relationship, and
|
|
59
|
+
* fails with `SCHEDULING_NO_COUNTERPARTY_CONTACT` if the relationship has
|
|
60
|
+
* no usable contact info.
|
|
61
|
+
*/
|
|
62
|
+
async resolveCounterpartyTarget(negotiation) {
|
|
63
|
+
if (!negotiation.relationshipId) {
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
66
|
+
const agentId = this.agentId();
|
|
67
|
+
const entityStore = await this.repository.entityStore(agentId);
|
|
68
|
+
const entity = await entityStore.get(negotiation.relationshipId);
|
|
69
|
+
if (!entity) {
|
|
70
|
+
fail(
|
|
71
|
+
404,
|
|
72
|
+
`SCHEDULING_NO_COUNTERPARTY_CONTACT: relationship ${negotiation.relationshipId} not found for negotiation ${negotiation.id}`
|
|
73
|
+
);
|
|
74
|
+
}
|
|
75
|
+
const relationshipStore = await this.repository.relationshipStore(agentId);
|
|
76
|
+
const edge = await relationshipStore.get(
|
|
77
|
+
contactEdgeId(negotiation.relationshipId)
|
|
78
|
+
);
|
|
79
|
+
const relationship = lifeOpsRelationshipFromEntity(agentId, entity, edge);
|
|
80
|
+
const primaryChannel = normalizeChannel(relationship.primaryChannel);
|
|
81
|
+
const primaryHandle = typeof relationship.primaryHandle === "string" ? relationship.primaryHandle.trim() : "";
|
|
82
|
+
if (primaryChannel && primaryHandle) {
|
|
83
|
+
return {
|
|
84
|
+
channel: primaryChannel,
|
|
85
|
+
target: primaryHandle,
|
|
86
|
+
name: relationship.name
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
const email = typeof relationship.email === "string" ? relationship.email.trim() : "";
|
|
90
|
+
if (email) {
|
|
91
|
+
return { channel: "email", target: email, name: relationship.name };
|
|
92
|
+
}
|
|
93
|
+
const phone = typeof relationship.phone === "string" ? relationship.phone.trim() : "";
|
|
94
|
+
if (phone) {
|
|
95
|
+
return { channel: "sms", target: phone, name: relationship.name };
|
|
96
|
+
}
|
|
97
|
+
fail(
|
|
98
|
+
409,
|
|
99
|
+
`SCHEDULING_NO_COUNTERPARTY_CONTACT: relationship ${relationship.id} has no usable contact (primaryChannel/primaryHandle, email, or phone)`
|
|
100
|
+
);
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Dispatch a plain message to the counterparty via an existing send
|
|
104
|
+
* path. Fails (propagates the dispatch error) so the caller does not
|
|
105
|
+
* report success when delivery actually failed.
|
|
106
|
+
*/
|
|
107
|
+
async dispatchSchedulingMessage(negotiation, body, subject) {
|
|
108
|
+
const contact = await this.resolveCounterpartyTarget(negotiation);
|
|
109
|
+
if (!contact) {
|
|
110
|
+
fail(
|
|
111
|
+
409,
|
|
112
|
+
`SCHEDULING_NO_COUNTERPARTY_CONTACT: negotiation ${negotiation.id} has no relationshipId; cannot deliver message`
|
|
113
|
+
);
|
|
114
|
+
}
|
|
115
|
+
try {
|
|
116
|
+
switch (contact.channel) {
|
|
117
|
+
case "email": {
|
|
118
|
+
const requestUrl = new URL(
|
|
119
|
+
"http://internal.invalid/lifeops/gmail/send"
|
|
120
|
+
);
|
|
121
|
+
await this.sendGmailMessage(requestUrl, {
|
|
122
|
+
to: [contact.target],
|
|
123
|
+
subject,
|
|
124
|
+
bodyText: body,
|
|
125
|
+
confirmSend: true
|
|
126
|
+
});
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
case "telegram": {
|
|
130
|
+
await this.sendTelegramMessage({
|
|
131
|
+
target: contact.target,
|
|
132
|
+
message: body
|
|
133
|
+
});
|
|
134
|
+
break;
|
|
135
|
+
}
|
|
136
|
+
case "whatsapp": {
|
|
137
|
+
await this.sendWhatsAppMessage({
|
|
138
|
+
to: contact.target,
|
|
139
|
+
text: body
|
|
140
|
+
});
|
|
141
|
+
break;
|
|
142
|
+
}
|
|
143
|
+
case "imessage": {
|
|
144
|
+
await this.sendIMessage({
|
|
145
|
+
to: contact.target,
|
|
146
|
+
text: body
|
|
147
|
+
});
|
|
148
|
+
break;
|
|
149
|
+
}
|
|
150
|
+
case "discord":
|
|
151
|
+
case "signal": {
|
|
152
|
+
if (typeof this.runtime.sendMessageToTarget !== "function") {
|
|
153
|
+
fail(
|
|
154
|
+
501,
|
|
155
|
+
`SCHEDULING_DISPATCH_UNAVAILABLE: runtime has no sendMessageToTarget for channel ${contact.channel}`
|
|
156
|
+
);
|
|
157
|
+
}
|
|
158
|
+
await this.runtime.sendMessageToTarget(
|
|
159
|
+
{
|
|
160
|
+
source: contact.channel,
|
|
161
|
+
channelId: contact.target
|
|
162
|
+
},
|
|
163
|
+
{ text: body, source: contact.channel }
|
|
164
|
+
);
|
|
165
|
+
break;
|
|
166
|
+
}
|
|
167
|
+
case "sms": {
|
|
168
|
+
return fail(
|
|
169
|
+
501,
|
|
170
|
+
`SCHEDULING_DISPATCH_UNAVAILABLE: sms dispatch for scheduling is not wired (counterparty phone=${contact.target}). Use MESSAGE operation=send_draft for SMS.`
|
|
171
|
+
);
|
|
172
|
+
}
|
|
173
|
+
default: {
|
|
174
|
+
return fail(
|
|
175
|
+
501,
|
|
176
|
+
`SCHEDULING_DISPATCH_UNAVAILABLE: unsupported channel ${contact.channel}`
|
|
177
|
+
);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
} catch (error) {
|
|
181
|
+
if (error && typeof error === "object" && error.name === "LifeOpsServiceError") {
|
|
182
|
+
throw error;
|
|
183
|
+
}
|
|
184
|
+
fail(
|
|
185
|
+
502,
|
|
186
|
+
`SCHEDULING_DISPATCH_FAILED: ${contact.channel} send to ${contact.target} failed: ${error instanceof Error ? error.message : String(error)}`
|
|
187
|
+
);
|
|
188
|
+
}
|
|
189
|
+
return contact;
|
|
190
|
+
}
|
|
191
|
+
async startNegotiation(input) {
|
|
192
|
+
const subject = input.subject.trim();
|
|
193
|
+
if (!subject) {
|
|
194
|
+
fail(400, "subject is required");
|
|
195
|
+
}
|
|
196
|
+
const now = isoNow();
|
|
197
|
+
const negotiation = {
|
|
198
|
+
id: crypto.randomUUID(),
|
|
199
|
+
agentId: this.agentId(),
|
|
200
|
+
subject,
|
|
201
|
+
relationshipId: input.relationshipId ?? null,
|
|
202
|
+
durationMinutes: typeof input.durationMinutes === "number" && input.durationMinutes > 0 ? Math.floor(input.durationMinutes) : 30,
|
|
203
|
+
timezone: input.timezone ?? "UTC",
|
|
204
|
+
state: "initiated",
|
|
205
|
+
acceptedProposalId: null,
|
|
206
|
+
startedAt: now,
|
|
207
|
+
finalizedAt: null,
|
|
208
|
+
metadata: input.metadata ?? {},
|
|
209
|
+
createdAt: now,
|
|
210
|
+
updatedAt: now
|
|
211
|
+
};
|
|
212
|
+
await this.repository.upsertSchedulingNegotiation(negotiation);
|
|
213
|
+
const subjectLine = `Scheduling: ${negotiation.subject}`;
|
|
214
|
+
const body = `Hi,
|
|
215
|
+
|
|
216
|
+
I'd like to set up "${negotiation.subject}" (roughly ${negotiation.durationMinutes} minutes, ${negotiation.timezone}). I'll follow up with specific proposed times shortly.
|
|
217
|
+
|
|
218
|
+
Reference: ${negotiation.id}`;
|
|
219
|
+
await this.dispatchSchedulingMessage(negotiation, body, subjectLine);
|
|
220
|
+
return negotiation;
|
|
221
|
+
}
|
|
222
|
+
async getNegotiation(id) {
|
|
223
|
+
return this.repository.getSchedulingNegotiation(this.agentId(), id);
|
|
224
|
+
}
|
|
225
|
+
async listActiveNegotiations(opts) {
|
|
226
|
+
const all = await this.repository.listSchedulingNegotiations(
|
|
227
|
+
this.agentId(),
|
|
228
|
+
{ limit: opts?.limit }
|
|
229
|
+
);
|
|
230
|
+
return all.filter(
|
|
231
|
+
(n) => n.state !== "confirmed" && n.state !== "cancelled"
|
|
232
|
+
);
|
|
233
|
+
}
|
|
234
|
+
async proposeTime(input) {
|
|
235
|
+
const negotiation = await this.repository.getSchedulingNegotiation(
|
|
236
|
+
this.agentId(),
|
|
237
|
+
input.negotiationId
|
|
238
|
+
);
|
|
239
|
+
if (!negotiation) {
|
|
240
|
+
fail(404, `negotiation ${input.negotiationId} not found`);
|
|
241
|
+
}
|
|
242
|
+
if (negotiation.state === "confirmed" || negotiation.state === "cancelled") {
|
|
243
|
+
fail(
|
|
244
|
+
409,
|
|
245
|
+
`cannot propose on negotiation in state ${negotiation.state}`
|
|
246
|
+
);
|
|
247
|
+
}
|
|
248
|
+
if (!LIFEOPS_NEGOTIATION_STATES.includes(negotiation.state)) {
|
|
249
|
+
fail(500, `unexpected negotiation state ${negotiation.state}`);
|
|
250
|
+
}
|
|
251
|
+
const startMs = Date.parse(input.startAt);
|
|
252
|
+
const endMs = Date.parse(input.endAt);
|
|
253
|
+
if (!Number.isFinite(startMs) || !Number.isFinite(endMs)) {
|
|
254
|
+
fail(400, "startAt/endAt must be valid ISO-8601 timestamps");
|
|
255
|
+
}
|
|
256
|
+
if (endMs <= startMs) {
|
|
257
|
+
fail(400, "endAt must be after startAt");
|
|
258
|
+
}
|
|
259
|
+
const now = isoNow();
|
|
260
|
+
const proposal = {
|
|
261
|
+
id: crypto.randomUUID(),
|
|
262
|
+
agentId: this.agentId(),
|
|
263
|
+
negotiationId: negotiation.id,
|
|
264
|
+
startAt: new Date(startMs).toISOString(),
|
|
265
|
+
endAt: new Date(endMs).toISOString(),
|
|
266
|
+
proposedBy: input.proposedBy,
|
|
267
|
+
status: "pending",
|
|
268
|
+
metadata: input.metadata ?? {},
|
|
269
|
+
createdAt: now,
|
|
270
|
+
updatedAt: now
|
|
271
|
+
};
|
|
272
|
+
await this.repository.upsertSchedulingProposal(proposal);
|
|
273
|
+
if (negotiation.state === "initiated" || negotiation.state === "awaiting_response") {
|
|
274
|
+
await this.repository.updateSchedulingNegotiationState(
|
|
275
|
+
this.agentId(),
|
|
276
|
+
negotiation.id,
|
|
277
|
+
"proposals_sent"
|
|
278
|
+
);
|
|
279
|
+
}
|
|
280
|
+
if (input.proposedBy !== "counterparty") {
|
|
281
|
+
const subjectLine = `Scheduling: ${negotiation.subject}`;
|
|
282
|
+
const body = `Proposed time for "${negotiation.subject}":
|
|
283
|
+
Start: ${proposal.startAt}
|
|
284
|
+
End: ${proposal.endAt}
|
|
285
|
+
(${negotiation.durationMinutes} min, ${negotiation.timezone})
|
|
286
|
+
|
|
287
|
+
Let me know if this works or suggest a different slot.
|
|
288
|
+
|
|
289
|
+
Reference: ${negotiation.id} / ${proposal.id}`;
|
|
290
|
+
await this.dispatchSchedulingMessage(negotiation, body, subjectLine);
|
|
291
|
+
}
|
|
292
|
+
return proposal;
|
|
293
|
+
}
|
|
294
|
+
async respondToProposal(proposalId, status) {
|
|
295
|
+
const proposal = await this.repository.getSchedulingProposal(
|
|
296
|
+
this.agentId(),
|
|
297
|
+
proposalId
|
|
298
|
+
);
|
|
299
|
+
if (!proposal) {
|
|
300
|
+
fail(404, `proposal ${proposalId} not found`);
|
|
301
|
+
}
|
|
302
|
+
if (proposal.status !== "pending") {
|
|
303
|
+
fail(409, `proposal already in terminal status ${proposal.status}`);
|
|
304
|
+
}
|
|
305
|
+
await this.repository.updateSchedulingProposalStatus(
|
|
306
|
+
this.agentId(),
|
|
307
|
+
proposalId,
|
|
308
|
+
status
|
|
309
|
+
);
|
|
310
|
+
const updated = await this.repository.getSchedulingProposal(
|
|
311
|
+
this.agentId(),
|
|
312
|
+
proposalId
|
|
313
|
+
);
|
|
314
|
+
if (!updated) {
|
|
315
|
+
fail(500, "proposal disappeared after update");
|
|
316
|
+
}
|
|
317
|
+
return updated;
|
|
318
|
+
}
|
|
319
|
+
async finalizeNegotiation(id, acceptedProposalId) {
|
|
320
|
+
const negotiation = await this.repository.getSchedulingNegotiation(
|
|
321
|
+
this.agentId(),
|
|
322
|
+
id
|
|
323
|
+
);
|
|
324
|
+
if (!negotiation) {
|
|
325
|
+
fail(404, `negotiation ${id} not found`);
|
|
326
|
+
}
|
|
327
|
+
if (negotiation.state === "cancelled") {
|
|
328
|
+
fail(409, "cannot finalize cancelled negotiation");
|
|
329
|
+
}
|
|
330
|
+
const proposal = await this.repository.getSchedulingProposal(
|
|
331
|
+
this.agentId(),
|
|
332
|
+
acceptedProposalId
|
|
333
|
+
);
|
|
334
|
+
if (!proposal || proposal.negotiationId !== id) {
|
|
335
|
+
fail(
|
|
336
|
+
404,
|
|
337
|
+
`proposal ${acceptedProposalId} not found for negotiation ${id}`
|
|
338
|
+
);
|
|
339
|
+
}
|
|
340
|
+
if (proposal.status !== "accepted") {
|
|
341
|
+
fail(
|
|
342
|
+
409,
|
|
343
|
+
`proposal ${acceptedProposalId} is not accepted (status=${proposal.status})`
|
|
344
|
+
);
|
|
345
|
+
}
|
|
346
|
+
const now = isoNow();
|
|
347
|
+
const updated = {
|
|
348
|
+
...negotiation,
|
|
349
|
+
state: "confirmed",
|
|
350
|
+
acceptedProposalId,
|
|
351
|
+
finalizedAt: now,
|
|
352
|
+
updatedAt: now
|
|
353
|
+
};
|
|
354
|
+
await this.repository.upsertSchedulingNegotiation(updated);
|
|
355
|
+
const subjectLine = `Confirmed: ${updated.subject}`;
|
|
356
|
+
const body = `Confirming "${updated.subject}":
|
|
357
|
+
Start: ${proposal.startAt}
|
|
358
|
+
End: ${proposal.endAt}
|
|
359
|
+
(${updated.durationMinutes} min, ${updated.timezone})
|
|
360
|
+
|
|
361
|
+
See you then.
|
|
362
|
+
|
|
363
|
+
Reference: ${updated.id} / ${proposal.id}`;
|
|
364
|
+
await this.dispatchSchedulingMessage(updated, body, subjectLine);
|
|
365
|
+
return updated;
|
|
366
|
+
}
|
|
367
|
+
async cancelNegotiation(id, reason) {
|
|
368
|
+
const negotiation = await this.repository.getSchedulingNegotiation(
|
|
369
|
+
this.agentId(),
|
|
370
|
+
id
|
|
371
|
+
);
|
|
372
|
+
if (!negotiation) {
|
|
373
|
+
fail(404, `negotiation ${id} not found`);
|
|
374
|
+
}
|
|
375
|
+
const nextMetadata = {
|
|
376
|
+
...negotiation.metadata,
|
|
377
|
+
...reason ? { cancellationReason: reason } : {}
|
|
378
|
+
};
|
|
379
|
+
const now = isoNow();
|
|
380
|
+
const updated = {
|
|
381
|
+
...negotiation,
|
|
382
|
+
state: "cancelled",
|
|
383
|
+
metadata: nextMetadata,
|
|
384
|
+
updatedAt: now
|
|
385
|
+
};
|
|
386
|
+
await this.repository.upsertSchedulingNegotiation(updated);
|
|
387
|
+
const subjectLine = `Cancelled: ${updated.subject}`;
|
|
388
|
+
const body = `Cancelling "${updated.subject}"` + (reason ? ` \u2014 ${reason}.` : ".") + `
|
|
389
|
+
|
|
390
|
+
Reference: ${updated.id}`;
|
|
391
|
+
await this.dispatchSchedulingMessage(updated, body, subjectLine);
|
|
392
|
+
}
|
|
393
|
+
async listProposals(negotiationId) {
|
|
394
|
+
return this.repository.listSchedulingProposals(
|
|
395
|
+
this.agentId(),
|
|
396
|
+
negotiationId
|
|
397
|
+
);
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
return LifeOpsSchedulingServiceMixin;
|
|
401
|
+
}
|
|
402
|
+
export {
|
|
403
|
+
withScheduling
|
|
404
|
+
};
|
|
405
|
+
//# sourceMappingURL=service-mixin-scheduling.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/service-mixin-scheduling.ts"],"sourcesContent":["import crypto from \"node:crypto\";\nimport {\n LIFEOPS_NEGOTIATION_STATES,\n type LifeOpsSchedulingNegotiation,\n type LifeOpsSchedulingProposal,\n} from \"@elizaos/shared\";\nimport {\n contactEdgeId,\n lifeOpsRelationshipFromEntity,\n} from \"./relationships/mapping.js\";\nimport {\n inspectLifeOpsSchedule,\n type LifeOpsScheduleInspection,\n type LifeOpsScheduleSummary,\n readScheduleSummary,\n} from \"./schedule-insight.js\";\nimport type {\n Constructor,\n LifeOpsServiceBase,\n MixinClass,\n} from \"./service-mixin-core.js\";\nimport { fail } from \"./service-normalize.js\";\n\nfunction isoNow(): string {\n return new Date().toISOString();\n}\n\n/**\n * Channels that a negotiation dispatch can be delivered on, resolved from\n * the linked relationship's contact info. Ordered so that richer / more\n * reliable channels are preferred when `primaryChannel` is ambiguous.\n */\nconst SCHEDULING_DISPATCH_CHANNELS = [\n \"email\",\n \"telegram\",\n \"discord\",\n \"signal\",\n \"whatsapp\",\n \"imessage\",\n \"sms\",\n] as const;\ntype SchedulingDispatchChannel = (typeof SCHEDULING_DISPATCH_CHANNELS)[number];\n\ntype CounterpartyTarget = {\n channel: SchedulingDispatchChannel;\n target: string;\n name: string;\n};\n\ntype SchedulingMixinDependencies = LifeOpsServiceBase & {\n sendGmailMessage(\n requestUrl: URL,\n request: {\n to: string[];\n subject: string;\n bodyText: string;\n confirmSend: boolean;\n },\n ): Promise<unknown>;\n sendTelegramMessage(request: {\n target: string;\n message: string;\n }): Promise<unknown>;\n sendWhatsAppMessage(request: { to: string; text: string }): Promise<unknown>;\n sendIMessage(request: { to: string; text: string }): Promise<unknown>;\n};\n\nexport interface LifeOpsSchedulingService {\n inspectSchedule(args: {\n timezone: string;\n now?: Date;\n }): Promise<LifeOpsScheduleInspection>;\n readScheduleSummary(args: {\n timezone: string;\n now?: Date;\n }): Promise<LifeOpsScheduleSummary>;\n resolveCounterpartyTarget(\n negotiation: LifeOpsSchedulingNegotiation,\n ): Promise<CounterpartyTarget | null>;\n dispatchSchedulingMessage(\n negotiation: LifeOpsSchedulingNegotiation,\n body: string,\n subject: string,\n ): Promise<CounterpartyTarget>;\n startNegotiation(input: {\n subject: string;\n relationshipId?: string | null;\n durationMinutes?: number;\n timezone?: string;\n metadata?: Record<string, unknown>;\n }): Promise<LifeOpsSchedulingNegotiation>;\n getNegotiation(id: string): Promise<LifeOpsSchedulingNegotiation | null>;\n listActiveNegotiations(opts?: {\n limit?: number;\n }): Promise<LifeOpsSchedulingNegotiation[]>;\n proposeTime(input: {\n negotiationId: string;\n startAt: string;\n endAt: string;\n proposedBy: \"agent\" | \"owner\" | \"counterparty\";\n metadata?: Record<string, unknown>;\n }): Promise<LifeOpsSchedulingProposal>;\n respondToProposal(\n proposalId: string,\n status: \"accepted\" | \"declined\" | \"expired\",\n ): Promise<LifeOpsSchedulingProposal>;\n finalizeNegotiation(\n id: string,\n acceptedProposalId: string,\n ): Promise<LifeOpsSchedulingNegotiation>;\n cancelNegotiation(id: string, reason?: string): Promise<void>;\n listProposals(negotiationId: string): Promise<LifeOpsSchedulingProposal[]>;\n}\n\nfunction normalizeChannel(\n value: string | null | undefined,\n): SchedulingDispatchChannel | null {\n if (typeof value !== \"string\") return null;\n const trimmed = value.trim().toLowerCase();\n return (SCHEDULING_DISPATCH_CHANNELS as readonly string[]).includes(trimmed)\n ? (trimmed as SchedulingDispatchChannel)\n : null;\n}\n\n/** @internal */\nexport function withScheduling<TBase extends Constructor<LifeOpsServiceBase>>(\n Base: TBase,\n): MixinClass<TBase, LifeOpsSchedulingService> {\n const SchedulingBase =\n Base as unknown as Constructor<SchedulingMixinDependencies>;\n\n class LifeOpsSchedulingServiceMixin extends SchedulingBase {\n async inspectSchedule(args: {\n timezone: string;\n now?: Date;\n }): Promise<LifeOpsScheduleInspection> {\n return await inspectLifeOpsSchedule({\n runtime: this.runtime,\n repository: this.repository,\n agentId: this.agentId(),\n timezone: args.timezone,\n now: args.now,\n });\n }\n\n /**\n * Read-only schedule summary for UI surfaces. Pulls the last persisted\n * merged state + last 7 days of sleep episodes without triggering any\n * probes. Use this instead of {@link inspectSchedule} from the UI.\n */\n async readScheduleSummary(args: {\n timezone: string;\n now?: Date;\n }): Promise<LifeOpsScheduleSummary> {\n return await readScheduleSummary({\n repository: this.repository,\n agentId: this.agentId(),\n timezone: args.timezone,\n now: args.now,\n });\n }\n\n /**\n * Resolve the counterparty's channel + target from the relationship\n * linked to the negotiation. Returns null if no linked relationship, and\n * fails with `SCHEDULING_NO_COUNTERPARTY_CONTACT` if the relationship has\n * no usable contact info.\n */\n async resolveCounterpartyTarget(\n negotiation: LifeOpsSchedulingNegotiation,\n ): Promise<CounterpartyTarget | null> {\n if (!negotiation.relationshipId) {\n return null;\n }\n const agentId = this.agentId();\n const entityStore = await this.repository.entityStore(agentId);\n const entity = await entityStore.get(negotiation.relationshipId);\n if (!entity) {\n fail(\n 404,\n `SCHEDULING_NO_COUNTERPARTY_CONTACT: relationship ${negotiation.relationshipId} not found for negotiation ${negotiation.id}`,\n );\n }\n const relationshipStore =\n await this.repository.relationshipStore(agentId);\n const edge = await relationshipStore.get(\n contactEdgeId(negotiation.relationshipId),\n );\n const relationship = lifeOpsRelationshipFromEntity(agentId, entity, edge);\n\n const primaryChannel = normalizeChannel(relationship.primaryChannel);\n const primaryHandle =\n typeof relationship.primaryHandle === \"string\"\n ? relationship.primaryHandle.trim()\n : \"\";\n if (primaryChannel && primaryHandle) {\n return {\n channel: primaryChannel,\n target: primaryHandle,\n name: relationship.name,\n };\n }\n const email =\n typeof relationship.email === \"string\" ? relationship.email.trim() : \"\";\n if (email) {\n return { channel: \"email\", target: email, name: relationship.name };\n }\n const phone =\n typeof relationship.phone === \"string\" ? relationship.phone.trim() : \"\";\n if (phone) {\n return { channel: \"sms\", target: phone, name: relationship.name };\n }\n fail(\n 409,\n `SCHEDULING_NO_COUNTERPARTY_CONTACT: relationship ${relationship.id} has no usable contact (primaryChannel/primaryHandle, email, or phone)`,\n );\n }\n\n /**\n * Dispatch a plain message to the counterparty via an existing send\n * path. Fails (propagates the dispatch error) so the caller does not\n * report success when delivery actually failed.\n */\n async dispatchSchedulingMessage(\n negotiation: LifeOpsSchedulingNegotiation,\n body: string,\n subject: string,\n ): Promise<CounterpartyTarget> {\n const contact = await this.resolveCounterpartyTarget(negotiation);\n if (!contact) {\n fail(\n 409,\n `SCHEDULING_NO_COUNTERPARTY_CONTACT: negotiation ${negotiation.id} has no relationshipId; cannot deliver message`,\n );\n }\n try {\n switch (contact.channel) {\n case \"email\": {\n const requestUrl = new URL(\n \"http://internal.invalid/lifeops/gmail/send\",\n );\n await this.sendGmailMessage(requestUrl, {\n to: [contact.target],\n subject,\n bodyText: body,\n confirmSend: true,\n });\n break;\n }\n case \"telegram\": {\n await this.sendTelegramMessage({\n target: contact.target,\n message: body,\n });\n break;\n }\n case \"whatsapp\": {\n await this.sendWhatsAppMessage({\n to: contact.target,\n text: body,\n });\n break;\n }\n case \"imessage\": {\n await this.sendIMessage({\n to: contact.target,\n text: body,\n });\n break;\n }\n case \"discord\":\n case \"signal\": {\n if (typeof this.runtime.sendMessageToTarget !== \"function\") {\n fail(\n 501,\n `SCHEDULING_DISPATCH_UNAVAILABLE: runtime has no sendMessageToTarget for channel ${contact.channel}`,\n );\n }\n await this.runtime.sendMessageToTarget(\n {\n source: contact.channel,\n channelId: contact.target,\n } as Parameters<typeof this.runtime.sendMessageToTarget>[0],\n { text: body, source: contact.channel },\n );\n break;\n }\n case \"sms\": {\n return fail(\n 501,\n `SCHEDULING_DISPATCH_UNAVAILABLE: sms dispatch for scheduling is not wired (counterparty phone=${contact.target}). Use MESSAGE operation=send_draft for SMS.`,\n );\n }\n default: {\n return fail(\n 501,\n `SCHEDULING_DISPATCH_UNAVAILABLE: unsupported channel ${contact.channel}`,\n );\n }\n }\n } catch (error) {\n // Re-throw LifeOpsServiceError as-is; wrap other errors so the caller\n // can map them to a structured failure instead of silently\n // claiming success.\n if (\n error &&\n typeof error === \"object\" &&\n (error as { name?: string }).name === \"LifeOpsServiceError\"\n ) {\n throw error;\n }\n fail(\n 502,\n `SCHEDULING_DISPATCH_FAILED: ${contact.channel} send to ${contact.target} failed: ${\n error instanceof Error ? error.message : String(error)\n }`,\n );\n }\n return contact;\n }\n\n async startNegotiation(input: {\n subject: string;\n relationshipId?: string | null;\n durationMinutes?: number;\n timezone?: string;\n metadata?: Record<string, unknown>;\n }): Promise<LifeOpsSchedulingNegotiation> {\n const subject = input.subject.trim();\n if (!subject) {\n fail(400, \"subject is required\");\n }\n const now = isoNow();\n const negotiation: LifeOpsSchedulingNegotiation = {\n id: crypto.randomUUID(),\n agentId: this.agentId(),\n subject,\n relationshipId: input.relationshipId ?? null,\n durationMinutes:\n typeof input.durationMinutes === \"number\" && input.durationMinutes > 0\n ? Math.floor(input.durationMinutes)\n : 30,\n timezone: input.timezone ?? \"UTC\",\n state: \"initiated\",\n acceptedProposalId: null,\n startedAt: now,\n finalizedAt: null,\n metadata: input.metadata ?? {},\n createdAt: now,\n updatedAt: now,\n };\n await this.repository.upsertSchedulingNegotiation(negotiation);\n\n const subjectLine = `Scheduling: ${negotiation.subject}`;\n const body =\n `Hi,\\n\\nI'd like to set up \"${negotiation.subject}\" ` +\n `(roughly ${negotiation.durationMinutes} minutes, ${negotiation.timezone}). ` +\n `I'll follow up with specific proposed times shortly.\\n\\n` +\n `Reference: ${negotiation.id}`;\n await this.dispatchSchedulingMessage(negotiation, body, subjectLine);\n\n return negotiation;\n }\n\n async getNegotiation(\n id: string,\n ): Promise<LifeOpsSchedulingNegotiation | null> {\n return this.repository.getSchedulingNegotiation(this.agentId(), id);\n }\n\n async listActiveNegotiations(opts?: {\n limit?: number;\n }): Promise<LifeOpsSchedulingNegotiation[]> {\n const all = await this.repository.listSchedulingNegotiations(\n this.agentId(),\n { limit: opts?.limit },\n );\n return all.filter(\n (n) => n.state !== \"confirmed\" && n.state !== \"cancelled\",\n );\n }\n\n async proposeTime(input: {\n negotiationId: string;\n startAt: string;\n endAt: string;\n proposedBy: \"agent\" | \"owner\" | \"counterparty\";\n metadata?: Record<string, unknown>;\n }): Promise<LifeOpsSchedulingProposal> {\n const negotiation = await this.repository.getSchedulingNegotiation(\n this.agentId(),\n input.negotiationId,\n );\n if (!negotiation) {\n fail(404, `negotiation ${input.negotiationId} not found`);\n }\n if (\n negotiation.state === \"confirmed\" ||\n negotiation.state === \"cancelled\"\n ) {\n fail(\n 409,\n `cannot propose on negotiation in state ${negotiation.state}`,\n );\n }\n if (!LIFEOPS_NEGOTIATION_STATES.includes(negotiation.state)) {\n fail(500, `unexpected negotiation state ${negotiation.state}`);\n }\n\n const startMs = Date.parse(input.startAt);\n const endMs = Date.parse(input.endAt);\n if (!Number.isFinite(startMs) || !Number.isFinite(endMs)) {\n fail(400, \"startAt/endAt must be valid ISO-8601 timestamps\");\n }\n if (endMs <= startMs) {\n fail(400, \"endAt must be after startAt\");\n }\n\n const now = isoNow();\n const proposal: LifeOpsSchedulingProposal = {\n id: crypto.randomUUID(),\n agentId: this.agentId(),\n negotiationId: negotiation.id,\n startAt: new Date(startMs).toISOString(),\n endAt: new Date(endMs).toISOString(),\n proposedBy: input.proposedBy,\n status: \"pending\",\n metadata: input.metadata ?? {},\n createdAt: now,\n updatedAt: now,\n };\n await this.repository.upsertSchedulingProposal(proposal);\n\n if (\n negotiation.state === \"initiated\" ||\n negotiation.state === \"awaiting_response\"\n ) {\n await this.repository.updateSchedulingNegotiationState(\n this.agentId(),\n negotiation.id,\n \"proposals_sent\",\n );\n }\n\n // Only send to the counterparty when the agent or owner is the one\n // proposing. A proposal whose `proposedBy = counterparty` came FROM\n // them, so echoing it back would be nonsense.\n if (input.proposedBy !== \"counterparty\") {\n const subjectLine = `Scheduling: ${negotiation.subject}`;\n const body =\n `Proposed time for \"${negotiation.subject}\":\\n` +\n ` Start: ${proposal.startAt}\\n` +\n ` End: ${proposal.endAt}\\n` +\n ` (${negotiation.durationMinutes} min, ${negotiation.timezone})\\n\\n` +\n `Let me know if this works or suggest a different slot.\\n\\n` +\n `Reference: ${negotiation.id} / ${proposal.id}`;\n await this.dispatchSchedulingMessage(negotiation, body, subjectLine);\n }\n\n return proposal;\n }\n\n async respondToProposal(\n proposalId: string,\n status: \"accepted\" | \"declined\" | \"expired\",\n ): Promise<LifeOpsSchedulingProposal> {\n const proposal = await this.repository.getSchedulingProposal(\n this.agentId(),\n proposalId,\n );\n if (!proposal) {\n fail(404, `proposal ${proposalId} not found`);\n }\n if (proposal.status !== \"pending\") {\n fail(409, `proposal already in terminal status ${proposal.status}`);\n }\n await this.repository.updateSchedulingProposalStatus(\n this.agentId(),\n proposalId,\n status,\n );\n const updated = await this.repository.getSchedulingProposal(\n this.agentId(),\n proposalId,\n );\n if (!updated) {\n fail(500, \"proposal disappeared after update\");\n }\n return updated;\n }\n\n async finalizeNegotiation(\n id: string,\n acceptedProposalId: string,\n ): Promise<LifeOpsSchedulingNegotiation> {\n const negotiation = await this.repository.getSchedulingNegotiation(\n this.agentId(),\n id,\n );\n if (!negotiation) {\n fail(404, `negotiation ${id} not found`);\n }\n if (negotiation.state === \"cancelled\") {\n fail(409, \"cannot finalize cancelled negotiation\");\n }\n const proposal = await this.repository.getSchedulingProposal(\n this.agentId(),\n acceptedProposalId,\n );\n if (!proposal || proposal.negotiationId !== id) {\n fail(\n 404,\n `proposal ${acceptedProposalId} not found for negotiation ${id}`,\n );\n }\n if (proposal.status !== \"accepted\") {\n fail(\n 409,\n `proposal ${acceptedProposalId} is not accepted (status=${proposal.status})`,\n );\n }\n const now = isoNow();\n const updated: LifeOpsSchedulingNegotiation = {\n ...negotiation,\n state: \"confirmed\",\n acceptedProposalId,\n finalizedAt: now,\n updatedAt: now,\n };\n await this.repository.upsertSchedulingNegotiation(updated);\n\n const subjectLine = `Confirmed: ${updated.subject}`;\n const body =\n `Confirming \"${updated.subject}\":\\n` +\n ` Start: ${proposal.startAt}\\n` +\n ` End: ${proposal.endAt}\\n` +\n ` (${updated.durationMinutes} min, ${updated.timezone})\\n\\n` +\n `See you then.\\n\\n` +\n `Reference: ${updated.id} / ${proposal.id}`;\n await this.dispatchSchedulingMessage(updated, body, subjectLine);\n\n return updated;\n }\n\n async cancelNegotiation(id: string, reason?: string): Promise<void> {\n const negotiation = await this.repository.getSchedulingNegotiation(\n this.agentId(),\n id,\n );\n if (!negotiation) {\n fail(404, `negotiation ${id} not found`);\n }\n const nextMetadata = {\n ...negotiation.metadata,\n ...(reason ? { cancellationReason: reason } : {}),\n };\n const now = isoNow();\n const updated: LifeOpsSchedulingNegotiation = {\n ...negotiation,\n state: \"cancelled\",\n metadata: nextMetadata,\n updatedAt: now,\n };\n await this.repository.upsertSchedulingNegotiation(updated);\n\n const subjectLine = `Cancelled: ${updated.subject}`;\n const body =\n `Cancelling \"${updated.subject}\"` +\n (reason ? ` — ${reason}.` : \".\") +\n `\\n\\nReference: ${updated.id}`;\n await this.dispatchSchedulingMessage(updated, body, subjectLine);\n }\n\n async listProposals(\n negotiationId: string,\n ): Promise<LifeOpsSchedulingProposal[]> {\n return this.repository.listSchedulingProposals(\n this.agentId(),\n negotiationId,\n );\n }\n }\n\n return LifeOpsSchedulingServiceMixin as unknown as MixinClass<\n TBase,\n LifeOpsSchedulingService\n >;\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { type ScreenTimeAggregateRow, type ScreenTimeWeeklyAverageItem } from "@elizaos/plugin-health";
|
|
2
|
+
import type { LifeOpsScreenTimeDaily, LifeOpsScreenTimeHistoryResponse, LifeOpsScreenTimeRangeKey, LifeOpsScreenTimeSession, LifeOpsScreenTimeSource, LifeOpsScreenTimeSummary, LifeOpsScreenTimeBreakdown as ScreenTimeBreakdown, LifeOpsSocialHabitSummary as SocialHabitSummary } from "@elizaos/shared";
|
|
3
|
+
import type { Constructor, LifeOpsServiceBase, MixinClass } from "./service-mixin-core.js";
|
|
4
|
+
type ScreenTimeEventInput = {
|
|
5
|
+
source: "app" | "website";
|
|
6
|
+
identifier: string;
|
|
7
|
+
displayName: string;
|
|
8
|
+
startAt: string;
|
|
9
|
+
endAt?: string | null;
|
|
10
|
+
durationSeconds?: number;
|
|
11
|
+
metadata?: Record<string, unknown>;
|
|
12
|
+
};
|
|
13
|
+
type ScreenTimeWeeklyAverageResponse = {
|
|
14
|
+
items: ScreenTimeWeeklyAverageItem[];
|
|
15
|
+
totalSeconds: number;
|
|
16
|
+
daysInWindow: number;
|
|
17
|
+
};
|
|
18
|
+
export interface LifeOpsScreenTimeServicePublic {
|
|
19
|
+
recordScreenTimeEvent(event: ScreenTimeEventInput): Promise<LifeOpsScreenTimeSession>;
|
|
20
|
+
finishActiveScreenTimeSession(id: string, endAt: string, durationSeconds: number): Promise<void>;
|
|
21
|
+
collectScreenTimeRows(opts: {
|
|
22
|
+
since: string;
|
|
23
|
+
until: string;
|
|
24
|
+
source?: LifeOpsScreenTimeSource;
|
|
25
|
+
identifier?: string;
|
|
26
|
+
}): Promise<ScreenTimeAggregateRow[]>;
|
|
27
|
+
getScreenTimeDaily(opts: {
|
|
28
|
+
date: string;
|
|
29
|
+
source?: LifeOpsScreenTimeSource;
|
|
30
|
+
identifier?: string;
|
|
31
|
+
limit?: number;
|
|
32
|
+
}): Promise<LifeOpsScreenTimeDaily[]>;
|
|
33
|
+
getScreenTimeSummary(opts: {
|
|
34
|
+
since: string;
|
|
35
|
+
until: string;
|
|
36
|
+
source?: LifeOpsScreenTimeSource;
|
|
37
|
+
identifier?: string;
|
|
38
|
+
topN?: number;
|
|
39
|
+
}): Promise<LifeOpsScreenTimeSummary>;
|
|
40
|
+
getScreenTimeBreakdown(opts: {
|
|
41
|
+
since: string;
|
|
42
|
+
until: string;
|
|
43
|
+
source?: LifeOpsScreenTimeSource;
|
|
44
|
+
identifier?: string;
|
|
45
|
+
topN?: number;
|
|
46
|
+
}): Promise<ScreenTimeBreakdown>;
|
|
47
|
+
getSocialHabitSummary(opts: {
|
|
48
|
+
since: string;
|
|
49
|
+
until: string;
|
|
50
|
+
topN?: number;
|
|
51
|
+
}): Promise<SocialHabitSummary>;
|
|
52
|
+
getScreenTimeHistory(opts: {
|
|
53
|
+
range: LifeOpsScreenTimeRangeKey;
|
|
54
|
+
topN?: number;
|
|
55
|
+
socialTopN?: number;
|
|
56
|
+
}): Promise<LifeOpsScreenTimeHistoryResponse>;
|
|
57
|
+
getScreenTimeWeeklyAverageByApp(opts: {
|
|
58
|
+
since: string;
|
|
59
|
+
until: string;
|
|
60
|
+
daysInWindow: number;
|
|
61
|
+
identifier?: string;
|
|
62
|
+
topN?: number;
|
|
63
|
+
}): Promise<ScreenTimeWeeklyAverageResponse>;
|
|
64
|
+
aggregateDailyForDate(date: string): Promise<{
|
|
65
|
+
updated: number;
|
|
66
|
+
}>;
|
|
67
|
+
}
|
|
68
|
+
/** @internal */
|
|
69
|
+
export declare function withScreenTime<TBase extends Constructor<LifeOpsServiceBase>>(Base: TBase): MixinClass<TBase, LifeOpsScreenTimeServicePublic>;
|
|
70
|
+
export {};
|
|
71
|
+
//# sourceMappingURL=service-mixin-screentime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-mixin-screentime.d.ts","sourceRoot":"","sources":["../../src/lifeops/service-mixin-screentime.ts"],"names":[],"mappings":"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"}
|