@elizaos/plugin-personal-assistant 2.0.3-beta.6 → 2.0.3-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/app-block.d.ts +15 -0
- package/dist/actions/app-block.d.ts.map +1 -0
- package/dist/actions/app-block.js +349 -0
- package/dist/actions/app-block.js.map +1 -0
- package/dist/actions/autofill.d.ts +20 -0
- package/dist/actions/autofill.d.ts.map +1 -0
- package/dist/actions/autofill.js +370 -0
- package/dist/actions/autofill.js.map +1 -0
- package/dist/actions/block.d.ts +30 -0
- package/dist/actions/block.d.ts.map +1 -0
- package/dist/actions/block.js +326 -0
- package/dist/actions/block.js.map +1 -0
- package/dist/actions/book-travel.d.ts +10 -0
- package/dist/actions/book-travel.d.ts.map +1 -0
- package/dist/actions/book-travel.js +467 -0
- package/dist/actions/book-travel.js.map +1 -0
- package/dist/actions/brief.d.ts +60 -0
- package/dist/actions/brief.d.ts.map +1 -0
- package/dist/actions/brief.js +485 -0
- package/dist/actions/brief.js.map +1 -0
- package/dist/actions/calendar.d.ts +22 -0
- package/dist/actions/calendar.d.ts.map +1 -0
- package/dist/actions/calendar.js +832 -0
- package/dist/actions/calendar.js.map +1 -0
- package/dist/actions/conflict-detect.d.ts +67 -0
- package/dist/actions/conflict-detect.d.ts.map +1 -0
- package/dist/actions/conflict-detect.js +310 -0
- package/dist/actions/conflict-detect.js.map +1 -0
- package/dist/actions/connector.d.ts +5 -0
- package/dist/actions/connector.d.ts.map +1 -0
- package/dist/actions/connector.js +1354 -0
- package/dist/actions/connector.js.map +1 -0
- package/dist/actions/credentials.d.ts +14 -0
- package/dist/actions/credentials.d.ts.map +1 -0
- package/dist/actions/credentials.js +191 -0
- package/dist/actions/credentials.js.map +1 -0
- package/dist/actions/document.d.ts +36 -0
- package/dist/actions/document.d.ts.map +1 -0
- package/dist/actions/document.js +613 -0
- package/dist/actions/document.js.map +1 -0
- package/dist/actions/entity.d.ts +20 -0
- package/dist/actions/entity.d.ts.map +1 -0
- package/dist/actions/entity.js +785 -0
- package/dist/actions/entity.js.map +1 -0
- package/dist/actions/health.d.ts +4 -0
- package/dist/actions/health.d.ts.map +1 -0
- package/dist/actions/health.js +37 -0
- package/dist/actions/health.js.map +1 -0
- package/dist/actions/inbox.d.ts +12 -0
- package/dist/actions/inbox.d.ts.map +1 -0
- package/dist/actions/inbox.js +13 -0
- package/dist/actions/inbox.js.map +1 -0
- package/dist/actions/lib/calendly-handler.d.ts +3 -0
- package/dist/actions/lib/calendly-handler.d.ts.map +1 -0
- package/dist/actions/lib/calendly-handler.js +506 -0
- package/dist/actions/lib/calendly-handler.js.map +1 -0
- package/dist/actions/lib/extract-goal-plan.d.ts +69 -0
- package/dist/actions/lib/extract-goal-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-goal-plan.js +488 -0
- package/dist/actions/lib/extract-goal-plan.js.map +1 -0
- package/dist/actions/lib/extract-life-operation.d.ts +18 -0
- package/dist/actions/lib/extract-life-operation.d.ts.map +1 -0
- package/dist/actions/lib/extract-life-operation.js +318 -0
- package/dist/actions/lib/extract-life-operation.js.map +1 -0
- package/dist/actions/lib/extract-task-plan.d.ts +78 -0
- package/dist/actions/lib/extract-task-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-task-plan.js +355 -0
- package/dist/actions/lib/extract-task-plan.js.map +1 -0
- package/dist/actions/lib/extract-update-fields.d.ts +27 -0
- package/dist/actions/lib/extract-update-fields.d.ts.map +1 -0
- package/dist/actions/lib/extract-update-fields.js +172 -0
- package/dist/actions/lib/extract-update-fields.js.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts +68 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.js +315 -0
- package/dist/actions/lib/lifeops-deferred-draft.js.map +1 -0
- package/dist/actions/lib/messaging-helpers.d.ts +20 -0
- package/dist/actions/lib/messaging-helpers.d.ts.map +1 -0
- package/dist/actions/lib/messaging-helpers.js +103 -0
- package/dist/actions/lib/messaging-helpers.js.map +1 -0
- package/dist/actions/lib/owner-policy-writes.d.ts +49 -0
- package/dist/actions/lib/owner-policy-writes.d.ts.map +1 -0
- package/dist/actions/lib/owner-policy-writes.js +157 -0
- package/dist/actions/lib/owner-policy-writes.js.map +1 -0
- package/dist/actions/lib/prompt-format.d.ts +3 -0
- package/dist/actions/lib/prompt-format.d.ts.map +1 -0
- package/dist/actions/lib/prompt-format.js +42 -0
- package/dist/actions/lib/prompt-format.js.map +1 -0
- package/dist/actions/lib/scheduling-handler.d.ts +93 -0
- package/dist/actions/lib/scheduling-handler.d.ts.map +1 -0
- package/dist/actions/lib/scheduling-handler.js +868 -0
- package/dist/actions/lib/scheduling-handler.js.map +1 -0
- package/dist/actions/life.d.ts +13 -0
- package/dist/actions/life.d.ts.map +1 -0
- package/dist/actions/life.js +2524 -0
- package/dist/actions/life.js.map +1 -0
- package/dist/actions/money.d.ts +24 -0
- package/dist/actions/money.d.ts.map +1 -0
- package/dist/actions/money.js +41 -0
- package/dist/actions/money.js.map +1 -0
- package/dist/actions/owner-surfaces.d.ts +11 -0
- package/dist/actions/owner-surfaces.d.ts.map +1 -0
- package/dist/actions/owner-surfaces.js +493 -0
- package/dist/actions/owner-surfaces.js.map +1 -0
- package/dist/actions/password-manager.d.ts +10 -0
- package/dist/actions/password-manager.d.ts.map +1 -0
- package/dist/actions/password-manager.js +195 -0
- package/dist/actions/password-manager.js.map +1 -0
- package/dist/actions/payments.d.ts +10 -0
- package/dist/actions/payments.d.ts.map +1 -0
- package/dist/actions/payments.js +5 -0
- package/dist/actions/payments.js.map +1 -0
- package/dist/actions/prioritize.d.ts +49 -0
- package/dist/actions/prioritize.d.ts.map +1 -0
- package/dist/actions/prioritize.js +313 -0
- package/dist/actions/prioritize.js.map +1 -0
- package/dist/actions/remote-desktop.d.ts +13 -0
- package/dist/actions/remote-desktop.d.ts.map +1 -0
- package/dist/actions/remote-desktop.js +11 -0
- package/dist/actions/remote-desktop.js.map +1 -0
- package/dist/actions/resolve-request.d.ts +12 -0
- package/dist/actions/resolve-request.d.ts.map +1 -0
- package/dist/actions/resolve-request.js +427 -0
- package/dist/actions/resolve-request.js.map +1 -0
- package/dist/actions/schedule.d.ts +10 -0
- package/dist/actions/schedule.d.ts.map +1 -0
- package/dist/actions/schedule.js +113 -0
- package/dist/actions/schedule.js.map +1 -0
- package/dist/actions/scheduled-task.d.ts +32 -0
- package/dist/actions/scheduled-task.d.ts.map +1 -0
- package/dist/actions/scheduled-task.js +661 -0
- package/dist/actions/scheduled-task.js.map +1 -0
- package/dist/actions/screen-time.d.ts +4 -0
- package/dist/actions/screen-time.d.ts.map +1 -0
- package/dist/actions/screen-time.js +47 -0
- package/dist/actions/screen-time.js.map +1 -0
- package/dist/actions/subscriptions.d.ts +8 -0
- package/dist/actions/subscriptions.d.ts.map +1 -0
- package/dist/actions/subscriptions.js +327 -0
- package/dist/actions/subscriptions.js.map +1 -0
- package/dist/actions/voice-call.d.ts +16 -0
- package/dist/actions/voice-call.d.ts.map +1 -0
- package/dist/actions/voice-call.js +756 -0
- package/dist/actions/voice-call.js.map +1 -0
- package/dist/actions/website-block.d.ts +15 -0
- package/dist/actions/website-block.d.ts.map +1 -0
- package/dist/actions/website-block.js +719 -0
- package/dist/actions/website-block.js.map +1 -0
- package/dist/actions/work-thread.d.ts +5 -0
- package/dist/actions/work-thread.d.ts.map +1 -0
- package/dist/actions/work-thread.js +556 -0
- package/dist/actions/work-thread.js.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts +28 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.js +61 -0
- package/dist/activity-profile/activity-tracker-repo.js.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts +52 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.js +119 -0
- package/dist/activity-profile/activity-tracker-reporting.js.map +1 -0
- package/dist/activity-profile/activity-tracker-service.d.ts +36 -0
- package/dist/activity-profile/activity-tracker-service.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-service.js +187 -0
- package/dist/activity-profile/activity-tracker-service.js.map +1 -0
- package/dist/activity-profile/analyzer.d.ts +23 -0
- package/dist/activity-profile/analyzer.d.ts.map +1 -0
- package/dist/activity-profile/analyzer.js +485 -0
- package/dist/activity-profile/analyzer.js.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts +14 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.js +159 -0
- package/dist/activity-profile/presence-signal-bridge-service.js.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts +3 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.js +21 -0
- package/dist/activity-profile/proactive-inbox-digest.js.map +1 -0
- package/dist/activity-profile/proactive-planner.d.ts +150 -0
- package/dist/activity-profile/proactive-planner.d.ts.map +1 -0
- package/dist/activity-profile/proactive-planner.js +529 -0
- package/dist/activity-profile/proactive-planner.js.map +1 -0
- package/dist/activity-profile/proactive-worker.d.ts +33 -0
- package/dist/activity-profile/proactive-worker.d.ts.map +1 -0
- package/dist/activity-profile/proactive-worker.js +779 -0
- package/dist/activity-profile/proactive-worker.js.map +1 -0
- package/dist/activity-profile/profile-metadata.d.ts +10 -0
- package/dist/activity-profile/profile-metadata.d.ts.map +1 -0
- package/dist/activity-profile/profile-metadata.js +16 -0
- package/dist/activity-profile/profile-metadata.js.map +1 -0
- package/dist/activity-profile/redactor.d.ts +15 -0
- package/dist/activity-profile/redactor.d.ts.map +1 -0
- package/dist/activity-profile/redactor.js +22 -0
- package/dist/activity-profile/redactor.js.map +1 -0
- package/dist/activity-profile/service.d.ts +11 -0
- package/dist/activity-profile/service.d.ts.map +1 -0
- package/dist/activity-profile/service.js +272 -0
- package/dist/activity-profile/service.js.map +1 -0
- package/dist/activity-profile/types.d.ts +97 -0
- package/dist/activity-profile/types.d.ts.map +1 -0
- package/dist/activity-profile/types.js +36 -0
- package/dist/activity-profile/types.js.map +1 -0
- package/dist/agent-lifeops.d.ts +2 -0
- package/dist/agent-lifeops.d.ts.map +1 -0
- package/dist/agent-lifeops.js +2 -0
- package/dist/agent-lifeops.js.map +1 -0
- package/dist/api/client-lifeops.d.ts +319 -0
- package/dist/api/client-lifeops.d.ts.map +1 -0
- package/dist/api/client-lifeops.js +794 -0
- package/dist/api/client-lifeops.js.map +1 -0
- package/dist/automation-node-contributor.d.ts +2 -0
- package/dist/automation-node-contributor.d.ts.map +1 -0
- package/dist/automation-node-contributor.js +184 -0
- package/dist/automation-node-contributor.js.map +1 -0
- package/dist/client.d.ts +16 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +18 -0
- package/dist/client.js.map +1 -0
- package/dist/components/AppBlockerSettingsCard.d.ts +3 -0
- package/dist/components/AppBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/AppBlockerSettingsCard.js +538 -0
- package/dist/components/AppBlockerSettingsCard.js.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts +3 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.js +148 -0
- package/dist/components/WebsiteBlockerSettingsCard.js.map +1 -0
- package/dist/contracts/index.d.ts +2 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/index.js +2 -0
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/lifeops.d.ts +2 -0
- package/dist/contracts/lifeops.d.ts.map +1 -0
- package/dist/contracts/lifeops.js +2 -0
- package/dist/contracts/lifeops.js.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts +17 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.js +56 -0
- package/dist/default-packs/autofill-whitelist-pack.js.map +1 -0
- package/dist/default-packs/consolidation-policies.d.ts +14 -0
- package/dist/default-packs/consolidation-policies.d.ts.map +1 -0
- package/dist/default-packs/consolidation-policies.js +17 -0
- package/dist/default-packs/consolidation-policies.js.map +1 -0
- package/dist/default-packs/contract-types.d.ts +200 -0
- package/dist/default-packs/contract-types.d.ts.map +1 -0
- package/dist/default-packs/contract-types.js +1 -0
- package/dist/default-packs/contract-types.js.map +1 -0
- package/dist/default-packs/daily-rhythm.d.ts +28 -0
- package/dist/default-packs/daily-rhythm.d.ts.map +1 -0
- package/dist/default-packs/daily-rhythm.js +136 -0
- package/dist/default-packs/daily-rhythm.js.map +1 -0
- package/dist/default-packs/escalation-ladders.d.ts +18 -0
- package/dist/default-packs/escalation-ladders.d.ts.map +1 -0
- package/dist/default-packs/escalation-ladders.js +17 -0
- package/dist/default-packs/escalation-ladders.js.map +1 -0
- package/dist/default-packs/executive-assistant.d.ts +50 -0
- package/dist/default-packs/executive-assistant.d.ts.map +1 -0
- package/dist/default-packs/executive-assistant.js +745 -0
- package/dist/default-packs/executive-assistant.js.map +1 -0
- package/dist/default-packs/followup-starter.d.ts +49 -0
- package/dist/default-packs/followup-starter.d.ts.map +1 -0
- package/dist/default-packs/followup-starter.js +104 -0
- package/dist/default-packs/followup-starter.js.map +1 -0
- package/dist/default-packs/habit-starters.d.ts +37 -0
- package/dist/default-packs/habit-starters.d.ts.map +1 -0
- package/dist/default-packs/habit-starters.js +255 -0
- package/dist/default-packs/habit-starters.js.map +1 -0
- package/dist/default-packs/inbox-triage-starter.d.ts +23 -0
- package/dist/default-packs/inbox-triage-starter.d.ts.map +1 -0
- package/dist/default-packs/inbox-triage-starter.js +61 -0
- package/dist/default-packs/inbox-triage-starter.js.map +1 -0
- package/dist/default-packs/index.d.ts +54 -0
- package/dist/default-packs/index.d.ts.map +1 -0
- package/dist/default-packs/index.js +150 -0
- package/dist/default-packs/index.js.map +1 -0
- package/dist/default-packs/lint.d.ts +62 -0
- package/dist/default-packs/lint.d.ts.map +1 -0
- package/dist/default-packs/lint.js +161 -0
- package/dist/default-packs/lint.js.map +1 -0
- package/dist/default-packs/morning-brief.d.ts +44 -0
- package/dist/default-packs/morning-brief.d.ts.map +1 -0
- package/dist/default-packs/morning-brief.js +69 -0
- package/dist/default-packs/morning-brief.js.map +1 -0
- package/dist/default-packs/quiet-user-watcher.d.ts +49 -0
- package/dist/default-packs/quiet-user-watcher.d.ts.map +1 -0
- package/dist/default-packs/quiet-user-watcher.js +92 -0
- package/dist/default-packs/quiet-user-watcher.js.map +1 -0
- package/dist/default-packs/registry-types.d.ts +51 -0
- package/dist/default-packs/registry-types.d.ts.map +1 -0
- package/dist/default-packs/registry-types.js +1 -0
- package/dist/default-packs/registry-types.js.map +1 -0
- package/dist/default-packs/task-definitions.d.ts +88 -0
- package/dist/default-packs/task-definitions.d.ts.map +1 -0
- package/dist/default-packs/task-definitions.js +87 -0
- package/dist/default-packs/task-definitions.js.map +1 -0
- package/dist/events/index.d.ts +34 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +30 -0
- package/dist/events/index.js.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts +3 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.js +90 -0
- package/dist/followup/actions/listOverdueFollowups.js.map +1 -0
- package/dist/followup/actions/markFollowupDone.d.ts +3 -0
- package/dist/followup/actions/markFollowupDone.d.ts.map +1 -0
- package/dist/followup/actions/markFollowupDone.js +171 -0
- package/dist/followup/actions/markFollowupDone.js.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts +3 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.js +171 -0
- package/dist/followup/actions/setFollowupThreshold.js.map +1 -0
- package/dist/followup/followup-tracker.d.ts +83 -0
- package/dist/followup/followup-tracker.d.ts.map +1 -0
- package/dist/followup/followup-tracker.js +311 -0
- package/dist/followup/followup-tracker.js.map +1 -0
- package/dist/followup/index.d.ts +5 -0
- package/dist/followup/index.d.ts.map +1 -0
- package/dist/followup/index.js +39 -0
- package/dist/followup/index.js.map +1 -0
- package/dist/hooks/connector-error.d.ts +2 -0
- package/dist/hooks/connector-error.d.ts.map +1 -0
- package/dist/hooks/connector-error.js +13 -0
- package/dist/hooks/connector-error.js.map +1 -0
- package/dist/hooks/useDiscordConnector.d.ts +11 -0
- package/dist/hooks/useDiscordConnector.d.ts.map +1 -0
- package/dist/hooks/useDiscordConnector.js +95 -0
- package/dist/hooks/useDiscordConnector.js.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts +23 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js +630 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js.map +1 -0
- package/dist/hooks/useIMessageConnector.d.ts +10 -0
- package/dist/hooks/useIMessageConnector.d.ts.map +1 -0
- package/dist/hooks/useIMessageConnector.js +57 -0
- package/dist/hooks/useIMessageConnector.js.map +1 -0
- package/dist/hooks/useInbox.d.ts +36 -0
- package/dist/hooks/useInbox.d.ts.map +1 -0
- package/dist/hooks/useInbox.js +96 -0
- package/dist/hooks/useInbox.js.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts +2 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.js +358 -0
- package/dist/hooks/useLifeOpsActivitySignals.js.map +1 -0
- package/dist/hooks/useLifeOpsAppState.d.ts +9 -0
- package/dist/hooks/useLifeOpsAppState.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsAppState.js +79 -0
- package/dist/hooks/useLifeOpsAppState.js.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts +8 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js +60 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts +11 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.js +92 -0
- package/dist/hooks/useLifeOpsXConnector.js.map +1 -0
- package/dist/hooks/useSignalConnector.d.ts +14 -0
- package/dist/hooks/useSignalConnector.d.ts.map +1 -0
- package/dist/hooks/useSignalConnector.js +89 -0
- package/dist/hooks/useSignalConnector.js.map +1 -0
- package/dist/hooks/useTelegramConnector.d.ts +14 -0
- package/dist/hooks/useTelegramConnector.d.ts.map +1 -0
- package/dist/hooks/useTelegramConnector.js +97 -0
- package/dist/hooks/useTelegramConnector.js.map +1 -0
- package/dist/hooks/useWhatsAppConnector.d.ts +8 -0
- package/dist/hooks/useWhatsAppConnector.d.ts.map +1 -0
- package/dist/hooks/useWhatsAppConnector.js +62 -0
- package/dist/hooks/useWhatsAppConnector.js.map +1 -0
- package/dist/inbox/message-fetcher.d.ts +11 -0
- package/dist/inbox/message-fetcher.d.ts.map +1 -0
- package/dist/inbox/message-fetcher.js +13 -0
- package/dist/inbox/message-fetcher.js.map +1 -0
- package/dist/inbox/repository.d.ts +11 -0
- package/dist/inbox/repository.d.ts.map +1 -0
- package/dist/inbox/repository.js +5 -0
- package/dist/inbox/repository.js.map +1 -0
- package/dist/inbox/types.d.ts +10 -0
- package/dist/inbox/types.d.ts.map +1 -0
- package/dist/inbox/types.js +2 -0
- package/dist/inbox/types.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +188 -0
- package/dist/index.js.map +1 -0
- package/dist/lifeops/access.d.ts +29 -0
- package/dist/lifeops/access.d.ts.map +1 -0
- package/dist/lifeops/access.js +56 -0
- package/dist/lifeops/access.js.map +1 -0
- package/dist/lifeops/app-state.d.ts +22 -0
- package/dist/lifeops/app-state.d.ts.map +1 -0
- package/dist/lifeops/app-state.js +67 -0
- package/dist/lifeops/app-state.js.map +1 -0
- package/dist/lifeops/apple-reminders.d.ts +67 -0
- package/dist/lifeops/apple-reminders.d.ts.map +1 -0
- package/dist/lifeops/apple-reminders.js +396 -0
- package/dist/lifeops/apple-reminders.js.map +1 -0
- package/dist/lifeops/approval-queue.d.ts +38 -0
- package/dist/lifeops/approval-queue.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.js +575 -0
- package/dist/lifeops/approval-queue.js.map +1 -0
- package/dist/lifeops/approval-queue.types.d.ts +172 -0
- package/dist/lifeops/approval-queue.types.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.types.js +27 -0
- package/dist/lifeops/approval-queue.types.js.map +1 -0
- package/dist/lifeops/autofill-whitelist.d.ts +20 -0
- package/dist/lifeops/autofill-whitelist.d.ts.map +1 -0
- package/dist/lifeops/autofill-whitelist.js +59 -0
- package/dist/lifeops/autofill-whitelist.js.map +1 -0
- package/dist/lifeops/background-planner-dispatch.d.ts +60 -0
- package/dist/lifeops/background-planner-dispatch.d.ts.map +1 -0
- package/dist/lifeops/background-planner-dispatch.js +113 -0
- package/dist/lifeops/background-planner-dispatch.js.map +1 -0
- package/dist/lifeops/background-planner.d.ts +140 -0
- package/dist/lifeops/background-planner.d.ts.map +1 -0
- package/dist/lifeops/background-planner.js +359 -0
- package/dist/lifeops/background-planner.js.map +1 -0
- package/dist/lifeops/bill-extraction.d.ts +46 -0
- package/dist/lifeops/bill-extraction.d.ts.map +1 -0
- package/dist/lifeops/bill-extraction.js +325 -0
- package/dist/lifeops/bill-extraction.js.map +1 -0
- package/dist/lifeops/browser-constants.d.ts +4 -0
- package/dist/lifeops/browser-constants.d.ts.map +1 -0
- package/dist/lifeops/browser-constants.js +27 -0
- package/dist/lifeops/browser-constants.js.map +1 -0
- package/dist/lifeops/browser-extension-store.d.ts +61 -0
- package/dist/lifeops/browser-extension-store.d.ts.map +1 -0
- package/dist/lifeops/browser-extension-store.js +176 -0
- package/dist/lifeops/browser-extension-store.js.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts +57 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.js +308 -0
- package/dist/lifeops/browser-session-lifecycle.js.map +1 -0
- package/dist/lifeops/bulk-review.d.ts +333 -0
- package/dist/lifeops/bulk-review.d.ts.map +1 -0
- package/dist/lifeops/bulk-review.js +1120 -0
- package/dist/lifeops/bulk-review.js.map +1 -0
- package/dist/lifeops/calendar-gate.d.ts +20 -0
- package/dist/lifeops/calendar-gate.d.ts.map +1 -0
- package/dist/lifeops/calendar-gate.js +30 -0
- package/dist/lifeops/calendar-gate.js.map +1 -0
- package/dist/lifeops/channels/contract.d.ts +47 -0
- package/dist/lifeops/channels/contract.d.ts.map +1 -0
- package/dist/lifeops/channels/contract.js +1 -0
- package/dist/lifeops/channels/contract.js.map +1 -0
- package/dist/lifeops/channels/default-pack.d.ts +26 -0
- package/dist/lifeops/channels/default-pack.d.ts.map +1 -0
- package/dist/lifeops/channels/default-pack.js +243 -0
- package/dist/lifeops/channels/default-pack.js.map +1 -0
- package/dist/lifeops/channels/index.d.ts +5 -0
- package/dist/lifeops/channels/index.d.ts.map +1 -0
- package/dist/lifeops/channels/index.js +23 -0
- package/dist/lifeops/channels/index.js.map +1 -0
- package/dist/lifeops/channels/priority-posture.d.ts +36 -0
- package/dist/lifeops/channels/priority-posture.d.ts.map +1 -0
- package/dist/lifeops/channels/priority-posture.js +27 -0
- package/dist/lifeops/channels/priority-posture.js.map +1 -0
- package/dist/lifeops/channels/registry.d.ts +7 -0
- package/dist/lifeops/channels/registry.d.ts.map +1 -0
- package/dist/lifeops/channels/registry.js +49 -0
- package/dist/lifeops/channels/registry.js.map +1 -0
- package/dist/lifeops/checkin/checkin-service.d.ts +66 -0
- package/dist/lifeops/checkin/checkin-service.d.ts.map +1 -0
- package/dist/lifeops/checkin/checkin-service.js +1084 -0
- package/dist/lifeops/checkin/checkin-service.js.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts +17 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.js +26 -0
- package/dist/lifeops/checkin/schedule-resolver.js.map +1 -0
- package/dist/lifeops/checkin/types.d.ts +106 -0
- package/dist/lifeops/checkin/types.d.ts.map +1 -0
- package/dist/lifeops/checkin/types.js +1 -0
- package/dist/lifeops/checkin/types.js.map +1 -0
- package/dist/lifeops/connectors/_helpers.d.ts +51 -0
- package/dist/lifeops/connectors/_helpers.d.ts.map +1 -0
- package/dist/lifeops/connectors/_helpers.js +104 -0
- package/dist/lifeops/connectors/_helpers.js.map +1 -0
- package/dist/lifeops/connectors/calendly.d.ts +11 -0
- package/dist/lifeops/connectors/calendly.d.ts.map +1 -0
- package/dist/lifeops/connectors/calendly.js +61 -0
- package/dist/lifeops/connectors/calendly.js.map +1 -0
- package/dist/lifeops/connectors/contract.d.ts +88 -0
- package/dist/lifeops/connectors/contract.d.ts.map +1 -0
- package/dist/lifeops/connectors/contract.js +1 -0
- package/dist/lifeops/connectors/contract.js.map +1 -0
- package/dist/lifeops/connectors/default-pack.d.ts +35 -0
- package/dist/lifeops/connectors/default-pack.d.ts.map +1 -0
- package/dist/lifeops/connectors/default-pack.js +37 -0
- package/dist/lifeops/connectors/default-pack.js.map +1 -0
- package/dist/lifeops/connectors/discord.d.ts +8 -0
- package/dist/lifeops/connectors/discord.d.ts.map +1 -0
- package/dist/lifeops/connectors/discord.js +53 -0
- package/dist/lifeops/connectors/discord.js.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts +75 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.js +35 -0
- package/dist/lifeops/connectors/dispatch-policy.js.map +1 -0
- package/dist/lifeops/connectors/duffel.d.ts +11 -0
- package/dist/lifeops/connectors/duffel.d.ts.map +1 -0
- package/dist/lifeops/connectors/duffel.js +74 -0
- package/dist/lifeops/connectors/duffel.js.map +1 -0
- package/dist/lifeops/connectors/google.d.ts +27 -0
- package/dist/lifeops/connectors/google.d.ts.map +1 -0
- package/dist/lifeops/connectors/google.js +80 -0
- package/dist/lifeops/connectors/google.js.map +1 -0
- package/dist/lifeops/connectors/imessage.d.ts +11 -0
- package/dist/lifeops/connectors/imessage.d.ts.map +1 -0
- package/dist/lifeops/connectors/imessage.js +55 -0
- package/dist/lifeops/connectors/imessage.js.map +1 -0
- package/dist/lifeops/connectors/index.d.ts +5 -0
- package/dist/lifeops/connectors/index.d.ts.map +1 -0
- package/dist/lifeops/connectors/index.js +23 -0
- package/dist/lifeops/connectors/index.js.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts +54 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.js +71 -0
- package/dist/lifeops/connectors/mockoon-redirect.js.map +1 -0
- package/dist/lifeops/connectors/registry.d.ts +7 -0
- package/dist/lifeops/connectors/registry.d.ts.map +1 -0
- package/dist/lifeops/connectors/registry.js +55 -0
- package/dist/lifeops/connectors/registry.js.map +1 -0
- package/dist/lifeops/connectors/signal.d.ts +8 -0
- package/dist/lifeops/connectors/signal.d.ts.map +1 -0
- package/dist/lifeops/connectors/signal.js +60 -0
- package/dist/lifeops/connectors/signal.js.map +1 -0
- package/dist/lifeops/connectors/telegram.d.ts +12 -0
- package/dist/lifeops/connectors/telegram.d.ts.map +1 -0
- package/dist/lifeops/connectors/telegram.js +65 -0
- package/dist/lifeops/connectors/telegram.js.map +1 -0
- package/dist/lifeops/connectors/twilio.d.ts +15 -0
- package/dist/lifeops/connectors/twilio.d.ts.map +1 -0
- package/dist/lifeops/connectors/twilio.js +126 -0
- package/dist/lifeops/connectors/twilio.js.map +1 -0
- package/dist/lifeops/connectors/whatsapp.d.ts +10 -0
- package/dist/lifeops/connectors/whatsapp.d.ts.map +1 -0
- package/dist/lifeops/connectors/whatsapp.js +56 -0
- package/dist/lifeops/connectors/whatsapp.js.map +1 -0
- package/dist/lifeops/connectors/x.d.ts +8 -0
- package/dist/lifeops/connectors/x.d.ts.map +1 -0
- package/dist/lifeops/connectors/x.js +62 -0
- package/dist/lifeops/connectors/x.js.map +1 -0
- package/dist/lifeops/contact-route-policy.d.ts +27 -0
- package/dist/lifeops/contact-route-policy.d.ts.map +1 -0
- package/dist/lifeops/contact-route-policy.js +153 -0
- package/dist/lifeops/contact-route-policy.js.map +1 -0
- package/dist/lifeops/continuity-probe.d.ts +49 -0
- package/dist/lifeops/continuity-probe.d.ts.map +1 -0
- package/dist/lifeops/continuity-probe.js +161 -0
- package/dist/lifeops/continuity-probe.js.map +1 -0
- package/dist/lifeops/cross-channel-search.d.ts +108 -0
- package/dist/lifeops/cross-channel-search.d.ts.map +1 -0
- package/dist/lifeops/cross-channel-search.js +888 -0
- package/dist/lifeops/cross-channel-search.js.map +1 -0
- package/dist/lifeops/defaults.d.ts +30 -0
- package/dist/lifeops/defaults.d.ts.map +1 -0
- package/dist/lifeops/defaults.js +206 -0
- package/dist/lifeops/defaults.js.map +1 -0
- package/dist/lifeops/device-bus-service.d.ts +16 -0
- package/dist/lifeops/device-bus-service.d.ts.map +1 -0
- package/dist/lifeops/device-bus-service.js +20 -0
- package/dist/lifeops/device-bus-service.js.map +1 -0
- package/dist/lifeops/device-identity.d.ts +31 -0
- package/dist/lifeops/device-identity.d.ts.map +1 -0
- package/dist/lifeops/device-identity.js +94 -0
- package/dist/lifeops/device-identity.js.map +1 -0
- package/dist/lifeops/document-review.d.ts +264 -0
- package/dist/lifeops/document-review.d.ts.map +1 -0
- package/dist/lifeops/document-review.js +925 -0
- package/dist/lifeops/document-review.js.map +1 -0
- package/dist/lifeops/email-classifier.d.ts +9 -0
- package/dist/lifeops/email-classifier.d.ts.map +1 -0
- package/dist/lifeops/email-classifier.js +15 -0
- package/dist/lifeops/email-classifier.js.map +1 -0
- package/dist/lifeops/email-curation.d.ts +13 -0
- package/dist/lifeops/email-curation.d.ts.map +1 -0
- package/dist/lifeops/email-curation.js +2 -0
- package/dist/lifeops/email-curation.js.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts +7 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.js +1 -0
- package/dist/lifeops/email-unsubscribe-types.js.map +1 -0
- package/dist/lifeops/enforcement-windows.d.ts +34 -0
- package/dist/lifeops/enforcement-windows.d.ts.map +1 -0
- package/dist/lifeops/enforcement-windows.js +80 -0
- package/dist/lifeops/enforcement-windows.js.map +1 -0
- package/dist/lifeops/engine.d.ts +8 -0
- package/dist/lifeops/engine.d.ts.map +1 -0
- package/dist/lifeops/engine.js +540 -0
- package/dist/lifeops/engine.js.map +1 -0
- package/dist/lifeops/entities/index.d.ts +4 -0
- package/dist/lifeops/entities/index.d.ts.map +1 -0
- package/dist/lifeops/entities/index.js +29 -0
- package/dist/lifeops/entities/index.js.map +1 -0
- package/dist/lifeops/entities/merge.d.ts +9 -0
- package/dist/lifeops/entities/merge.d.ts.map +1 -0
- package/dist/lifeops/entities/merge.js +17 -0
- package/dist/lifeops/entities/merge.js.map +1 -0
- package/dist/lifeops/entities/store.d.ts +13 -0
- package/dist/lifeops/entities/store.d.ts.map +1 -0
- package/dist/lifeops/entities/store.js +7 -0
- package/dist/lifeops/entities/store.js.map +1 -0
- package/dist/lifeops/entities/types.d.ts +9 -0
- package/dist/lifeops/entities/types.d.ts.map +1 -0
- package/dist/lifeops/entities/types.js +13 -0
- package/dist/lifeops/entities/types.js.map +1 -0
- package/dist/lifeops/entities/voice-attribution.d.ts +70 -0
- package/dist/lifeops/entities/voice-attribution.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-attribution.js +121 -0
- package/dist/lifeops/entities/voice-attribution.js.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts +32 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.js +68 -0
- package/dist/lifeops/entities/voice-observer-bridge.js.map +1 -0
- package/dist/lifeops/entities/voice-observer.d.ts +72 -0
- package/dist/lifeops/entities/voice-observer.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer.js +97 -0
- package/dist/lifeops/entities/voice-observer.js.map +1 -0
- package/dist/lifeops/escalation-ladders.d.ts +28 -0
- package/dist/lifeops/escalation-ladders.d.ts.map +1 -0
- package/dist/lifeops/escalation-ladders.js +17 -0
- package/dist/lifeops/escalation-ladders.js.map +1 -0
- package/dist/lifeops/fda-probe.d.ts +23 -0
- package/dist/lifeops/fda-probe.d.ts.map +1 -0
- package/dist/lifeops/fda-probe.js +59 -0
- package/dist/lifeops/fda-probe.js.map +1 -0
- package/dist/lifeops/feature-flags.d.ts +24 -0
- package/dist/lifeops/feature-flags.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.js +261 -0
- package/dist/lifeops/feature-flags.js.map +1 -0
- package/dist/lifeops/feature-flags.types.d.ts +156 -0
- package/dist/lifeops/feature-flags.types.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.types.js +129 -0
- package/dist/lifeops/feature-flags.types.js.map +1 -0
- package/dist/lifeops/first-run/defaults.d.ts +57 -0
- package/dist/lifeops/first-run/defaults.d.ts.map +1 -0
- package/dist/lifeops/first-run/defaults.js +159 -0
- package/dist/lifeops/first-run/defaults.js.map +1 -0
- package/dist/lifeops/first-run/questions.d.ts +74 -0
- package/dist/lifeops/first-run/questions.d.ts.map +1 -0
- package/dist/lifeops/first-run/questions.js +184 -0
- package/dist/lifeops/first-run/questions.js.map +1 -0
- package/dist/lifeops/first-run/replay.d.ts +41 -0
- package/dist/lifeops/first-run/replay.d.ts.map +1 -0
- package/dist/lifeops/first-run/replay.js +34 -0
- package/dist/lifeops/first-run/replay.js.map +1 -0
- package/dist/lifeops/first-run/service.d.ts +147 -0
- package/dist/lifeops/first-run/service.d.ts.map +1 -0
- package/dist/lifeops/first-run/service.js +455 -0
- package/dist/lifeops/first-run/service.js.map +1 -0
- package/dist/lifeops/first-run/state.d.ts +36 -0
- package/dist/lifeops/first-run/state.d.ts.map +1 -0
- package/dist/lifeops/first-run/state.js +128 -0
- package/dist/lifeops/first-run/state.js.map +1 -0
- package/dist/lifeops/global-pause/store.d.ts +22 -0
- package/dist/lifeops/global-pause/store.d.ts.map +1 -0
- package/dist/lifeops/global-pause/store.js +18 -0
- package/dist/lifeops/global-pause/store.js.map +1 -0
- package/dist/lifeops/goal-grounding.d.ts +9 -0
- package/dist/lifeops/goal-grounding.d.ts.map +1 -0
- package/dist/lifeops/goal-grounding.js +19 -0
- package/dist/lifeops/goal-grounding.js.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts +8 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.js +7 -0
- package/dist/lifeops/goal-semantic-evaluator.js.map +1 -0
- package/dist/lifeops/google/format-helpers.d.ts +63 -0
- package/dist/lifeops/google/format-helpers.d.ts.map +1 -0
- package/dist/lifeops/google/format-helpers.js +597 -0
- package/dist/lifeops/google/format-helpers.js.map +1 -0
- package/dist/lifeops/google-plugin-delegates.d.ts +59 -0
- package/dist/lifeops/google-plugin-delegates.d.ts.map +1 -0
- package/dist/lifeops/google-plugin-delegates.js +408 -0
- package/dist/lifeops/google-plugin-delegates.js.map +1 -0
- package/dist/lifeops/google-scopes.d.ts +15 -0
- package/dist/lifeops/google-scopes.d.ts.map +1 -0
- package/dist/lifeops/google-scopes.js +118 -0
- package/dist/lifeops/google-scopes.js.map +1 -0
- package/dist/lifeops/handoff/store.d.ts +23 -0
- package/dist/lifeops/handoff/store.d.ts.map +1 -0
- package/dist/lifeops/handoff/store.js +20 -0
- package/dist/lifeops/handoff/store.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts +16 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.js +33 -0
- package/dist/lifeops/i18n/localized-examples-provider.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts +32 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js +28 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts +64 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.js +283 -0
- package/dist/lifeops/i18n/prompt-registry.js.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts +7 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.js +81 -0
- package/dist/lifeops/imessage-outbound-probe.js.map +1 -0
- package/dist/lifeops/index.d.ts +24 -0
- package/dist/lifeops/index.d.ts.map +1 -0
- package/dist/lifeops/index.js +24 -0
- package/dist/lifeops/index.js.map +1 -0
- package/dist/lifeops/intent-sync.d.ts +64 -0
- package/dist/lifeops/intent-sync.d.ts.map +1 -0
- package/dist/lifeops/intent-sync.js +321 -0
- package/dist/lifeops/intent-sync.js.map +1 -0
- package/dist/lifeops/messaging/index.d.ts +2 -0
- package/dist/lifeops/messaging/index.d.ts.map +1 -0
- package/dist/lifeops/messaging/index.js +5 -0
- package/dist/lifeops/messaging/index.js.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts +3 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.js +83 -0
- package/dist/lifeops/messaging/owner-send-policy.js.map +1 -0
- package/dist/lifeops/notifications-push.d.ts +37 -0
- package/dist/lifeops/notifications-push.d.ts.map +1 -0
- package/dist/lifeops/notifications-push.js +95 -0
- package/dist/lifeops/notifications-push.js.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts +5 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.js +48 -0
- package/dist/lifeops/optimized-prompt-instructions.js.map +1 -0
- package/dist/lifeops/owner/fact-store.d.ts +143 -0
- package/dist/lifeops/owner/fact-store.d.ts.map +1 -0
- package/dist/lifeops/owner/fact-store.js +446 -0
- package/dist/lifeops/owner/fact-store.js.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts +3 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js +241 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js.map +1 -0
- package/dist/lifeops/owner-profile.d.ts +61 -0
- package/dist/lifeops/owner-profile.d.ts.map +1 -0
- package/dist/lifeops/owner-profile.js +407 -0
- package/dist/lifeops/owner-profile.js.map +1 -0
- package/dist/lifeops/pending-prompts/store.d.ts +23 -0
- package/dist/lifeops/pending-prompts/store.d.ts.map +1 -0
- package/dist/lifeops/pending-prompts/store.js +16 -0
- package/dist/lifeops/pending-prompts/store.js.map +1 -0
- package/dist/lifeops/policy-memory.d.ts +190 -0
- package/dist/lifeops/policy-memory.d.ts.map +1 -0
- package/dist/lifeops/policy-memory.js +1026 -0
- package/dist/lifeops/policy-memory.js.map +1 -0
- package/dist/lifeops/priority-scoring.d.ts +51 -0
- package/dist/lifeops/priority-scoring.d.ts.map +1 -0
- package/dist/lifeops/priority-scoring.js +305 -0
- package/dist/lifeops/priority-scoring.js.map +1 -0
- package/dist/lifeops/privacy-egress.d.ts +92 -0
- package/dist/lifeops/privacy-egress.d.ts.map +1 -0
- package/dist/lifeops/privacy-egress.js +230 -0
- package/dist/lifeops/privacy-egress.js.map +1 -0
- package/dist/lifeops/privacy.d.ts +49 -0
- package/dist/lifeops/privacy.d.ts.map +1 -0
- package/dist/lifeops/privacy.js +66 -0
- package/dist/lifeops/privacy.js.map +1 -0
- package/dist/lifeops/redact-sensitive-data.d.ts +32 -0
- package/dist/lifeops/redact-sensitive-data.d.ts.map +1 -0
- package/dist/lifeops/redact-sensitive-data.js +98 -0
- package/dist/lifeops/redact-sensitive-data.js.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts +13 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.js +73 -0
- package/dist/lifeops/registries/app-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/blocker-registry.d.ts +76 -0
- package/dist/lifeops/registries/blocker-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/blocker-registry.js +40 -0
- package/dist/lifeops/registries/blocker-registry.js.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts +57 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.js +82 -0
- package/dist/lifeops/registries/event-kind-registry.js.map +1 -0
- package/dist/lifeops/registries/family-registry.d.ts +72 -0
- package/dist/lifeops/registries/family-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/family-registry.js +98 -0
- package/dist/lifeops/registries/family-registry.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts +32 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js +36 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts +76 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.js +68 -0
- package/dist/lifeops/registries/feature-flag-registry.js.map +1 -0
- package/dist/lifeops/registries/index.d.ts +24 -0
- package/dist/lifeops/registries/index.d.ts.map +1 -0
- package/dist/lifeops/registries/index.js +115 -0
- package/dist/lifeops/registries/index.js.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts +21 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.js +76 -0
- package/dist/lifeops/registries/website-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts +30 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js +315 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts +101 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.js +56 -0
- package/dist/lifeops/registries/workflow-step-registry.js.map +1 -0
- package/dist/lifeops/relationships/extraction.d.ts +77 -0
- package/dist/lifeops/relationships/extraction.d.ts.map +1 -0
- package/dist/lifeops/relationships/extraction.js +146 -0
- package/dist/lifeops/relationships/extraction.js.map +1 -0
- package/dist/lifeops/relationships/index.d.ts +4 -0
- package/dist/lifeops/relationships/index.d.ts.map +1 -0
- package/dist/lifeops/relationships/index.js +19 -0
- package/dist/lifeops/relationships/index.js.map +1 -0
- package/dist/lifeops/relationships/mapping.d.ts +34 -0
- package/dist/lifeops/relationships/mapping.d.ts.map +1 -0
- package/dist/lifeops/relationships/mapping.js +87 -0
- package/dist/lifeops/relationships/mapping.js.map +1 -0
- package/dist/lifeops/relationships/store.d.ts +12 -0
- package/dist/lifeops/relationships/store.d.ts.map +1 -0
- package/dist/lifeops/relationships/store.js +5 -0
- package/dist/lifeops/relationships/store.js.map +1 -0
- package/dist/lifeops/relationships/types.d.ts +9 -0
- package/dist/lifeops/relationships/types.d.ts.map +1 -0
- package/dist/lifeops/relationships/types.js +11 -0
- package/dist/lifeops/relationships/types.js.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts +13 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.js +107 -0
- package/dist/lifeops/relative-schedule-resolver.js.map +1 -0
- package/dist/lifeops/relative-time.d.ts +15 -0
- package/dist/lifeops/relative-time.d.ts.map +1 -0
- package/dist/lifeops/relative-time.js +191 -0
- package/dist/lifeops/relative-time.js.map +1 -0
- package/dist/lifeops/repository.d.ts +638 -0
- package/dist/lifeops/repository.d.ts.map +1 -0
- package/dist/lifeops/repository.js +6289 -0
- package/dist/lifeops/repository.js.map +1 -0
- package/dist/lifeops/runtime-cache.d.ts +4 -0
- package/dist/lifeops/runtime-cache.d.ts.map +1 -0
- package/dist/lifeops/runtime-cache.js +7 -0
- package/dist/lifeops/runtime-cache.js.map +1 -0
- package/dist/lifeops/runtime-service-delegates.d.ts +236 -0
- package/dist/lifeops/runtime-service-delegates.d.ts.map +1 -0
- package/dist/lifeops/runtime-service-delegates.js +839 -0
- package/dist/lifeops/runtime-service-delegates.js.map +1 -0
- package/dist/lifeops/runtime.d.ts +13 -0
- package/dist/lifeops/runtime.d.ts.map +1 -0
- package/dist/lifeops/runtime.js +104 -0
- package/dist/lifeops/runtime.js.map +1 -0
- package/dist/lifeops/schedule-insight.d.ts +133 -0
- package/dist/lifeops/schedule-insight.d.ts.map +1 -0
- package/dist/lifeops/schedule-insight.js +726 -0
- package/dist/lifeops/schedule-insight.js.map +1 -0
- package/dist/lifeops/schedule-state.d.ts +39 -0
- package/dist/lifeops/schedule-state.d.ts.map +1 -0
- package/dist/lifeops/schedule-state.js +671 -0
- package/dist/lifeops/schedule-state.js.map +1 -0
- package/dist/lifeops/schedule-sync-config.d.ts +3 -0
- package/dist/lifeops/schedule-sync-config.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-config.js +23 -0
- package/dist/lifeops/schedule-sync-config.js.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts +2 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.js +2 -0
- package/dist/lifeops/schedule-sync-contracts.js.map +1 -0
- package/dist/lifeops/scheduled-task/index.d.ts +13 -0
- package/dist/lifeops/scheduled-task/index.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/index.js +14 -0
- package/dist/lifeops/scheduled-task/index.js.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts +33 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js +334 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts +28 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.js +202 -0
- package/dist/lifeops/scheduled-task/scheduler.js.map +1 -0
- package/dist/lifeops/scheduled-task/service.d.ts +61 -0
- package/dist/lifeops/scheduled-task/service.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/service.js +64 -0
- package/dist/lifeops/scheduled-task/service.js.map +1 -0
- package/dist/lifeops/scheduler-task.d.ts +19 -0
- package/dist/lifeops/scheduler-task.d.ts.map +1 -0
- package/dist/lifeops/scheduler-task.js +201 -0
- package/dist/lifeops/scheduler-task.js.map +1 -0
- package/dist/lifeops/schema.d.ts +28068 -0
- package/dist/lifeops/schema.d.ts.map +1 -0
- package/dist/lifeops/schema.js +1689 -0
- package/dist/lifeops/schema.js.map +1 -0
- package/dist/lifeops/screen-context.d.ts +66 -0
- package/dist/lifeops/screen-context.d.ts.map +1 -0
- package/dist/lifeops/screen-context.js +347 -0
- package/dist/lifeops/screen-context.js.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts +113 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.js +142 -0
- package/dist/lifeops/seed-routine-migration/migrator.js.map +1 -0
- package/dist/lifeops/seed-routines.d.ts +24 -0
- package/dist/lifeops/seed-routines.d.ts.map +1 -0
- package/dist/lifeops/seed-routines.js +140 -0
- package/dist/lifeops/seed-routines.js.map +1 -0
- package/dist/lifeops/send-policy/contract.d.ts +81 -0
- package/dist/lifeops/send-policy/contract.d.ts.map +1 -0
- package/dist/lifeops/send-policy/contract.js +1 -0
- package/dist/lifeops/send-policy/contract.js.map +1 -0
- package/dist/lifeops/send-policy/index.d.ts +3 -0
- package/dist/lifeops/send-policy/index.d.ts.map +1 -0
- package/dist/lifeops/send-policy/index.js +13 -0
- package/dist/lifeops/send-policy/index.js.map +1 -0
- package/dist/lifeops/send-policy/registry.d.ts +7 -0
- package/dist/lifeops/send-policy/registry.d.ts.map +1 -0
- package/dist/lifeops/send-policy/registry.js +62 -0
- package/dist/lifeops/send-policy/registry.js.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts +46 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.js +103 -0
- package/dist/lifeops/sensitive-request-delivery.js.map +1 -0
- package/dist/lifeops/service-constants.d.ts +10 -0
- package/dist/lifeops/service-constants.d.ts.map +1 -0
- package/dist/lifeops/service-constants.js +129 -0
- package/dist/lifeops/service-constants.js.map +1 -0
- package/dist/lifeops/service-helpers-browser.d.ts +41 -0
- package/dist/lifeops/service-helpers-browser.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-browser.js +290 -0
- package/dist/lifeops/service-helpers-browser.js.map +1 -0
- package/dist/lifeops/service-helpers-misc.d.ts +68 -0
- package/dist/lifeops/service-helpers-misc.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-misc.js +531 -0
- package/dist/lifeops/service-helpers-misc.js.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts +23 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.js +257 -0
- package/dist/lifeops/service-helpers-occurrence.js.map +1 -0
- package/dist/lifeops/service-helpers-reminder.d.ts +260 -0
- package/dist/lifeops/service-helpers-reminder.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-reminder.js +1186 -0
- package/dist/lifeops/service-helpers-reminder.js.map +1 -0
- package/dist/lifeops/service-mixin-browser.d.ts +31 -0
- package/dist/lifeops/service-mixin-browser.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-browser.js +975 -0
- package/dist/lifeops/service-mixin-browser.js.map +1 -0
- package/dist/lifeops/service-mixin-calendar.d.ts +53 -0
- package/dist/lifeops/service-mixin-calendar.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-calendar.js +68 -0
- package/dist/lifeops/service-mixin-calendar.js.map +1 -0
- package/dist/lifeops/service-mixin-core.d.ts +51 -0
- package/dist/lifeops/service-mixin-core.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-core.js +500 -0
- package/dist/lifeops/service-mixin-core.js.map +1 -0
- package/dist/lifeops/service-mixin-definitions.d.ts +14 -0
- package/dist/lifeops/service-mixin-definitions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-definitions.js +470 -0
- package/dist/lifeops/service-mixin-definitions.js.map +1 -0
- package/dist/lifeops/service-mixin-discord.d.ts +49 -0
- package/dist/lifeops/service-mixin-discord.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-discord.js +1253 -0
- package/dist/lifeops/service-mixin-discord.js.map +1 -0
- package/dist/lifeops/service-mixin-drive.d.ts +96 -0
- package/dist/lifeops/service-mixin-drive.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-drive.js +213 -0
- package/dist/lifeops/service-mixin-drive.js.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts +23 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js +27 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js.map +1 -0
- package/dist/lifeops/service-mixin-gmail.d.ts +43 -0
- package/dist/lifeops/service-mixin-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-gmail.js +727 -0
- package/dist/lifeops/service-mixin-gmail.js.map +1 -0
- package/dist/lifeops/service-mixin-goals.d.ts +22 -0
- package/dist/lifeops/service-mixin-goals.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-goals.js +884 -0
- package/dist/lifeops/service-mixin-goals.js.map +1 -0
- package/dist/lifeops/service-mixin-google.d.ts +13 -0
- package/dist/lifeops/service-mixin-google.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-google.js +398 -0
- package/dist/lifeops/service-mixin-google.js.map +1 -0
- package/dist/lifeops/service-mixin-health.d.ts +27 -0
- package/dist/lifeops/service-mixin-health.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-health.js +670 -0
- package/dist/lifeops/service-mixin-health.js.map +1 -0
- package/dist/lifeops/service-mixin-imessage.d.ts +106 -0
- package/dist/lifeops/service-mixin-imessage.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-imessage.js +303 -0
- package/dist/lifeops/service-mixin-imessage.js.map +1 -0
- package/dist/lifeops/service-mixin-inbox.d.ts +55 -0
- package/dist/lifeops/service-mixin-inbox.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-inbox.js +597 -0
- package/dist/lifeops/service-mixin-inbox.js.map +1 -0
- package/dist/lifeops/service-mixin-relationships.d.ts +65 -0
- package/dist/lifeops/service-mixin-relationships.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-relationships.js +150 -0
- package/dist/lifeops/service-mixin-relationships.js.map +1 -0
- package/dist/lifeops/service-mixin-reminders.d.ts +62 -0
- package/dist/lifeops/service-mixin-reminders.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-reminders.js +4003 -0
- package/dist/lifeops/service-mixin-reminders.js.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts +53 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.js +405 -0
- package/dist/lifeops/service-mixin-scheduling.js.map +1 -0
- package/dist/lifeops/service-mixin-screentime.d.ts +71 -0
- package/dist/lifeops/service-mixin-screentime.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-screentime.js +530 -0
- package/dist/lifeops/service-mixin-screentime.js.map +1 -0
- package/dist/lifeops/service-mixin-signal.d.ts +74 -0
- package/dist/lifeops/service-mixin-signal.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-signal.js +214 -0
- package/dist/lifeops/service-mixin-signal.js.map +1 -0
- package/dist/lifeops/service-mixin-sleep.d.ts +68 -0
- package/dist/lifeops/service-mixin-sleep.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-sleep.js +43 -0
- package/dist/lifeops/service-mixin-sleep.js.map +1 -0
- package/dist/lifeops/service-mixin-status.d.ts +31 -0
- package/dist/lifeops/service-mixin-status.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-status.js +373 -0
- package/dist/lifeops/service-mixin-status.js.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts +101 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.js +50 -0
- package/dist/lifeops/service-mixin-subscriptions.js.map +1 -0
- package/dist/lifeops/service-mixin-telegram.d.ts +104 -0
- package/dist/lifeops/service-mixin-telegram.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-telegram.js +280 -0
- package/dist/lifeops/service-mixin-telegram.js.map +1 -0
- package/dist/lifeops/service-mixin-travel.d.ts +66 -0
- package/dist/lifeops/service-mixin-travel.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-travel.js +275 -0
- package/dist/lifeops/service-mixin-travel.js.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts +96 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.js +186 -0
- package/dist/lifeops/service-mixin-whatsapp.js.map +1 -0
- package/dist/lifeops/service-mixin-workflows.d.ts +15 -0
- package/dist/lifeops/service-mixin-workflows.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-workflows.js +710 -0
- package/dist/lifeops/service-mixin-workflows.js.map +1 -0
- package/dist/lifeops/service-mixin-x-read.d.ts +31 -0
- package/dist/lifeops/service-mixin-x-read.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x-read.js +267 -0
- package/dist/lifeops/service-mixin-x-read.js.map +1 -0
- package/dist/lifeops/service-mixin-x.d.ts +66 -0
- package/dist/lifeops/service-mixin-x.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x.js +501 -0
- package/dist/lifeops/service-mixin-x.js.map +1 -0
- package/dist/lifeops/service-normalize-connector.d.ts +19 -0
- package/dist/lifeops/service-normalize-connector.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-connector.js +816 -0
- package/dist/lifeops/service-normalize-connector.js.map +1 -0
- package/dist/lifeops/service-normalize-gmail.d.ts +11 -0
- package/dist/lifeops/service-normalize-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-gmail.js +85 -0
- package/dist/lifeops/service-normalize-gmail.js.map +1 -0
- package/dist/lifeops/service-normalize-task.d.ts +9 -0
- package/dist/lifeops/service-normalize-task.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-task.js +567 -0
- package/dist/lifeops/service-normalize-task.js.map +1 -0
- package/dist/lifeops/service-normalize.d.ts +9 -0
- package/dist/lifeops/service-normalize.d.ts.map +1 -0
- package/dist/lifeops/service-normalize.js +53 -0
- package/dist/lifeops/service-normalize.js.map +1 -0
- package/dist/lifeops/service-types.d.ts +75 -0
- package/dist/lifeops/service-types.d.ts.map +1 -0
- package/dist/lifeops/service-types.js +5 -0
- package/dist/lifeops/service-types.js.map +1 -0
- package/dist/lifeops/service.d.ts +482 -0
- package/dist/lifeops/service.d.ts.map +1 -0
- package/dist/lifeops/service.js +62 -0
- package/dist/lifeops/service.js.map +1 -0
- package/dist/lifeops/signal-runtime-config.d.ts +13 -0
- package/dist/lifeops/signal-runtime-config.d.ts.map +1 -0
- package/dist/lifeops/signal-runtime-config.js +44 -0
- package/dist/lifeops/signal-runtime-config.js.map +1 -0
- package/dist/lifeops/signals/bus.d.ts +78 -0
- package/dist/lifeops/signals/bus.d.ts.map +1 -0
- package/dist/lifeops/signals/bus.js +117 -0
- package/dist/lifeops/signals/bus.js.map +1 -0
- package/dist/lifeops/sql.d.ts +65 -0
- package/dist/lifeops/sql.d.ts.map +1 -0
- package/dist/lifeops/sql.js +182 -0
- package/dist/lifeops/sql.js.map +1 -0
- package/dist/lifeops/stretch-decider.d.ts +73 -0
- package/dist/lifeops/stretch-decider.d.ts.map +1 -0
- package/dist/lifeops/stretch-decider.js +49 -0
- package/dist/lifeops/stretch-decider.js.map +1 -0
- package/dist/lifeops/telemetry-mapping.d.ts +14 -0
- package/dist/lifeops/telemetry-mapping.d.ts.map +1 -0
- package/dist/lifeops/telemetry-mapping.js +115 -0
- package/dist/lifeops/telemetry-mapping.js.map +1 -0
- package/dist/lifeops/telemetry-retention.d.ts +21 -0
- package/dist/lifeops/telemetry-retention.d.ts.map +1 -0
- package/dist/lifeops/telemetry-retention.js +13 -0
- package/dist/lifeops/telemetry-retention.js.map +1 -0
- package/dist/lifeops/time/timezone.d.ts +4 -0
- package/dist/lifeops/time/timezone.d.ts.map +1 -0
- package/dist/lifeops/time/timezone.js +154 -0
- package/dist/lifeops/time/timezone.js.map +1 -0
- package/dist/lifeops/time-util.d.ts +10 -0
- package/dist/lifeops/time-util.d.ts.map +1 -0
- package/dist/lifeops/time-util.js +14 -0
- package/dist/lifeops/time-util.js.map +1 -0
- package/dist/lifeops/time.d.ts +17 -0
- package/dist/lifeops/time.d.ts.map +1 -0
- package/dist/lifeops/time.js +152 -0
- package/dist/lifeops/time.js.map +1 -0
- package/dist/lifeops/travel-booking.types.d.ts +46 -0
- package/dist/lifeops/travel-booking.types.d.ts.map +1 -0
- package/dist/lifeops/travel-booking.types.js +1 -0
- package/dist/lifeops/travel-booking.types.js.map +1 -0
- package/dist/lifeops/triggers/schedule-once.d.ts +19 -0
- package/dist/lifeops/triggers/schedule-once.d.ts.map +1 -0
- package/dist/lifeops/triggers/schedule-once.js +99 -0
- package/dist/lifeops/triggers/schedule-once.js.map +1 -0
- package/dist/lifeops/validate/coding-task-request.d.ts +18 -0
- package/dist/lifeops/validate/coding-task-request.d.ts.map +1 -0
- package/dist/lifeops/validate/coding-task-request.js +16 -0
- package/dist/lifeops/validate/coding-task-request.js.map +1 -0
- package/dist/lifeops/voice/grounded-reply.d.ts +41 -0
- package/dist/lifeops/voice/grounded-reply.d.ts.map +1 -0
- package/dist/lifeops/voice/grounded-reply.js +24 -0
- package/dist/lifeops/voice/grounded-reply.js.map +1 -0
- package/dist/lifeops/voice-affect.d.ts +79 -0
- package/dist/lifeops/voice-affect.d.ts.map +1 -0
- package/dist/lifeops/voice-affect.js +253 -0
- package/dist/lifeops/voice-affect.js.map +1 -0
- package/dist/lifeops/wave1-types.d.ts +125 -0
- package/dist/lifeops/wave1-types.d.ts.map +1 -0
- package/dist/lifeops/wave1-types.js +1 -0
- package/dist/lifeops/wave1-types.js.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts +33 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js +226 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js.map +1 -0
- package/dist/lifeops/work-threads/index.d.ts +3 -0
- package/dist/lifeops/work-threads/index.d.ts.map +1 -0
- package/dist/lifeops/work-threads/index.js +7 -0
- package/dist/lifeops/work-threads/index.js.map +1 -0
- package/dist/lifeops/work-threads/store.d.ts +91 -0
- package/dist/lifeops/work-threads/store.d.ts.map +1 -0
- package/dist/lifeops/work-threads/store.js +245 -0
- package/dist/lifeops/work-threads/store.js.map +1 -0
- package/dist/lifeops/work-threads/types.d.ts +58 -0
- package/dist/lifeops/work-threads/types.d.ts.map +1 -0
- package/dist/lifeops/work-threads/types.js +1 -0
- package/dist/lifeops/work-threads/types.js.map +1 -0
- package/dist/platform/host.d.ts +16 -0
- package/dist/platform/host.d.ts.map +1 -0
- package/dist/platform/host.js +22 -0
- package/dist/platform/host.js.map +1 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.d.ts.map +1 -0
- package/dist/platform/index.js +3 -0
- package/dist/platform/index.js.map +1 -0
- package/dist/platform/lifeops-github.d.ts +15 -0
- package/dist/platform/lifeops-github.d.ts.map +1 -0
- package/dist/platform/lifeops-github.js +146 -0
- package/dist/platform/lifeops-github.js.map +1 -0
- package/dist/plugin.d.ts +106 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +989 -0
- package/dist/plugin.js.map +1 -0
- package/dist/provider.d.ts +4 -0
- package/dist/provider.d.ts.map +1 -0
- package/dist/provider.js +108 -0
- package/dist/provider.js.map +1 -0
- package/dist/providers/activity-profile.d.ts +3 -0
- package/dist/providers/activity-profile.d.ts.map +1 -0
- package/dist/providers/activity-profile.js +140 -0
- package/dist/providers/activity-profile.js.map +1 -0
- package/dist/providers/cross-channel-context.d.ts +29 -0
- package/dist/providers/cross-channel-context.d.ts.map +1 -0
- package/dist/providers/cross-channel-context.js +206 -0
- package/dist/providers/cross-channel-context.js.map +1 -0
- package/dist/providers/first-run.d.ts +22 -0
- package/dist/providers/first-run.d.ts.map +1 -0
- package/dist/providers/first-run.js +93 -0
- package/dist/providers/first-run.js.map +1 -0
- package/dist/providers/health.d.ts +2 -0
- package/dist/providers/health.d.ts.map +1 -0
- package/dist/providers/health.js +14 -0
- package/dist/providers/health.js.map +1 -0
- package/dist/providers/inbox-triage.d.ts +3 -0
- package/dist/providers/inbox-triage.d.ts.map +1 -0
- package/dist/providers/inbox-triage.js +134 -0
- package/dist/providers/inbox-triage.js.map +1 -0
- package/dist/providers/lifeops.d.ts +3 -0
- package/dist/providers/lifeops.d.ts.map +1 -0
- package/dist/providers/lifeops.js +548 -0
- package/dist/providers/lifeops.js.map +1 -0
- package/dist/providers/pending-prompts.d.ts +38 -0
- package/dist/providers/pending-prompts.d.ts.map +1 -0
- package/dist/providers/pending-prompts.js +81 -0
- package/dist/providers/pending-prompts.js.map +1 -0
- package/dist/providers/recent-task-states.d.ts +52 -0
- package/dist/providers/recent-task-states.d.ts.map +1 -0
- package/dist/providers/recent-task-states.js +166 -0
- package/dist/providers/recent-task-states.js.map +1 -0
- package/dist/providers/room-policy.d.ts +16 -0
- package/dist/providers/room-policy.d.ts.map +1 -0
- package/dist/providers/room-policy.js +71 -0
- package/dist/providers/room-policy.js.map +1 -0
- package/dist/providers/work-threads.d.ts +3 -0
- package/dist/providers/work-threads.d.ts.map +1 -0
- package/dist/providers/work-threads.js +97 -0
- package/dist/providers/work-threads.js.map +1 -0
- package/dist/public.d.ts +3 -0
- package/dist/public.d.ts.map +1 -0
- package/dist/public.js +17 -0
- package/dist/public.js.map +1 -0
- package/dist/routes/cloud-features-routes.d.ts +9 -0
- package/dist/routes/cloud-features-routes.d.ts.map +1 -0
- package/dist/routes/cloud-features-routes.js +164 -0
- package/dist/routes/cloud-features-routes.js.map +1 -0
- package/dist/routes/entities.d.ts +14 -0
- package/dist/routes/entities.d.ts.map +1 -0
- package/dist/routes/entities.js +203 -0
- package/dist/routes/entities.js.map +1 -0
- package/dist/routes/lifeops-routes.d.ts +20 -0
- package/dist/routes/lifeops-routes.d.ts.map +1 -0
- package/dist/routes/lifeops-routes.js +2337 -0
- package/dist/routes/lifeops-routes.js.map +1 -0
- package/dist/routes/plugin.d.ts +9 -0
- package/dist/routes/plugin.d.ts.map +1 -0
- package/dist/routes/plugin.js +568 -0
- package/dist/routes/plugin.js.map +1 -0
- package/dist/routes/relationships.d.ts +13 -0
- package/dist/routes/relationships.d.ts.map +1 -0
- package/dist/routes/relationships.js +195 -0
- package/dist/routes/relationships.js.map +1 -0
- package/dist/routes/scheduled-tasks.d.ts +102 -0
- package/dist/routes/scheduled-tasks.d.ts.map +1 -0
- package/dist/routes/scheduled-tasks.js +322 -0
- package/dist/routes/scheduled-tasks.js.map +1 -0
- package/dist/routes/sleep-routes.d.ts +3 -0
- package/dist/routes/sleep-routes.d.ts.map +1 -0
- package/dist/routes/sleep-routes.js +33 -0
- package/dist/routes/sleep-routes.js.map +1 -0
- package/dist/routes/travel-provider-relay-routes.d.ts +2 -0
- package/dist/routes/travel-provider-relay-routes.d.ts.map +1 -0
- package/dist/routes/travel-provider-relay-routes.js +7 -0
- package/dist/routes/travel-provider-relay-routes.js.map +1 -0
- package/dist/routes/website-blocker-routes.d.ts +6 -0
- package/dist/routes/website-blocker-routes.d.ts.map +1 -0
- package/dist/routes/website-blocker-routes.js +218 -0
- package/dist/routes/website-blocker-routes.js.map +1 -0
- package/dist/security/action-confirmation.d.ts +12 -0
- package/dist/security/action-confirmation.d.ts.map +1 -0
- package/dist/security/action-confirmation.js +36 -0
- package/dist/security/action-confirmation.js.map +1 -0
- package/dist/service.d.ts +34 -0
- package/dist/service.d.ts.map +1 -0
- package/dist/service.js +111 -0
- package/dist/service.js.map +1 -0
- package/dist/travel-time/calendar-create.d.ts +17 -0
- package/dist/travel-time/calendar-create.d.ts.map +1 -0
- package/dist/travel-time/calendar-create.js +28 -0
- package/dist/travel-time/calendar-create.js.map +1 -0
- package/dist/travel-time/service.d.ts +114 -0
- package/dist/travel-time/service.d.ts.map +1 -0
- package/dist/travel-time/service.js +209 -0
- package/dist/travel-time/service.js.map +1 -0
- package/dist/types/app-blocker-settings-card.d.ts +2 -0
- package/dist/types/app-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/app-blocker-settings-card.js +1 -0
- package/dist/types/app-blocker-settings-card.js.map +1 -0
- package/dist/types/briefing.d.ts +59 -0
- package/dist/types/briefing.d.ts.map +1 -0
- package/dist/types/briefing.js +1 -0
- package/dist/types/briefing.js.map +1 -0
- package/dist/types/document-request.d.ts +41 -0
- package/dist/types/document-request.d.ts.map +1 -0
- package/dist/types/document-request.js +1 -0
- package/dist/types/document-request.js.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/website-blocker-settings-card.d.ts +2 -0
- package/dist/types/website-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/website-blocker-settings-card.js +1 -0
- package/dist/types/website-blocker-settings-card.js.map +1 -0
- package/dist/ui.d.ts +13 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +25 -0
- package/dist/ui.js.map +1 -0
- package/dist/utils/format-duration.d.ts +2 -0
- package/dist/utils/format-duration.d.ts.map +1 -0
- package/dist/utils/format-duration.js +13 -0
- package/dist/utils/format-duration.js.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +3 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/lifeops-url.d.ts +3 -0
- package/dist/utils/lifeops-url.d.ts.map +1 -0
- package/dist/utils/lifeops-url.js +28 -0
- package/dist/utils/lifeops-url.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts +32 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.js +30 -0
- package/dist/website-blocker/chat-integration/block-activator.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts +7 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js +115 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts +39 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js +133 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts +21 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js +230 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts +13 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js +22 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js.map +1 -0
- package/dist/website-blocker/chat-integration/index.d.ts +5 -0
- package/dist/website-blocker/chat-integration/index.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/index.js +26 -0
- package/dist/website-blocker/chat-integration/index.js.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts +75 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.js +154 -0
- package/dist/website-blocker/proactive-block-bridge.js.map +1 -0
- package/dist/website-blocker/public.d.ts +12 -0
- package/dist/website-blocker/public.d.ts.map +1 -0
- package/dist/website-blocker/public.js +51 -0
- package/dist/website-blocker/public.js.map +1 -0
- package/package.json +28 -28
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
import {
|
|
2
|
+
createOrder,
|
|
3
|
+
createPayment,
|
|
4
|
+
getOffer,
|
|
5
|
+
getOrder,
|
|
6
|
+
readDuffelConfigFromEnv,
|
|
7
|
+
searchFlights
|
|
8
|
+
} from "@elizaos/plugin-elizacloud/cloud/duffel-client";
|
|
9
|
+
const TRAVEL_CAPABILITIES = {
|
|
10
|
+
inbound: false,
|
|
11
|
+
outbound: "partial",
|
|
12
|
+
search: true,
|
|
13
|
+
identity: false,
|
|
14
|
+
attachments: false,
|
|
15
|
+
deliveryStatus: false
|
|
16
|
+
};
|
|
17
|
+
function choosePreparedOrderType(offer) {
|
|
18
|
+
return offer.paymentRequirements?.requiresInstantPayment === false ? "hold" : "instant";
|
|
19
|
+
}
|
|
20
|
+
function normalizePassengerValue(value) {
|
|
21
|
+
const trimmed = value?.trim();
|
|
22
|
+
return trimmed ? trimmed : null;
|
|
23
|
+
}
|
|
24
|
+
function resolveOfferPassengerId(offer, passenger, index) {
|
|
25
|
+
const explicit = normalizePassengerValue(passenger.offerPassengerId);
|
|
26
|
+
if (explicit) {
|
|
27
|
+
return explicit;
|
|
28
|
+
}
|
|
29
|
+
const fallback = offer.passengers[index]?.id?.trim();
|
|
30
|
+
if (fallback) {
|
|
31
|
+
return fallback;
|
|
32
|
+
}
|
|
33
|
+
throw new Error(
|
|
34
|
+
`Travel booking requires an offer passenger id for passenger ${index + 1}`
|
|
35
|
+
);
|
|
36
|
+
}
|
|
37
|
+
function buildItinerarySummary(offer) {
|
|
38
|
+
const firstSlice = offer.slices[0];
|
|
39
|
+
const lastSlice = offer.slices[offer.slices.length - 1];
|
|
40
|
+
if (!firstSlice || !lastSlice) {
|
|
41
|
+
return "Flight itinerary";
|
|
42
|
+
}
|
|
43
|
+
return `${firstSlice.origin} -> ${lastSlice.destination}`;
|
|
44
|
+
}
|
|
45
|
+
function buildCalendarTitle(offer, order, calendarSync) {
|
|
46
|
+
const custom = calendarSync?.title?.trim();
|
|
47
|
+
if (custom) {
|
|
48
|
+
return custom;
|
|
49
|
+
}
|
|
50
|
+
const route = buildItinerarySummary(offer);
|
|
51
|
+
return order.bookingReference ? `Flight ${route} (${order.bookingReference})` : `Flight ${route}`;
|
|
52
|
+
}
|
|
53
|
+
function buildCalendarDescription(offer, order, payment, calendarSync) {
|
|
54
|
+
const parts = [];
|
|
55
|
+
const custom = calendarSync?.description?.trim();
|
|
56
|
+
if (custom) {
|
|
57
|
+
parts.push(custom);
|
|
58
|
+
}
|
|
59
|
+
if (order.bookingReference) {
|
|
60
|
+
parts.push(`Booking reference: ${order.bookingReference}`);
|
|
61
|
+
}
|
|
62
|
+
parts.push(`Order id: ${order.id}`);
|
|
63
|
+
parts.push(`Total: ${order.totalAmount} ${order.totalCurrency}`);
|
|
64
|
+
if (payment?.id) {
|
|
65
|
+
parts.push(`Payment id: ${payment.id}`);
|
|
66
|
+
}
|
|
67
|
+
const documentIds = order.documents.map((document) => document.uniqueIdentifier).filter(
|
|
68
|
+
(value) => typeof value === "string" && value.length > 0
|
|
69
|
+
);
|
|
70
|
+
if (documentIds.length > 0) {
|
|
71
|
+
parts.push(`Documents: ${documentIds.join(", ")}`);
|
|
72
|
+
}
|
|
73
|
+
const carriers = offer.slices.flatMap(
|
|
74
|
+
(slice) => slice.segments.map((segment) => segment.carrierIataCode)
|
|
75
|
+
).filter((value, index, values) => value && values.indexOf(value) === index);
|
|
76
|
+
if (carriers.length > 0) {
|
|
77
|
+
parts.push(`Carriers: ${carriers.join(", ")}`);
|
|
78
|
+
}
|
|
79
|
+
return parts.join("\n");
|
|
80
|
+
}
|
|
81
|
+
function buildCalendarLocation(offer, calendarSync) {
|
|
82
|
+
const custom = calendarSync?.location?.trim();
|
|
83
|
+
if (custom) {
|
|
84
|
+
return custom;
|
|
85
|
+
}
|
|
86
|
+
const firstSlice = offer.slices[0];
|
|
87
|
+
const lastSlice = offer.slices[offer.slices.length - 1];
|
|
88
|
+
if (!firstSlice || !lastSlice) {
|
|
89
|
+
return "";
|
|
90
|
+
}
|
|
91
|
+
return `${firstSlice.origin} -> ${lastSlice.destination}`;
|
|
92
|
+
}
|
|
93
|
+
function firstDepartureAt(order) {
|
|
94
|
+
const segment = order.slices[0]?.segments[0];
|
|
95
|
+
if (!segment) {
|
|
96
|
+
throw new Error("Booked flight order has no departure segment");
|
|
97
|
+
}
|
|
98
|
+
return segment.departingAt;
|
|
99
|
+
}
|
|
100
|
+
function finalArrivalAt(order) {
|
|
101
|
+
const lastSlice = order.slices[order.slices.length - 1];
|
|
102
|
+
const segment = lastSlice?.segments[lastSlice.segments.length - 1];
|
|
103
|
+
if (!segment) {
|
|
104
|
+
throw new Error("Booked flight order has no arrival segment");
|
|
105
|
+
}
|
|
106
|
+
return segment.arrivingAt;
|
|
107
|
+
}
|
|
108
|
+
function withTravel(Base) {
|
|
109
|
+
const TravelBase = Base;
|
|
110
|
+
class LifeOpsTravelServiceMixin extends TravelBase {
|
|
111
|
+
getTravelConnectorStatus() {
|
|
112
|
+
try {
|
|
113
|
+
const config = readDuffelConfigFromEnv();
|
|
114
|
+
return {
|
|
115
|
+
provider: "travel",
|
|
116
|
+
connected: true,
|
|
117
|
+
adapter: "duffel",
|
|
118
|
+
mode: config.mode,
|
|
119
|
+
lastCheckedAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
120
|
+
};
|
|
121
|
+
} catch {
|
|
122
|
+
return {
|
|
123
|
+
provider: "travel",
|
|
124
|
+
connected: false,
|
|
125
|
+
adapter: null,
|
|
126
|
+
mode: null,
|
|
127
|
+
lastCheckedAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
async searchFlights(request) {
|
|
132
|
+
const config = readDuffelConfigFromEnv();
|
|
133
|
+
return searchFlights(request, config);
|
|
134
|
+
}
|
|
135
|
+
async getFlightOffer(offerId) {
|
|
136
|
+
const config = readDuffelConfigFromEnv();
|
|
137
|
+
return getOffer(offerId, config);
|
|
138
|
+
}
|
|
139
|
+
async prepareFlightBooking(args) {
|
|
140
|
+
if (args.passengers.length === 0) {
|
|
141
|
+
throw new Error("Travel booking requires at least one passenger");
|
|
142
|
+
}
|
|
143
|
+
let offer;
|
|
144
|
+
let offerRequestId = null;
|
|
145
|
+
if (args.offerId?.trim()) {
|
|
146
|
+
offer = await this.getFlightOffer(args.offerId.trim());
|
|
147
|
+
} else if (args.search) {
|
|
148
|
+
const result = await this.searchFlights(args.search);
|
|
149
|
+
const selectedOffer = result.offers[0];
|
|
150
|
+
if (!selectedOffer) {
|
|
151
|
+
throw new Error(
|
|
152
|
+
"Duffel returned no offers for the requested itinerary"
|
|
153
|
+
);
|
|
154
|
+
}
|
|
155
|
+
offer = await this.getFlightOffer(selectedOffer.id);
|
|
156
|
+
offerRequestId = result.offerRequestId;
|
|
157
|
+
} else {
|
|
158
|
+
throw new Error(
|
|
159
|
+
"Travel booking requires an offer id or a search request"
|
|
160
|
+
);
|
|
161
|
+
}
|
|
162
|
+
return {
|
|
163
|
+
offer,
|
|
164
|
+
orderType: choosePreparedOrderType(offer),
|
|
165
|
+
payload: {
|
|
166
|
+
kind: "flight",
|
|
167
|
+
provider: "duffel",
|
|
168
|
+
itineraryRef: offer.id,
|
|
169
|
+
totalCents: Math.round(Number(offer.totalAmount) * 100),
|
|
170
|
+
currency: offer.totalCurrency,
|
|
171
|
+
offerId: offer.id,
|
|
172
|
+
offerRequestId,
|
|
173
|
+
orderType: choosePreparedOrderType(offer),
|
|
174
|
+
search: args.search ?? null,
|
|
175
|
+
passengers: [...args.passengers],
|
|
176
|
+
calendarSync: args.calendarSync ?? {
|
|
177
|
+
enabled: true,
|
|
178
|
+
calendarId: "primary",
|
|
179
|
+
title: null,
|
|
180
|
+
description: null,
|
|
181
|
+
location: null,
|
|
182
|
+
timeZone: null
|
|
183
|
+
},
|
|
184
|
+
summary: buildItinerarySummary(offer)
|
|
185
|
+
}
|
|
186
|
+
};
|
|
187
|
+
}
|
|
188
|
+
async createFlightOrder(args) {
|
|
189
|
+
const config = readDuffelConfigFromEnv();
|
|
190
|
+
return createOrder(
|
|
191
|
+
{
|
|
192
|
+
selectedOffers: [args.offer.id],
|
|
193
|
+
type: args.orderType,
|
|
194
|
+
passengers: args.passengers.map((passenger, index) => ({
|
|
195
|
+
id: resolveOfferPassengerId(args.offer, passenger, index),
|
|
196
|
+
title: normalizePassengerValue(passenger.title) ?? void 0,
|
|
197
|
+
gender: normalizePassengerValue(passenger.gender) ?? void 0,
|
|
198
|
+
givenName: passenger.givenName.trim(),
|
|
199
|
+
familyName: passenger.familyName.trim(),
|
|
200
|
+
bornOn: passenger.bornOn.trim(),
|
|
201
|
+
email: normalizePassengerValue(passenger.email) ?? void 0,
|
|
202
|
+
phoneNumber: normalizePassengerValue(passenger.phoneNumber) ?? void 0
|
|
203
|
+
})),
|
|
204
|
+
payment: args.orderType === "instant" ? {
|
|
205
|
+
type: "balance",
|
|
206
|
+
amount: args.offer.totalAmount,
|
|
207
|
+
currency: args.offer.totalCurrency
|
|
208
|
+
} : void 0
|
|
209
|
+
},
|
|
210
|
+
config
|
|
211
|
+
);
|
|
212
|
+
}
|
|
213
|
+
async getTravelOrder(orderId) {
|
|
214
|
+
const config = readDuffelConfigFromEnv();
|
|
215
|
+
return getOrder(orderId, config);
|
|
216
|
+
}
|
|
217
|
+
async payTravelOrder(args) {
|
|
218
|
+
const config = readDuffelConfigFromEnv();
|
|
219
|
+
return createPayment(args, config);
|
|
220
|
+
}
|
|
221
|
+
async bookFlightItinerary(requestUrl, args) {
|
|
222
|
+
const prepared = await this.prepareFlightBooking(args);
|
|
223
|
+
const order = await this.createFlightOrder({
|
|
224
|
+
offer: prepared.offer,
|
|
225
|
+
passengers: args.passengers,
|
|
226
|
+
orderType: prepared.orderType
|
|
227
|
+
});
|
|
228
|
+
let refreshedOrder = order;
|
|
229
|
+
let payment = null;
|
|
230
|
+
if (prepared.orderType === "hold" && refreshedOrder.paymentStatus?.awaitingPayment) {
|
|
231
|
+
refreshedOrder = await this.getTravelOrder(order.id);
|
|
232
|
+
payment = await this.payTravelOrder({
|
|
233
|
+
orderId: refreshedOrder.id,
|
|
234
|
+
amount: refreshedOrder.totalAmount,
|
|
235
|
+
currency: refreshedOrder.totalCurrency
|
|
236
|
+
});
|
|
237
|
+
refreshedOrder = await this.getTravelOrder(order.id);
|
|
238
|
+
}
|
|
239
|
+
let calendarEvent = null;
|
|
240
|
+
const calendarSync = args.calendarSync ?? null;
|
|
241
|
+
if (calendarSync?.enabled !== false) {
|
|
242
|
+
calendarEvent = await this.createCalendarEvent(requestUrl, {
|
|
243
|
+
calendarId: calendarSync?.calendarId ?? "primary",
|
|
244
|
+
title: buildCalendarTitle(
|
|
245
|
+
prepared.offer,
|
|
246
|
+
refreshedOrder,
|
|
247
|
+
calendarSync
|
|
248
|
+
),
|
|
249
|
+
description: buildCalendarDescription(
|
|
250
|
+
prepared.offer,
|
|
251
|
+
refreshedOrder,
|
|
252
|
+
payment,
|
|
253
|
+
calendarSync
|
|
254
|
+
),
|
|
255
|
+
location: buildCalendarLocation(prepared.offer, calendarSync),
|
|
256
|
+
startAt: firstDepartureAt(refreshedOrder),
|
|
257
|
+
endAt: finalArrivalAt(refreshedOrder),
|
|
258
|
+
timeZone: calendarSync?.timeZone ?? void 0
|
|
259
|
+
});
|
|
260
|
+
}
|
|
261
|
+
return {
|
|
262
|
+
offer: prepared.offer,
|
|
263
|
+
order: refreshedOrder,
|
|
264
|
+
payment,
|
|
265
|
+
calendarEvent
|
|
266
|
+
};
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
return LifeOpsTravelServiceMixin;
|
|
270
|
+
}
|
|
271
|
+
export {
|
|
272
|
+
TRAVEL_CAPABILITIES,
|
|
273
|
+
withTravel
|
|
274
|
+
};
|
|
275
|
+
//# sourceMappingURL=service-mixin-travel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/service-mixin-travel.ts"],"sourcesContent":["import {\n createOrder,\n createPayment,\n type DuffelOffer,\n type DuffelOrder,\n type DuffelPayment,\n getOffer,\n getOrder,\n readDuffelConfigFromEnv,\n type SearchFlightsRequest,\n type SearchFlightsResult,\n searchFlights,\n} from \"@elizaos/plugin-elizacloud/cloud/duffel-client\";\nimport type { LifeOpsCalendarService } from \"./service-mixin-calendar.js\";\nimport type {\n Constructor,\n LifeOpsServiceBase,\n MixinClass,\n} from \"./service-mixin-core.js\";\nimport type {\n FlightBookingExecutionResult,\n PreparedFlightBooking,\n TravelBookingPassenger,\n TravelCalendarSyncPlan,\n} from \"./travel-booking.types.js\";\n\n// ---------------------------------------------------------------------------\n// Capability descriptor\n// ---------------------------------------------------------------------------\n\n/**\n * Capability descriptor for the travel connector.\n *\n * inbound: false — no inbound messages from travel providers.\n * outbound: 'partial' — flights can be searched and booked; hotel and\n * ground transport remain out of scope.\n * search: true — flight offer search via Duffel Offer Requests API.\n * identity: false — no per-user identity linking.\n * attachments: false — no file attachments.\n * deliveryStatus: false — provider-side delivery receipts do not apply.\n *\n * Scope: flights only. Hotels and car hire are outside this capability.\n */\nexport const TRAVEL_CAPABILITIES = {\n inbound: false,\n outbound: \"partial\",\n search: true,\n identity: false,\n attachments: false,\n deliveryStatus: false,\n} as const;\n\nexport type TravelCapabilities = typeof TRAVEL_CAPABILITIES;\n\n// ---------------------------------------------------------------------------\n// Connector status type\n// ---------------------------------------------------------------------------\n\nexport interface TravelConnectorStatus {\n provider: \"travel\";\n connected: boolean;\n adapter: \"duffel\" | null;\n /** \"cloud\" when routing through Eliza Cloud relay (default), \"direct\"\n * when ELIZA_DUFFEL_DIRECT=1 + DUFFEL_API_KEY are set. null when the\n * travel connector is unconfigured. */\n mode: \"cloud\" | \"direct\" | null;\n lastCheckedAt: string;\n}\n\ntype TravelMixinDependencies = LifeOpsServiceBase &\n Pick<LifeOpsCalendarService, \"createCalendarEvent\">;\n\nexport interface LifeOpsTravelServicePublic {\n getTravelConnectorStatus(): TravelConnectorStatus;\n searchFlights(request: SearchFlightsRequest): Promise<SearchFlightsResult>;\n getFlightOffer(offerId: string): Promise<DuffelOffer>;\n prepareFlightBooking(args: {\n offerId?: string | null;\n search?: SearchFlightsRequest | null;\n passengers: ReadonlyArray<TravelBookingPassenger>;\n calendarSync?: TravelCalendarSyncPlan | null;\n }): Promise<PreparedFlightBooking>;\n createFlightOrder(args: {\n offer: DuffelOffer;\n passengers: ReadonlyArray<TravelBookingPassenger>;\n orderType?: \"hold\" | \"instant\";\n }): Promise<DuffelOrder>;\n getTravelOrder(orderId: string): Promise<DuffelOrder>;\n payTravelOrder(args: {\n orderId: string;\n amount: string;\n currency: string;\n }): Promise<DuffelPayment>;\n bookFlightItinerary(\n requestUrl: URL,\n args: {\n offerId?: string | null;\n search?: SearchFlightsRequest | null;\n passengers: ReadonlyArray<TravelBookingPassenger>;\n calendarSync?: TravelCalendarSyncPlan | null;\n },\n ): Promise<FlightBookingExecutionResult>;\n}\n\nfunction choosePreparedOrderType(offer: DuffelOffer): \"hold\" | \"instant\" {\n return offer.paymentRequirements?.requiresInstantPayment === false\n ? \"hold\"\n : \"instant\";\n}\n\nfunction normalizePassengerValue(\n value: string | null | undefined,\n): string | null {\n const trimmed = value?.trim();\n return trimmed ? trimmed : null;\n}\n\nfunction resolveOfferPassengerId(\n offer: DuffelOffer,\n passenger: TravelBookingPassenger,\n index: number,\n): string {\n const explicit = normalizePassengerValue(passenger.offerPassengerId);\n if (explicit) {\n return explicit;\n }\n const fallback = offer.passengers[index]?.id?.trim();\n if (fallback) {\n return fallback;\n }\n throw new Error(\n `Travel booking requires an offer passenger id for passenger ${index + 1}`,\n );\n}\n\nfunction buildItinerarySummary(offer: DuffelOffer): string {\n const firstSlice = offer.slices[0];\n const lastSlice = offer.slices[offer.slices.length - 1];\n if (!firstSlice || !lastSlice) {\n return \"Flight itinerary\";\n }\n return `${firstSlice.origin} -> ${lastSlice.destination}`;\n}\n\nfunction buildCalendarTitle(\n offer: DuffelOffer,\n order: DuffelOrder,\n calendarSync: TravelCalendarSyncPlan | null | undefined,\n): string {\n const custom = calendarSync?.title?.trim();\n if (custom) {\n return custom;\n }\n const route = buildItinerarySummary(offer);\n return order.bookingReference\n ? `Flight ${route} (${order.bookingReference})`\n : `Flight ${route}`;\n}\n\nfunction buildCalendarDescription(\n offer: DuffelOffer,\n order: DuffelOrder,\n payment: DuffelPayment | null,\n calendarSync: TravelCalendarSyncPlan | null | undefined,\n): string {\n const parts: string[] = [];\n const custom = calendarSync?.description?.trim();\n if (custom) {\n parts.push(custom);\n }\n if (order.bookingReference) {\n parts.push(`Booking reference: ${order.bookingReference}`);\n }\n parts.push(`Order id: ${order.id}`);\n parts.push(`Total: ${order.totalAmount} ${order.totalCurrency}`);\n if (payment?.id) {\n parts.push(`Payment id: ${payment.id}`);\n }\n const documentIds = order.documents\n .map((document) => document.uniqueIdentifier)\n .filter(\n (value): value is string => typeof value === \"string\" && value.length > 0,\n );\n if (documentIds.length > 0) {\n parts.push(`Documents: ${documentIds.join(\", \")}`);\n }\n const carriers = offer.slices\n .flatMap((slice) =>\n slice.segments.map((segment) => segment.carrierIataCode),\n )\n .filter((value, index, values) => value && values.indexOf(value) === index);\n if (carriers.length > 0) {\n parts.push(`Carriers: ${carriers.join(\", \")}`);\n }\n return parts.join(\"\\n\");\n}\n\nfunction buildCalendarLocation(\n offer: DuffelOffer,\n calendarSync: TravelCalendarSyncPlan | null | undefined,\n): string {\n const custom = calendarSync?.location?.trim();\n if (custom) {\n return custom;\n }\n const firstSlice = offer.slices[0];\n const lastSlice = offer.slices[offer.slices.length - 1];\n if (!firstSlice || !lastSlice) {\n return \"\";\n }\n return `${firstSlice.origin} -> ${lastSlice.destination}`;\n}\n\nfunction firstDepartureAt(order: DuffelOrder): string {\n const segment = order.slices[0]?.segments[0];\n if (!segment) {\n throw new Error(\"Booked flight order has no departure segment\");\n }\n return segment.departingAt;\n}\n\nfunction finalArrivalAt(order: DuffelOrder): string {\n const lastSlice = order.slices[order.slices.length - 1];\n const segment = lastSlice?.segments[lastSlice.segments.length - 1];\n if (!segment) {\n throw new Error(\"Booked flight order has no arrival segment\");\n }\n return segment.arrivingAt;\n}\n\n// ---------------------------------------------------------------------------\n// Mixin\n// ---------------------------------------------------------------------------\n\n/** @internal */\nexport function withTravel<TBase extends Constructor<LifeOpsServiceBase>>(\n Base: TBase,\n): MixinClass<TBase, LifeOpsTravelServicePublic> {\n const TravelBase = Base as unknown as Constructor<TravelMixinDependencies>;\n\n class LifeOpsTravelServiceMixin extends TravelBase {\n getTravelConnectorStatus(): TravelConnectorStatus {\n try {\n const config = readDuffelConfigFromEnv();\n return {\n provider: \"travel\",\n connected: true,\n adapter: \"duffel\",\n mode: config.mode,\n lastCheckedAt: new Date().toISOString(),\n };\n } catch {\n return {\n provider: \"travel\",\n connected: false,\n adapter: null,\n mode: null,\n lastCheckedAt: new Date().toISOString(),\n };\n }\n }\n\n async searchFlights(\n request: SearchFlightsRequest,\n ): Promise<SearchFlightsResult> {\n const config = readDuffelConfigFromEnv();\n return searchFlights(request, config);\n }\n\n async getFlightOffer(offerId: string): Promise<DuffelOffer> {\n const config = readDuffelConfigFromEnv();\n return getOffer(offerId, config);\n }\n\n async prepareFlightBooking(args: {\n offerId?: string | null;\n search?: SearchFlightsRequest | null;\n passengers: ReadonlyArray<TravelBookingPassenger>;\n calendarSync?: TravelCalendarSyncPlan | null;\n }): Promise<PreparedFlightBooking> {\n if (args.passengers.length === 0) {\n throw new Error(\"Travel booking requires at least one passenger\");\n }\n\n let offer: DuffelOffer;\n let offerRequestId: string | null = null;\n\n if (args.offerId?.trim()) {\n offer = await this.getFlightOffer(args.offerId.trim());\n } else if (args.search) {\n const result = await this.searchFlights(args.search);\n const selectedOffer = result.offers[0];\n if (!selectedOffer) {\n throw new Error(\n \"Duffel returned no offers for the requested itinerary\",\n );\n }\n offer = await this.getFlightOffer(selectedOffer.id);\n offerRequestId = result.offerRequestId;\n } else {\n throw new Error(\n \"Travel booking requires an offer id or a search request\",\n );\n }\n\n return {\n offer,\n orderType: choosePreparedOrderType(offer),\n payload: {\n kind: \"flight\",\n provider: \"duffel\",\n itineraryRef: offer.id,\n totalCents: Math.round(Number(offer.totalAmount) * 100),\n currency: offer.totalCurrency,\n offerId: offer.id,\n offerRequestId,\n orderType: choosePreparedOrderType(offer),\n search: args.search ?? null,\n passengers: [...args.passengers],\n calendarSync: args.calendarSync ?? {\n enabled: true,\n calendarId: \"primary\",\n title: null,\n description: null,\n location: null,\n timeZone: null,\n },\n summary: buildItinerarySummary(offer),\n },\n };\n }\n\n async createFlightOrder(args: {\n offer: DuffelOffer;\n passengers: ReadonlyArray<TravelBookingPassenger>;\n orderType: \"hold\" | \"instant\";\n }): Promise<DuffelOrder> {\n const config = readDuffelConfigFromEnv();\n return createOrder(\n {\n selectedOffers: [args.offer.id],\n type: args.orderType,\n passengers: args.passengers.map((passenger, index) => ({\n id: resolveOfferPassengerId(args.offer, passenger, index),\n title: normalizePassengerValue(passenger.title) ?? undefined,\n gender: normalizePassengerValue(passenger.gender) ?? undefined,\n givenName: passenger.givenName.trim(),\n familyName: passenger.familyName.trim(),\n bornOn: passenger.bornOn.trim(),\n email: normalizePassengerValue(passenger.email) ?? undefined,\n phoneNumber:\n normalizePassengerValue(passenger.phoneNumber) ?? undefined,\n })),\n payment:\n args.orderType === \"instant\"\n ? {\n type: \"balance\",\n amount: args.offer.totalAmount,\n currency: args.offer.totalCurrency,\n }\n : undefined,\n },\n config,\n );\n }\n\n async getTravelOrder(orderId: string): Promise<DuffelOrder> {\n const config = readDuffelConfigFromEnv();\n return getOrder(orderId, config);\n }\n\n async payTravelOrder(args: {\n orderId: string;\n amount: string;\n currency: string;\n }): Promise<DuffelPayment> {\n const config = readDuffelConfigFromEnv();\n return createPayment(args, config);\n }\n\n async bookFlightItinerary(\n requestUrl: URL,\n args: {\n offerId?: string | null;\n search?: SearchFlightsRequest | null;\n passengers: ReadonlyArray<TravelBookingPassenger>;\n calendarSync?: TravelCalendarSyncPlan | null;\n },\n ): Promise<FlightBookingExecutionResult> {\n const prepared = await this.prepareFlightBooking(args);\n const order = await this.createFlightOrder({\n offer: prepared.offer,\n passengers: args.passengers,\n orderType: prepared.orderType,\n });\n\n let refreshedOrder = order;\n let payment: DuffelPayment | null = null;\n if (\n prepared.orderType === \"hold\" &&\n refreshedOrder.paymentStatus?.awaitingPayment\n ) {\n refreshedOrder = await this.getTravelOrder(order.id);\n payment = await this.payTravelOrder({\n orderId: refreshedOrder.id,\n amount: refreshedOrder.totalAmount,\n currency: refreshedOrder.totalCurrency,\n });\n refreshedOrder = await this.getTravelOrder(order.id);\n }\n\n let calendarEvent: Awaited<\n ReturnType<LifeOpsCalendarService[\"createCalendarEvent\"]>\n > | null = null;\n const calendarSync = args.calendarSync ?? null;\n if (calendarSync?.enabled !== false) {\n calendarEvent = await this.createCalendarEvent(requestUrl, {\n calendarId: calendarSync?.calendarId ?? \"primary\",\n title: buildCalendarTitle(\n prepared.offer,\n refreshedOrder,\n calendarSync,\n ),\n description: buildCalendarDescription(\n prepared.offer,\n refreshedOrder,\n payment,\n calendarSync,\n ),\n location: buildCalendarLocation(prepared.offer, calendarSync),\n startAt: firstDepartureAt(refreshedOrder),\n endAt: finalArrivalAt(refreshedOrder),\n timeZone: calendarSync?.timeZone ?? undefined,\n });\n }\n\n return {\n offer: prepared.offer,\n order: refreshedOrder,\n payment,\n calendarEvent,\n };\n }\n }\n\n return LifeOpsTravelServiceMixin as unknown as MixinClass<\n TBase,\n LifeOpsTravelServicePublic\n >;\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import type { LifeOpsWhatsAppConnectorStatus } from "@elizaos/shared";
|
|
2
|
+
import type { Constructor, LifeOpsServiceBase } from "./service-mixin-core.js";
|
|
3
|
+
type WhatsAppSendRequest = {
|
|
4
|
+
to: string;
|
|
5
|
+
text: string;
|
|
6
|
+
replyToMessageId?: string;
|
|
7
|
+
};
|
|
8
|
+
type WhatsAppMessage = {
|
|
9
|
+
id: string;
|
|
10
|
+
from: string;
|
|
11
|
+
channelId: string;
|
|
12
|
+
timestamp: string;
|
|
13
|
+
type: "text" | "image" | "audio" | "document" | "unknown";
|
|
14
|
+
text?: string;
|
|
15
|
+
metadata?: Record<string, unknown>;
|
|
16
|
+
};
|
|
17
|
+
/** @internal */
|
|
18
|
+
export declare function withWhatsApp<TBase extends Constructor<LifeOpsServiceBase>>(Base: TBase): {
|
|
19
|
+
new (...args: any[]): {
|
|
20
|
+
getWhatsAppConnectorStatus(): Promise<LifeOpsWhatsAppConnectorStatus>;
|
|
21
|
+
sendWhatsAppMessage(req: WhatsAppSendRequest): Promise<{
|
|
22
|
+
ok: true;
|
|
23
|
+
messageId: string;
|
|
24
|
+
}>;
|
|
25
|
+
ingestWhatsAppWebhook(payload: unknown): Promise<{
|
|
26
|
+
ingested: number;
|
|
27
|
+
messages: WhatsAppMessage[];
|
|
28
|
+
}>;
|
|
29
|
+
/**
|
|
30
|
+
* Backward-compatible alias for the plugin-managed recent-message read.
|
|
31
|
+
* WhatsApp webhook parsing and message storage live in plugin-whatsapp.
|
|
32
|
+
*/
|
|
33
|
+
syncWhatsAppInbound(): Promise<{
|
|
34
|
+
drained: number;
|
|
35
|
+
messages: WhatsAppMessage[];
|
|
36
|
+
}>;
|
|
37
|
+
/** Return recent WhatsApp messages from plugin-whatsapp. */
|
|
38
|
+
pullWhatsAppRecent(limit?: number): Promise<{
|
|
39
|
+
count: number;
|
|
40
|
+
messages: WhatsAppMessage[];
|
|
41
|
+
}>;
|
|
42
|
+
readonly repository: import("./repository.js").LifeOpsRepository;
|
|
43
|
+
readonly explicitOwnerEntityIdValue: string | null;
|
|
44
|
+
readonly ownerEntityIdValue: string;
|
|
45
|
+
readonly scheduleSyncClient: import("@elizaos/plugin-elizacloud/cloud/lifeops-schedule-sync-client").LifeOpsScheduleSyncClient;
|
|
46
|
+
ownerRoutingEntityIdPromise: Promise<string | null> | null;
|
|
47
|
+
adaptiveWindowPolicyCache: {
|
|
48
|
+
policy: ReturnType<typeof import("./defaults.js").computeAdaptiveWindowPolicy>;
|
|
49
|
+
computedAt: number;
|
|
50
|
+
} | null;
|
|
51
|
+
readonly runtime: import("@elizaos/core").IAgentRuntime;
|
|
52
|
+
agentId(): string;
|
|
53
|
+
ownerEntityId(): string;
|
|
54
|
+
ownerRoutingEntityId(): Promise<string | null>;
|
|
55
|
+
getBrowserSettingsInternal(): Promise<import("@elizaos/plugin-browser").BrowserBridgeSettings>;
|
|
56
|
+
isBrowserPaused(settings: import("@elizaos/plugin-browser").BrowserBridgeSettings): boolean;
|
|
57
|
+
requireBrowserAvailableForActions(actions: readonly import("@elizaos/plugin-browser").BrowserBridgeAction[]): Promise<import("@elizaos/plugin-browser").BrowserBridgeSettings>;
|
|
58
|
+
buildBrowserCompanion(request: import("@elizaos/plugin-browser").UpsertBrowserBridgeCompanionRequest, current: import("@elizaos/plugin-browser").BrowserBridgeCompanionStatus | null): import("@elizaos/plugin-browser").BrowserBridgeCompanionStatus;
|
|
59
|
+
normalizeOwnership(input: import("@elizaos/shared").LifeOpsOwnershipInput | undefined, current?: import("@elizaos/shared").LifeOpsOwnership): import("@elizaos/shared").LifeOpsOwnership;
|
|
60
|
+
normalizeChildOwnership(parent: import("@elizaos/shared").LifeOpsOwnership, input: import("@elizaos/shared").LifeOpsOwnershipInput | undefined, field?: string): import("@elizaos/shared").LifeOpsOwnership;
|
|
61
|
+
logLifeOpsWarn(operation: string, message: string, context?: Record<string, unknown>): void;
|
|
62
|
+
logLifeOpsError(operation: string, error: unknown, context?: Record<string, unknown>): void;
|
|
63
|
+
withReminderProcessingLock<T>(operation: () => Promise<T>): Promise<T>;
|
|
64
|
+
recordAudit(eventType: import("@elizaos/shared").LifeOpsAuditEventType, ownerType: "definition" | "occurrence" | "goal", ownerId: string, reason: string, inputs: Record<string, unknown>, decision: Record<string, unknown>): Promise<void>;
|
|
65
|
+
recordConnectorAudit(ownerId: string, reason: string, inputs: Record<string, unknown>, decision: Record<string, unknown>): Promise<void>;
|
|
66
|
+
recordChannelPolicyAudit(ownerId: string, reason: string, inputs: Record<string, unknown>, decision: Record<string, unknown>): Promise<void>;
|
|
67
|
+
recordWorkflowAudit(eventType: "workflow_created" | "workflow_updated" | "workflow_run", ownerId: string, actor: "user" | "workflow" | undefined, reason: string, inputs: Record<string, unknown>, decision: Record<string, unknown>): Promise<import("@elizaos/shared").LifeOpsAuditEvent>;
|
|
68
|
+
recordReminderAudit(eventType: "reminder_due" | "reminder_delivered" | "reminder_blocked" | "reminder_escalation_started" | "reminder_escalation_resolved", ownerType: "occurrence" | "calendar_event", ownerId: string, reason: string, inputs: Record<string, unknown>, decision: Record<string, unknown>): Promise<void>;
|
|
69
|
+
recordBrowserAudit(eventType: "browser_session_created" | "browser_session_updated", ownerId: string, reason: string, inputs: Record<string, unknown>, decision: Record<string, unknown>): Promise<void>;
|
|
70
|
+
recordXPostAudit(ownerId: string, reason: string, inputs: Record<string, unknown>, decision: Record<string, unknown>): Promise<void>;
|
|
71
|
+
clearGoogleGrantAuthFailure(grant: import("@elizaos/shared").LifeOpsConnectorGrant): Promise<import("@elizaos/shared").LifeOpsConnectorGrant>;
|
|
72
|
+
markGoogleGrantNeedsReauth(grant: import("@elizaos/shared").LifeOpsConnectorGrant, message: string): Promise<import("@elizaos/shared").LifeOpsConnectorGrant>;
|
|
73
|
+
emitAssistantEvent(text: string, source: string, data?: Record<string, unknown>): void;
|
|
74
|
+
getWorkflowDefinition(workflowId: string): Promise<import("@elizaos/shared").LifeOpsWorkflowDefinition>;
|
|
75
|
+
requireXGrant(requestedMode?: import("@elizaos/shared").LifeOpsConnectorMode): Promise<import("@elizaos/shared").LifeOpsConnectorGrant>;
|
|
76
|
+
};
|
|
77
|
+
} & TBase;
|
|
78
|
+
/**
|
|
79
|
+
* Public surface added by {@link withWhatsApp}. Hand-declared (not derived from
|
|
80
|
+
* the mixin instance, which would force full mixin evaluation) and listed on the
|
|
81
|
+
* `LifeOpsService` declaration-merge interface to surface these runtime methods —
|
|
82
|
+
* composition exceeds TypeScript's mixin inference depth.
|
|
83
|
+
*/
|
|
84
|
+
export interface LifeOpsWhatsAppService {
|
|
85
|
+
getWhatsAppConnectorStatus(): Promise<LifeOpsWhatsAppConnectorStatus>;
|
|
86
|
+
sendWhatsAppMessage(req: WhatsAppSendRequest): Promise<{
|
|
87
|
+
ok: true;
|
|
88
|
+
messageId: string;
|
|
89
|
+
}>;
|
|
90
|
+
pullWhatsAppRecent(limit?: number): Promise<{
|
|
91
|
+
count: number;
|
|
92
|
+
messages: WhatsAppMessage[];
|
|
93
|
+
}>;
|
|
94
|
+
}
|
|
95
|
+
export {};
|
|
96
|
+
//# sourceMappingURL=service-mixin-whatsapp.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-mixin-whatsapp.d.ts","sourceRoot":"","sources":["../../src/lifeops/service-mixin-whatsapp.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,8BAA8B,EAAE,MAAM,iBAAiB,CAAC;AAKtE,OAAO,KAAK,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAM/E,KAAK,mBAAmB,GAAG;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,KAAK,eAAe,GAAG;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,GAAG,OAAO,GAAG,OAAO,GAAG,UAAU,GAAG,SAAS,CAAC;IAC1D,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC,CAAC;AAuGF,gBAAgB;AAChB,wBAAgB,YAAY,CAAC,KAAK,SAAS,WAAW,CAAC,kBAAkB,CAAC,EACxE,IAAI,EAAE,KAAK;;sCAG2B,OAAO,CAAC,8BAA8B,CAAC;iCAmEpE,mBAAmB,GACvB,OAAO,CAAC;YAAE,EAAE,EAAE,IAAI,CAAC;YAAC,SAAS,EAAE,MAAM,CAAA;SAAE,CAAC;uCA6BhC,OAAO,GACf,OAAO,CAAC;YAAE,QAAQ,EAAE,MAAM,CAAC;YAAC,QAAQ,EAAE,eAAe,EAAE,CAAA;SAAE,CAAC;QAmB7D;;;WAGG;+BAC0B,OAAO,CAAC;YACnC,OAAO,EAAE,MAAM,CAAC;YAChB,QAAQ,EAAE,eAAe,EAAE,CAAC;SAC7B,CAAC;QAKF,4DAA4D;4CACtB,OAAO,CAAC;YAC5C,KAAK,EAAE,MAAM,CAAC;YACd,QAAQ,EAAE,eAAe,EAAE,CAAC;SAC7B,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAoBL;AAED;;;;;GAKG;AACH,MAAM,WAAW,sBAAsB;IACrC,0BAA0B,IAAI,OAAO,CAAC,8BAA8B,CAAC,CAAC;IACtE,mBAAmB,CACjB,GAAG,EAAE,mBAAmB,GACvB,OAAO,CAAC;QAAE,EAAE,EAAE,IAAI,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC5C,kBAAkB,CAChB,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,eAAe,EAAE,CAAA;KAAE,CAAC,CAAC;CAC5D"}
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import {
|
|
2
|
+
fetchWhatsAppMessagesWithRuntimeService,
|
|
3
|
+
sendWhatsAppMessageWithRuntimeService
|
|
4
|
+
} from "./runtime-service-delegates.js";
|
|
5
|
+
import { fail } from "./service-normalize.js";
|
|
6
|
+
const WHATSAPP_PLUGIN_SETUP_MESSAGE = "WhatsApp is managed by @elizaos/plugin-whatsapp. Configure and enable the WhatsApp connector plugin; LifeOps no longer sends with local WhatsApp credentials.";
|
|
7
|
+
function getWhatsAppRuntimeService(runtime) {
|
|
8
|
+
const service = runtime.getService?.(
|
|
9
|
+
"whatsapp"
|
|
10
|
+
);
|
|
11
|
+
return service && typeof service === "object" ? service : null;
|
|
12
|
+
}
|
|
13
|
+
function whatsAppServiceCanSend(service) {
|
|
14
|
+
return typeof service?.sendMessage === "function";
|
|
15
|
+
}
|
|
16
|
+
function whatsAppServiceCanRead(service) {
|
|
17
|
+
return typeof service?.fetchConnectorMessages === "function" || typeof service?.handleWebhook === "function";
|
|
18
|
+
}
|
|
19
|
+
function whatsAppServiceConnected(service) {
|
|
20
|
+
return Boolean(
|
|
21
|
+
service?.connected === true || service?.isServiceConnected?.() === true || whatsAppServiceCanSend(service) || whatsAppServiceCanRead(service)
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
function record(value) {
|
|
25
|
+
return value && typeof value === "object" ? value : {};
|
|
26
|
+
}
|
|
27
|
+
function stringField(value, fallback = "") {
|
|
28
|
+
return typeof value === "string" && value.length > 0 ? value : fallback;
|
|
29
|
+
}
|
|
30
|
+
function isoFromMemory(memory) {
|
|
31
|
+
const createdAt = Number(memory.createdAt);
|
|
32
|
+
return Number.isFinite(createdAt) && createdAt > 0 ? new Date(createdAt).toISOString() : (/* @__PURE__ */ new Date()).toISOString();
|
|
33
|
+
}
|
|
34
|
+
function memoryToWhatsAppMessage(memory) {
|
|
35
|
+
const metadata = record(memory.metadata);
|
|
36
|
+
const whatsapp = record(metadata.whatsapp);
|
|
37
|
+
const sender = record(metadata.sender);
|
|
38
|
+
const id = stringField(
|
|
39
|
+
whatsapp.messageId ?? metadata.messageIdFull ?? metadata.messageId ?? memory.id,
|
|
40
|
+
cryptoRandomFallback()
|
|
41
|
+
);
|
|
42
|
+
const channelId = stringField(
|
|
43
|
+
whatsapp.chatId ?? metadata.channelId ?? memory.roomId,
|
|
44
|
+
"unknown"
|
|
45
|
+
);
|
|
46
|
+
const from = stringField(
|
|
47
|
+
whatsapp.from ?? sender.id ?? sender.phone ?? memory.entityId,
|
|
48
|
+
channelId
|
|
49
|
+
);
|
|
50
|
+
return {
|
|
51
|
+
id,
|
|
52
|
+
from,
|
|
53
|
+
channelId,
|
|
54
|
+
timestamp: isoFromMemory(memory),
|
|
55
|
+
type: stringField(whatsapp.type, "text"),
|
|
56
|
+
text: stringField(memory.content.text),
|
|
57
|
+
metadata
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
function cryptoRandomFallback() {
|
|
61
|
+
return `whatsapp:${Date.now()}:${Math.random().toString(36).slice(2)}`;
|
|
62
|
+
}
|
|
63
|
+
function withWhatsApp(Base) {
|
|
64
|
+
class LifeOpsWhatsAppServiceMixin extends Base {
|
|
65
|
+
async getWhatsAppConnectorStatus() {
|
|
66
|
+
const runtimeService = getWhatsAppRuntimeService(this.runtime);
|
|
67
|
+
const serviceConnected = whatsAppServiceConnected(runtimeService);
|
|
68
|
+
const outboundReady = whatsAppServiceCanSend(runtimeService);
|
|
69
|
+
const inboundReady = whatsAppServiceCanRead(runtimeService);
|
|
70
|
+
const status = {
|
|
71
|
+
provider: "whatsapp",
|
|
72
|
+
connected: outboundReady || inboundReady,
|
|
73
|
+
inbound: true,
|
|
74
|
+
...runtimeService?.phoneNumber ? { phoneNumber: runtimeService.phoneNumber } : {},
|
|
75
|
+
localAuthAvailable: false,
|
|
76
|
+
localAuthRegistered: null,
|
|
77
|
+
serviceConnected,
|
|
78
|
+
outboundReady,
|
|
79
|
+
inboundReady,
|
|
80
|
+
transport: serviceConnected ? "baileys" : "unconfigured",
|
|
81
|
+
lastCheckedAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
82
|
+
};
|
|
83
|
+
const degradations = [];
|
|
84
|
+
if (!runtimeService) {
|
|
85
|
+
degradations.push({
|
|
86
|
+
axis: "delivery-degraded",
|
|
87
|
+
code: "whatsapp_plugin_unavailable",
|
|
88
|
+
message: WHATSAPP_PLUGIN_SETUP_MESSAGE,
|
|
89
|
+
retryable: true
|
|
90
|
+
});
|
|
91
|
+
} else if (!serviceConnected) {
|
|
92
|
+
degradations.push({
|
|
93
|
+
axis: "delivery-degraded",
|
|
94
|
+
code: "whatsapp_plugin_disconnected",
|
|
95
|
+
message: "The WhatsApp runtime service is registered but not connected. Reconnect the WhatsApp connector in @elizaos/plugin-whatsapp.",
|
|
96
|
+
retryable: true
|
|
97
|
+
});
|
|
98
|
+
} else {
|
|
99
|
+
if (!outboundReady) {
|
|
100
|
+
degradations.push({
|
|
101
|
+
axis: "delivery-degraded",
|
|
102
|
+
code: "whatsapp_plugin_send_unavailable",
|
|
103
|
+
message: "The WhatsApp runtime service is connected, but @elizaos/plugin-whatsapp does not expose a send path.",
|
|
104
|
+
retryable: true
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
if (!inboundReady) {
|
|
108
|
+
degradations.push({
|
|
109
|
+
axis: "transport-offline",
|
|
110
|
+
code: "whatsapp_plugin_inbound_unavailable",
|
|
111
|
+
message: "The WhatsApp runtime service is connected, but @elizaos/plugin-whatsapp does not expose webhook or message fetch handling.",
|
|
112
|
+
retryable: true
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
if (degradations.length > 0) {
|
|
117
|
+
status.degradations = degradations;
|
|
118
|
+
}
|
|
119
|
+
return status;
|
|
120
|
+
}
|
|
121
|
+
async sendWhatsAppMessage(req) {
|
|
122
|
+
const delegated = await sendWhatsAppMessageWithRuntimeService({
|
|
123
|
+
runtime: this.runtime,
|
|
124
|
+
request: req
|
|
125
|
+
});
|
|
126
|
+
if (delegated.status === "handled") {
|
|
127
|
+
return delegated.value;
|
|
128
|
+
}
|
|
129
|
+
if (delegated.error) {
|
|
130
|
+
this.logLifeOpsWarn(
|
|
131
|
+
"runtime_service_delegation_failed",
|
|
132
|
+
delegated.reason,
|
|
133
|
+
{
|
|
134
|
+
provider: "whatsapp",
|
|
135
|
+
operation: "message.send",
|
|
136
|
+
error: delegated.error instanceof Error ? delegated.error.message : String(delegated.error)
|
|
137
|
+
}
|
|
138
|
+
);
|
|
139
|
+
}
|
|
140
|
+
fail(
|
|
141
|
+
503,
|
|
142
|
+
`WhatsApp runtime service send is unavailable: ${delegated.reason} ${WHATSAPP_PLUGIN_SETUP_MESSAGE}`
|
|
143
|
+
);
|
|
144
|
+
}
|
|
145
|
+
async ingestWhatsAppWebhook(payload) {
|
|
146
|
+
const runtimeService = getWhatsAppRuntimeService(this.runtime);
|
|
147
|
+
if (runtimeService && typeof runtimeService.handleWebhook === "function" && payload && typeof payload === "object" && !Array.isArray(payload)) {
|
|
148
|
+
await runtimeService.handleWebhook(payload);
|
|
149
|
+
return { ingested: 0, messages: [] };
|
|
150
|
+
}
|
|
151
|
+
fail(
|
|
152
|
+
503,
|
|
153
|
+
`WhatsApp webhook ingestion is owned by @elizaos/plugin-whatsapp. ${WHATSAPP_PLUGIN_SETUP_MESSAGE}`
|
|
154
|
+
);
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Backward-compatible alias for the plugin-managed recent-message read.
|
|
158
|
+
* WhatsApp webhook parsing and message storage live in plugin-whatsapp.
|
|
159
|
+
*/
|
|
160
|
+
async syncWhatsAppInbound() {
|
|
161
|
+
const result = await this.pullWhatsAppRecent(100);
|
|
162
|
+
return { drained: result.count, messages: result.messages };
|
|
163
|
+
}
|
|
164
|
+
/** Return recent WhatsApp messages from plugin-whatsapp. */
|
|
165
|
+
async pullWhatsAppRecent(limit = 25) {
|
|
166
|
+
const clampedLimit = Math.min(Math.max(1, Math.floor(limit)), 500);
|
|
167
|
+
const delegated = await fetchWhatsAppMessagesWithRuntimeService({
|
|
168
|
+
runtime: this.runtime,
|
|
169
|
+
limit: clampedLimit
|
|
170
|
+
});
|
|
171
|
+
if (delegated.status !== "handled") {
|
|
172
|
+
fail(
|
|
173
|
+
delegated.reason.includes("not registered") ? 409 : 502,
|
|
174
|
+
delegated.error instanceof Error ? delegated.error.message : `${delegated.reason} ${WHATSAPP_PLUGIN_SETUP_MESSAGE}`
|
|
175
|
+
);
|
|
176
|
+
}
|
|
177
|
+
const messages = delegated.value.map(memoryToWhatsAppMessage);
|
|
178
|
+
return { count: messages.length, messages };
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
return LifeOpsWhatsAppServiceMixin;
|
|
182
|
+
}
|
|
183
|
+
export {
|
|
184
|
+
withWhatsApp
|
|
185
|
+
};
|
|
186
|
+
//# sourceMappingURL=service-mixin-whatsapp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/service-mixin-whatsapp.ts"],"sourcesContent":["import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { resolveDefaultAgentWorkspaceDir } from \"@elizaos/agent\";\nimport type { Memory, Plugin } from \"@elizaos/core\";\nimport { whatsappAuthExists } from \"@elizaos/plugin-whatsapp\";\nimport type { LifeOpsWhatsAppConnectorStatus } from \"@elizaos/shared\";\nimport {\n fetchWhatsAppMessagesWithRuntimeService,\n sendWhatsAppMessageWithRuntimeService,\n} from \"./runtime-service-delegates.js\";\nimport type { Constructor, LifeOpsServiceBase } from \"./service-mixin-core.js\";\nimport { fail } from \"./service-normalize.js\";\n\nconst WHATSAPP_PLUGIN_SETUP_MESSAGE =\n \"WhatsApp is managed by @elizaos/plugin-whatsapp. Configure and enable the WhatsApp connector plugin; LifeOps no longer sends with local WhatsApp credentials.\";\n\ntype WhatsAppSendRequest = {\n to: string;\n text: string;\n replyToMessageId?: string;\n};\n\ntype WhatsAppMessage = {\n id: string;\n from: string;\n channelId: string;\n timestamp: string;\n type: \"text\" | \"image\" | \"audio\" | \"document\" | \"unknown\";\n text?: string;\n metadata?: Record<string, unknown>;\n};\n\ntype WhatsAppRuntimeServiceLike = {\n connected?: boolean;\n isServiceConnected?: () => boolean;\n phoneNumber?: string | null;\n sendMessage?: (message: {\n accountId?: string;\n type: \"text\";\n to: string;\n content: string;\n replyToMessageId?: string;\n }) => Promise<{ messages?: Array<{ id?: string }> }>;\n fetchConnectorMessages?: unknown;\n handleWebhook?: (event: Record<string, unknown>) => Promise<void>;\n};\n\nfunction getWhatsAppRuntimeService(\n runtime: Constructor<LifeOpsServiceBase>[\"prototype\"][\"runtime\"],\n): WhatsAppRuntimeServiceLike | null {\n const service = runtime.getService?.(\n \"whatsapp\",\n ) as WhatsAppRuntimeServiceLike | null;\n return service && typeof service === \"object\" ? service : null;\n}\n\nfunction whatsAppServiceCanSend(\n service: WhatsAppRuntimeServiceLike | null,\n): boolean {\n return typeof service?.sendMessage === \"function\";\n}\n\nfunction whatsAppServiceCanRead(\n service: WhatsAppRuntimeServiceLike | null,\n): boolean {\n return (\n typeof service?.fetchConnectorMessages === \"function\" ||\n typeof service?.handleWebhook === \"function\"\n );\n}\n\nfunction whatsAppServiceConnected(\n service: WhatsAppRuntimeServiceLike | null,\n): boolean {\n return Boolean(\n service?.connected === true ||\n service?.isServiceConnected?.() === true ||\n whatsAppServiceCanSend(service) ||\n whatsAppServiceCanRead(service),\n );\n}\n\nfunction record(value: unknown): Record<string, unknown> {\n return value && typeof value === \"object\"\n ? (value as Record<string, unknown>)\n : {};\n}\n\nfunction stringField(value: unknown, fallback = \"\"): string {\n return typeof value === \"string\" && value.length > 0 ? value : fallback;\n}\n\nfunction isoFromMemory(memory: Memory): string {\n const createdAt = Number(memory.createdAt);\n return Number.isFinite(createdAt) && createdAt > 0\n ? new Date(createdAt).toISOString()\n : new Date().toISOString();\n}\n\nfunction memoryToWhatsAppMessage(memory: Memory): WhatsAppMessage {\n const metadata = record(memory.metadata);\n const whatsapp = record(metadata.whatsapp);\n const sender = record(metadata.sender);\n const id = stringField(\n whatsapp.messageId ??\n metadata.messageIdFull ??\n metadata.messageId ??\n memory.id,\n cryptoRandomFallback(),\n );\n const channelId = stringField(\n whatsapp.chatId ?? metadata.channelId ?? memory.roomId,\n \"unknown\",\n );\n const from = stringField(\n whatsapp.from ?? sender.id ?? sender.phone ?? memory.entityId,\n channelId,\n );\n return {\n id,\n from,\n channelId,\n timestamp: isoFromMemory(memory),\n type: stringField(whatsapp.type, \"text\") as WhatsAppMessage[\"type\"],\n text: stringField(memory.content.text),\n metadata,\n };\n}\n\nfunction cryptoRandomFallback(): string {\n return `whatsapp:${Date.now()}:${Math.random().toString(36).slice(2)}`;\n}\n\n/** @internal */\nexport function withWhatsApp<TBase extends Constructor<LifeOpsServiceBase>>(\n Base: TBase,\n) {\n class LifeOpsWhatsAppServiceMixin extends Base {\n async getWhatsAppConnectorStatus(): Promise<LifeOpsWhatsAppConnectorStatus> {\n const runtimeService = getWhatsAppRuntimeService(this.runtime);\n const serviceConnected = whatsAppServiceConnected(runtimeService);\n const outboundReady = whatsAppServiceCanSend(runtimeService);\n const inboundReady = whatsAppServiceCanRead(runtimeService);\n const status: LifeOpsWhatsAppConnectorStatus = {\n provider: \"whatsapp\",\n connected: outboundReady || inboundReady,\n inbound: true,\n ...(runtimeService?.phoneNumber\n ? { phoneNumber: runtimeService.phoneNumber }\n : {}),\n localAuthAvailable: false,\n localAuthRegistered: null,\n serviceConnected,\n outboundReady,\n inboundReady,\n transport: serviceConnected ? \"baileys\" : \"unconfigured\",\n lastCheckedAt: new Date().toISOString(),\n };\n\n const degradations: NonNullable<\n LifeOpsWhatsAppConnectorStatus[\"degradations\"]\n > = [];\n if (!runtimeService) {\n degradations.push({\n axis: \"delivery-degraded\",\n code: \"whatsapp_plugin_unavailable\",\n message: WHATSAPP_PLUGIN_SETUP_MESSAGE,\n retryable: true,\n });\n } else if (!serviceConnected) {\n degradations.push({\n axis: \"delivery-degraded\",\n code: \"whatsapp_plugin_disconnected\",\n message:\n \"The WhatsApp runtime service is registered but not connected. Reconnect the WhatsApp connector in @elizaos/plugin-whatsapp.\",\n retryable: true,\n });\n } else {\n if (!outboundReady) {\n degradations.push({\n axis: \"delivery-degraded\",\n code: \"whatsapp_plugin_send_unavailable\",\n message:\n \"The WhatsApp runtime service is connected, but @elizaos/plugin-whatsapp does not expose a send path.\",\n retryable: true,\n });\n }\n if (!inboundReady) {\n degradations.push({\n axis: \"transport-offline\",\n code: \"whatsapp_plugin_inbound_unavailable\",\n message:\n \"The WhatsApp runtime service is connected, but @elizaos/plugin-whatsapp does not expose webhook or message fetch handling.\",\n retryable: true,\n });\n }\n }\n if (degradations.length > 0) {\n status.degradations = degradations;\n }\n\n return status;\n }\n\n async sendWhatsAppMessage(\n req: WhatsAppSendRequest,\n ): Promise<{ ok: true; messageId: string }> {\n const delegated = await sendWhatsAppMessageWithRuntimeService({\n runtime: this.runtime,\n request: req,\n });\n if (delegated.status === \"handled\") {\n return delegated.value;\n }\n if (delegated.error) {\n this.logLifeOpsWarn(\n \"runtime_service_delegation_failed\",\n delegated.reason,\n {\n provider: \"whatsapp\",\n operation: \"message.send\",\n error:\n delegated.error instanceof Error\n ? delegated.error.message\n : String(delegated.error),\n },\n );\n }\n fail(\n 503,\n `WhatsApp runtime service send is unavailable: ${delegated.reason} ${WHATSAPP_PLUGIN_SETUP_MESSAGE}`,\n );\n }\n\n async ingestWhatsAppWebhook(\n payload: unknown,\n ): Promise<{ ingested: number; messages: WhatsAppMessage[] }> {\n const runtimeService = getWhatsAppRuntimeService(this.runtime);\n if (\n runtimeService &&\n typeof runtimeService.handleWebhook === \"function\" &&\n payload &&\n typeof payload === \"object\" &&\n !Array.isArray(payload)\n ) {\n await runtimeService.handleWebhook(payload as Record<string, unknown>);\n return { ingested: 0, messages: [] };\n }\n\n fail(\n 503,\n `WhatsApp webhook ingestion is owned by @elizaos/plugin-whatsapp. ${WHATSAPP_PLUGIN_SETUP_MESSAGE}`,\n );\n }\n\n /**\n * Backward-compatible alias for the plugin-managed recent-message read.\n * WhatsApp webhook parsing and message storage live in plugin-whatsapp.\n */\n async syncWhatsAppInbound(): Promise<{\n drained: number;\n messages: WhatsAppMessage[];\n }> {\n const result = await this.pullWhatsAppRecent(100);\n return { drained: result.count, messages: result.messages };\n }\n\n /** Return recent WhatsApp messages from plugin-whatsapp. */\n async pullWhatsAppRecent(limit = 25): Promise<{\n count: number;\n messages: WhatsAppMessage[];\n }> {\n const clampedLimit = Math.min(Math.max(1, Math.floor(limit)), 500);\n const delegated = await fetchWhatsAppMessagesWithRuntimeService({\n runtime: this.runtime,\n limit: clampedLimit,\n });\n if (delegated.status !== \"handled\") {\n fail(\n delegated.reason.includes(\"not registered\") ? 409 : 502,\n delegated.error instanceof Error\n ? delegated.error.message\n : `${delegated.reason} ${WHATSAPP_PLUGIN_SETUP_MESSAGE}`,\n );\n }\n const messages = delegated.value.map(memoryToWhatsAppMessage);\n return { count: messages.length, messages };\n }\n }\n\n return LifeOpsWhatsAppServiceMixin;\n}\n\n/**\n * Public surface added by {@link withWhatsApp}. Hand-declared (not derived from\n * the mixin instance, which would force full mixin evaluation) and listed on the\n * `LifeOpsService` declaration-merge interface to surface these runtime methods —\n * composition exceeds TypeScript's mixin inference depth.\n */\nexport interface LifeOpsWhatsAppService {\n getWhatsAppConnectorStatus(): Promise<LifeOpsWhatsAppConnectorStatus>;\n sendWhatsAppMessage(\n req: WhatsAppSendRequest,\n ): Promise<{ ok: true; messageId: string }>;\n pullWhatsAppRecent(\n limit?: number,\n ): Promise<{ count: number; messages: WhatsAppMessage[] }>;\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { CreateLifeOpsWorkflowRequest, LifeOpsCalendarEvent, LifeOpsCalendarEventEndedFilters, LifeOpsWorkflowRecord, LifeOpsWorkflowRun, UpdateLifeOpsWorkflowRequest } from "../contracts/index.js";
|
|
2
|
+
import type { Constructor, LifeOpsServiceBase, MixinClass } from "./service-mixin-core.js";
|
|
3
|
+
export interface LifeOpsWorkflowService {
|
|
4
|
+
listWorkflows(): Promise<LifeOpsWorkflowRecord[]>;
|
|
5
|
+
getWorkflow(workflowId: string): Promise<LifeOpsWorkflowRecord>;
|
|
6
|
+
createWorkflow(request: CreateLifeOpsWorkflowRequest): Promise<LifeOpsWorkflowRecord>;
|
|
7
|
+
updateWorkflow(workflowId: string, request: UpdateLifeOpsWorkflowRequest): Promise<LifeOpsWorkflowRecord>;
|
|
8
|
+
runWorkflow(workflowId: string, request?: {
|
|
9
|
+
now?: string;
|
|
10
|
+
confirmBrowserActions?: boolean;
|
|
11
|
+
}): Promise<LifeOpsWorkflowRun>;
|
|
12
|
+
}
|
|
13
|
+
export declare function matchesCalendarEventEndedFilters(event: LifeOpsCalendarEvent, filters: LifeOpsCalendarEventEndedFilters | undefined): boolean;
|
|
14
|
+
export declare function withWorkflows<TBase extends Constructor<LifeOpsServiceBase>>(Base: TBase): MixinClass<TBase, LifeOpsWorkflowService>;
|
|
15
|
+
//# sourceMappingURL=service-mixin-workflows.d.ts.map
|