@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 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/service-mixin-workflows.ts"],"sourcesContent":["import { computeNextCronRunAtMs } from \"@elizaos/agent\";\nimport type {\n CreateLifeOpsWorkflowRequest,\n LifeOpsCalendarEvent,\n LifeOpsCalendarEventEndedFilters,\n LifeOpsEventKind,\n LifeOpsWorkflowDefinition,\n LifeOpsWorkflowRecord,\n LifeOpsWorkflowRun,\n LifeOpsWorkflowSchedule,\n UpdateLifeOpsWorkflowRequest,\n} from \"../contracts/index.js\";\nimport { LIFEOPS_WORKFLOW_STATUSES } from \"../contracts/index.js\";\nimport {\n getWorkflowStepRegistry,\n UnknownWorkflowStepError,\n type WorkflowStepExecuteArgs,\n type WorkflowStepExecuteContext,\n} from \"./registries/workflow-step-registry.js\";\nimport { resolveNextRelativeScheduleInstant } from \"./relative-schedule-resolver.js\";\nimport {\n createLifeOpsWorkflowDefinition,\n createLifeOpsWorkflowRun,\n type LifeOpsScheduleMergedStateRecord,\n} from \"./repository.js\";\nimport { parseWorkflowSchedulerState } from \"./service-helpers-browser.js\";\nimport {\n isRecord,\n normalizeOptionalRecord,\n requireRecord,\n} from \"./service-helpers-misc.js\";\nimport type {\n Constructor,\n LifeOpsServiceBase,\n MixinClass,\n} from \"./service-mixin-core.js\";\nimport {\n fail,\n normalizeEnumValue,\n normalizeIsoString,\n normalizeOptionalBoolean,\n requireNonEmptyString,\n} from \"./service-normalize.js\";\nimport {\n normalizeWorkflowPermissionPolicy,\n normalizeWorkflowSchedule,\n normalizeWorkflowTriggerType,\n} from \"./service-normalize-connector.js\";\nimport { normalizeWorkflowActionPlan } from \"./service-normalize-task.js\";\nimport type {\n ExecuteWorkflowResult,\n LifeOpsWorkflowSchedulerState,\n} from \"./service-types.js\";\nimport { LifeOpsServiceError } from \"./service-types.js\";\nimport { addMinutes } from \"./time.js\";\n\nexport interface LifeOpsWorkflowService {\n listWorkflows(): Promise<LifeOpsWorkflowRecord[]>;\n getWorkflow(workflowId: string): Promise<LifeOpsWorkflowRecord>;\n createWorkflow(\n request: CreateLifeOpsWorkflowRequest,\n ): Promise<LifeOpsWorkflowRecord>;\n updateWorkflow(\n workflowId: string,\n request: UpdateLifeOpsWorkflowRequest,\n ): Promise<LifeOpsWorkflowRecord>;\n runWorkflow(\n workflowId: string,\n request?: { now?: string; confirmBrowserActions?: boolean },\n ): Promise<LifeOpsWorkflowRun>;\n}\n\ntype LifeOpsWorkflowEvent = {\n id: string;\n kind: LifeOpsEventKind;\n occurredAt: string;\n confidence: number;\n payload: Record<string, unknown>;\n};\n\ntype WorkflowEventSchedule = Extract<\n LifeOpsWorkflowSchedule,\n { kind: \"event\" }\n>;\n\ntype WorkflowMixinDependencies = LifeOpsServiceBase & {\n readEffectiveScheduleState(args?: {\n timezone?: string | null;\n now?: Date;\n }): Promise<LifeOpsScheduleMergedStateRecord | null>;\n emitWorkflowRunNudge(\n workflow: LifeOpsWorkflowDefinition,\n run: LifeOpsWorkflowRun,\n ): Promise<void>;\n};\n\nexport function matchesCalendarEventEndedFilters(\n event: LifeOpsCalendarEvent,\n filters: LifeOpsCalendarEventEndedFilters | undefined,\n): boolean {\n if (!filters) return true;\n if (\n filters.calendarIds &&\n filters.calendarIds.length > 0 &&\n !filters.calendarIds.includes(event.calendarId)\n ) {\n return false;\n }\n if (filters.titleIncludesAny && filters.titleIncludesAny.length > 0) {\n const title = event.title.toLowerCase();\n if (\n !filters.titleIncludesAny.some((needle) =>\n title.includes(needle.toLowerCase()),\n )\n ) {\n return false;\n }\n }\n if (typeof filters.minDurationMinutes === \"number\") {\n const durationMinutes =\n (Date.parse(event.endAt) - Date.parse(event.startAt)) / 60_000;\n if (\n !Number.isFinite(durationMinutes) ||\n durationMinutes < filters.minDurationMinutes\n ) {\n return false;\n }\n }\n if (\n filters.attendeeEmailIncludesAny &&\n filters.attendeeEmailIncludesAny.length > 0\n ) {\n const attendees = Array.isArray(event.attendees) ? event.attendees : [];\n const emails = attendees\n .map((attendee) =>\n attendee && typeof attendee === \"object\" && \"email\" in attendee\n ? String((attendee as { email?: unknown }).email ?? \"\").toLowerCase()\n : \"\",\n )\n .filter(Boolean);\n if (\n !filters.attendeeEmailIncludesAny.some((needle) =>\n emails.some((email) => email.includes(needle.toLowerCase())),\n )\n ) {\n return false;\n }\n }\n return true;\n}\n\nfunction matchesLifeOpsDerivedEventFilters(\n event: LifeOpsWorkflowEvent,\n filters: unknown,\n nowIso: string,\n): boolean {\n if (!filters || typeof filters !== \"object\" || Array.isArray(filters)) {\n return true;\n }\n const record = filters as Record<string, unknown>;\n if (\n typeof record.minConfidence === \"number\" &&\n event.confidence < record.minConfidence\n ) {\n return false;\n }\n if (typeof record.offsetMinutes === \"number\") {\n const dueAtMs =\n Date.parse(event.occurredAt) + record.offsetMinutes * 60_000;\n if (Date.parse(nowIso) < dueAtMs) {\n return false;\n }\n }\n if (\n event.kind === \"lifeops.bedtime.imminent\" &&\n typeof record.minutesBefore === \"number\"\n ) {\n const payloadMinutes = event.payload.minutesUntilBedtimeTarget;\n if (\n typeof payloadMinutes !== \"number\" ||\n payloadMinutes > record.minutesBefore\n ) {\n return false;\n }\n }\n if (\n event.kind === \"lifeops.regularity.changed\" &&\n typeof record.becomes === \"string\"\n ) {\n // The event fires on any class transition; the filter narrows to the\n // specific target class. The target class lands in the payload via the\n // merged state's regularity block.\n const payload = event.payload;\n const regularity =\n typeof payload === \"object\" && payload !== null\n ? (payload as { regularityClass?: unknown }).regularityClass\n : undefined;\n if (regularity !== record.becomes) {\n return false;\n }\n }\n if (\n event.kind === \"gmail.message.received\" ||\n event.kind === \"gmail.thread.needs_response\"\n ) {\n const payload = isRecord(event.payload) ? event.payload : {};\n const grantId = typeof payload.grantId === \"string\" ? payload.grantId : \"\";\n if (\n Array.isArray(record.grantIds) &&\n record.grantIds.length > 0 &&\n !record.grantIds.includes(grantId)\n ) {\n return false;\n }\n if (\n Array.isArray(record.fromIncludesAny) &&\n record.fromIncludesAny.length > 0\n ) {\n const sender =\n `${String(payload.from ?? \"\")} ${String(payload.fromEmail ?? \"\")}`.toLowerCase();\n if (\n !record.fromIncludesAny.some((needle) =>\n sender.includes(String(needle).toLowerCase()),\n )\n ) {\n return false;\n }\n }\n if (\n Array.isArray(record.subjectIncludesAny) &&\n record.subjectIncludesAny.length > 0\n ) {\n const subject = String(payload.subject ?? \"\").toLowerCase();\n if (\n !record.subjectIncludesAny.some((needle) =>\n subject.includes(String(needle).toLowerCase()),\n )\n ) {\n return false;\n }\n }\n if (Array.isArray(record.labelIds) && record.labelIds.length > 0) {\n const labels = new Set(\n Array.isArray(payload.labels)\n ? payload.labels.map((label) => String(label))\n : [],\n );\n if (!record.labelIds.some((labelId) => labels.has(String(labelId)))) {\n return false;\n }\n }\n if (\n typeof record.requiresReplyNeeded === \"boolean\" &&\n Boolean(payload.likelyReplyNeeded) !== record.requiresReplyNeeded\n ) {\n return false;\n }\n }\n return true;\n}\n\nexport function withWorkflows<TBase extends Constructor<LifeOpsServiceBase>>(\n Base: TBase,\n): MixinClass<TBase, LifeOpsWorkflowService> {\n const WorkflowsBase =\n Base as unknown as Constructor<WorkflowMixinDependencies>;\n\n class LifeOpsWorkflowServiceMixin extends WorkflowsBase {\n protected readWorkflowSchedulerState(\n workflow: LifeOpsWorkflowDefinition,\n ): LifeOpsWorkflowSchedulerState | null {\n return parseWorkflowSchedulerState(\n isRecord(workflow.metadata) ? workflow.metadata.lifeopsScheduler : null,\n );\n }\n\n public computeWorkflowNextDueAt(\n workflow: LifeOpsWorkflowDefinition,\n cursorIso?: string | null,\n ): string | null {\n if (workflow.triggerType !== \"schedule\") {\n return null;\n }\n const schedule = workflow.schedule;\n if (\n schedule.kind === \"manual\" ||\n schedule.kind === \"event\" ||\n schedule.kind === \"relative_to_wake\" ||\n schedule.kind === \"relative_to_bedtime\" ||\n schedule.kind === \"during_morning\" ||\n schedule.kind === \"during_night\"\n ) {\n return null;\n }\n if (schedule.kind === \"once\") {\n return cursorIso ? null : schedule.runAt;\n }\n if (schedule.kind === \"interval\") {\n const baseIso = cursorIso ?? workflow.createdAt;\n return addMinutes(\n new Date(baseIso),\n schedule.everyMinutes,\n ).toISOString();\n }\n const baseMs = cursorIso\n ? Date.parse(cursorIso)\n : Date.parse(workflow.createdAt) - 60_000;\n const nextRunMs = computeNextCronRunAtMs(\n schedule.cronExpression,\n baseMs,\n schedule.timezone,\n );\n return nextRunMs === null ? null : new Date(nextRunMs).toISOString();\n }\n\n public withWorkflowSchedulerState(\n workflow: LifeOpsWorkflowDefinition,\n state: LifeOpsWorkflowSchedulerState | null,\n ): LifeOpsWorkflowDefinition {\n const metadata = { ...workflow.metadata };\n if (state) {\n metadata.lifeopsScheduler = state;\n } else {\n delete metadata.lifeopsScheduler;\n }\n return {\n ...workflow,\n metadata,\n updatedAt: new Date().toISOString(),\n };\n }\n\n public initializeWorkflowSchedulerState(\n workflow: LifeOpsWorkflowDefinition,\n ): LifeOpsWorkflowDefinition {\n const currentState = this.readWorkflowSchedulerState(workflow);\n const targetState = this.buildInitialSchedulerState(workflow);\n if (\n (currentState === null && targetState === null) ||\n (currentState &&\n targetState &&\n currentState.nextDueAt === targetState.nextDueAt &&\n currentState.lastDueAt === targetState.lastDueAt &&\n currentState.lastRunId === targetState.lastRunId &&\n currentState.lastRunStatus === targetState.lastRunStatus &&\n (currentState.lastFiredEventEndAt ?? null) ===\n (targetState.lastFiredEventEndAt ?? null) &&\n (currentState.lastFiredEventId ?? null) ===\n (targetState.lastFiredEventId ?? null))\n ) {\n return workflow;\n }\n return this.withWorkflowSchedulerState(workflow, targetState);\n }\n\n buildInitialSchedulerState(\n workflow: LifeOpsWorkflowDefinition,\n ): LifeOpsWorkflowSchedulerState | null {\n if (workflow.triggerType === \"manual\") {\n return null;\n }\n if (workflow.triggerType === \"event\") {\n // Anchor the cursor at workflow creation so we never fire for events\n // that ended before the workflow existed.\n return {\n managedBy: \"task_worker\",\n nextDueAt: null,\n lastDueAt: null,\n lastRunId: null,\n lastRunStatus: null,\n updatedAt: new Date().toISOString(),\n lastFiredEventEndAt: workflow.createdAt,\n lastFiredEventId: null,\n };\n }\n if (workflow.schedule.kind === \"manual\") {\n return null;\n }\n return {\n managedBy: \"task_worker\",\n nextDueAt: this.computeWorkflowNextDueAt(workflow),\n lastDueAt: null,\n lastRunId: null,\n lastRunStatus: null,\n updatedAt: new Date().toISOString(),\n };\n }\n\n public async runDueWorkflows(args: {\n now: string;\n limit: number;\n }): Promise<LifeOpsWorkflowRun[]> {\n const nowMs = Date.parse(args.now);\n const workflows = await this.repository.listWorkflows(this.agentId());\n const runs: LifeOpsWorkflowRun[] = [];\n\n for (const workflow of workflows) {\n if (runs.length >= args.limit) {\n break;\n }\n if (\n workflow.status !== \"active\" ||\n workflow.triggerType !== \"schedule\" ||\n workflow.schedule.kind === \"manual\"\n ) {\n continue;\n }\n\n let nextWorkflow = workflow;\n const existingSchedulerState =\n this.readWorkflowSchedulerState(nextWorkflow);\n let schedulerState =\n existingSchedulerState ??\n ({\n managedBy: \"task_worker\",\n nextDueAt: this.computeWorkflowNextDueAt(nextWorkflow),\n lastDueAt: null,\n lastRunId: null,\n lastRunStatus: null,\n updatedAt: new Date().toISOString(),\n } satisfies LifeOpsWorkflowSchedulerState);\n let stateChanged = existingSchedulerState === null;\n if (\n schedulerState.nextDueAt === null &&\n (nextWorkflow.schedule.kind === \"relative_to_wake\" ||\n nextWorkflow.schedule.kind === \"relative_to_bedtime\" ||\n nextWorkflow.schedule.kind === \"during_morning\" ||\n nextWorkflow.schedule.kind === \"during_night\")\n ) {\n const effectiveSchedule = await this.readEffectiveScheduleState({\n timezone: nextWorkflow.schedule.timezone,\n now: new Date(args.now),\n });\n schedulerState = {\n ...schedulerState,\n nextDueAt: resolveNextRelativeScheduleInstant({\n schedule: nextWorkflow.schedule,\n state: effectiveSchedule,\n cursorIso: schedulerState.lastDueAt,\n nowMs: Date.parse(args.now),\n }),\n updatedAt: new Date().toISOString(),\n };\n stateChanged = true;\n }\n\n while (\n runs.length < args.limit &&\n schedulerState.nextDueAt &&\n Date.parse(schedulerState.nextDueAt) <= nowMs\n ) {\n const dueAt = schedulerState.nextDueAt;\n const { run, error } = await this.executeWorkflowDefinition(\n nextWorkflow,\n {\n startedAt: dueAt,\n confirmBrowserActions: false,\n request: {\n scheduledExecution: true,\n },\n },\n );\n runs.push(run);\n await this.emitWorkflowRunNudge(nextWorkflow, run);\n const nextDueAt =\n nextWorkflow.schedule.kind === \"relative_to_wake\" ||\n nextWorkflow.schedule.kind === \"relative_to_bedtime\" ||\n nextWorkflow.schedule.kind === \"during_morning\" ||\n nextWorkflow.schedule.kind === \"during_night\"\n ? resolveNextRelativeScheduleInstant({\n schedule: nextWorkflow.schedule,\n state: await this.readEffectiveScheduleState({\n timezone: nextWorkflow.schedule.timezone,\n now: new Date(args.now),\n }),\n cursorIso: dueAt,\n nowMs: Date.parse(args.now),\n })\n : this.computeWorkflowNextDueAt(nextWorkflow, dueAt);\n schedulerState = {\n managedBy: \"task_worker\",\n nextDueAt,\n lastDueAt: dueAt,\n lastRunId: run.id,\n lastRunStatus: run.status,\n updatedAt: new Date().toISOString(),\n };\n stateChanged = true;\n\n if (error) {\n this.logLifeOpsError(\"workflow_scheduled_execution\", error, {\n workflowId: nextWorkflow.id,\n workflowRunId: run.id,\n dueAt,\n });\n }\n }\n\n if (stateChanged) {\n nextWorkflow = this.withWorkflowSchedulerState(\n nextWorkflow,\n schedulerState,\n );\n await this.repository.updateWorkflow(nextWorkflow);\n }\n }\n\n return runs;\n }\n\n /**\n * Fires event-triggered workflows for calendar events that have ended since\n * the workflow's cursor. Uses a (end_at, id) tuple cursor per workflow so\n * repeated invocations never re-fire for the same event.\n */\n public async runDueEventWorkflows(args: {\n now: string;\n limit: number;\n lifeOpsEvents?: LifeOpsWorkflowEvent[];\n }): Promise<LifeOpsWorkflowRun[]> {\n const workflows = await this.repository.listWorkflows(this.agentId());\n const runs: LifeOpsWorkflowRun[] = [];\n\n for (const workflow of workflows) {\n if (runs.length >= args.limit) {\n break;\n }\n if (\n workflow.status !== \"active\" ||\n workflow.triggerType !== \"event\" ||\n workflow.schedule.kind !== \"event\"\n ) {\n continue;\n }\n const eventSchedule = workflow.schedule as WorkflowEventSchedule;\n let nextWorkflow = workflow;\n const existingState = this.readWorkflowSchedulerState(nextWorkflow);\n let schedulerState: LifeOpsWorkflowSchedulerState = existingState ?? {\n managedBy: \"task_worker\",\n nextDueAt: null,\n lastDueAt: null,\n lastRunId: null,\n lastRunStatus: null,\n updatedAt: new Date().toISOString(),\n lastFiredEventEndAt: nextWorkflow.createdAt,\n lastFiredEventId: null,\n };\n let stateChanged = existingState === null;\n\n const remaining = args.limit - runs.length;\n if (eventSchedule.eventKind === \"calendar.event.ended\") {\n const candidates =\n await this.repository.listCalendarEventsEndedAfterCursor({\n agentId: this.agentId(),\n provider: \"google\",\n side: \"owner\",\n cursorEndAt: schedulerState.lastFiredEventEndAt ?? null,\n cursorEventId: schedulerState.lastFiredEventId ?? null,\n upToIso: args.now,\n limit: Math.max(remaining * 4, 8),\n });\n\n const filters =\n eventSchedule.filters?.kind === \"calendar.event.ended\"\n ? eventSchedule.filters.filters\n : undefined;\n\n for (const event of candidates) {\n if (runs.length >= args.limit) {\n break;\n }\n if (!matchesCalendarEventEndedFilters(event, filters)) {\n schedulerState = {\n ...schedulerState,\n lastFiredEventEndAt: event.endAt,\n lastFiredEventId: event.id,\n updatedAt: new Date().toISOString(),\n };\n stateChanged = true;\n continue;\n }\n const { run, error } = await this.executeWorkflowDefinition(\n nextWorkflow,\n {\n startedAt: event.endAt,\n confirmBrowserActions: false,\n request: {\n scheduledExecution: false,\n event: {\n kind: \"calendar.event.ended\",\n eventId: event.id,\n calendarId: event.calendarId,\n title: event.title,\n startAt: event.startAt,\n endAt: event.endAt,\n htmlLink: event.htmlLink,\n },\n },\n },\n );\n runs.push(run);\n await this.emitWorkflowRunNudge(nextWorkflow, run);\n schedulerState = {\n ...schedulerState,\n lastDueAt: event.endAt,\n lastRunId: run.id,\n lastRunStatus: run.status,\n lastFiredEventEndAt: event.endAt,\n lastFiredEventId: event.id,\n updatedAt: new Date().toISOString(),\n };\n stateChanged = true;\n\n if (error) {\n this.logLifeOpsError(\"workflow_event_execution\", error, {\n workflowId: nextWorkflow.id,\n workflowRunId: run.id,\n eventId: event.id,\n eventEndAt: event.endAt,\n });\n }\n }\n } else {\n const candidates = (args.lifeOpsEvents ?? [])\n .filter((event) => event.kind === eventSchedule.eventKind)\n .filter((event) => {\n if (!schedulerState.lastFiredEventEndAt) {\n return true;\n }\n if (event.occurredAt > schedulerState.lastFiredEventEndAt) {\n return true;\n }\n return (\n event.occurredAt === schedulerState.lastFiredEventEndAt &&\n event.id !== schedulerState.lastFiredEventId\n );\n })\n .slice(0, Math.max(remaining * 4, 8));\n\n const filters =\n eventSchedule.filters?.kind === eventSchedule.eventKind\n ? eventSchedule.filters.filters\n : undefined;\n\n for (const event of candidates) {\n if (runs.length >= args.limit) {\n break;\n }\n if (!matchesLifeOpsDerivedEventFilters(event, filters, args.now)) {\n schedulerState = {\n ...schedulerState,\n updatedAt: new Date().toISOString(),\n };\n stateChanged = true;\n continue;\n }\n const { run, error } = await this.executeWorkflowDefinition(\n nextWorkflow,\n {\n startedAt: event.occurredAt,\n confirmBrowserActions: false,\n request: {\n scheduledExecution: false,\n event: {\n kind: event.kind,\n eventId: event.id,\n occurredAt: event.occurredAt,\n confidence: event.confidence,\n payload: event.payload,\n },\n },\n },\n );\n runs.push(run);\n await this.emitWorkflowRunNudge(nextWorkflow, run);\n schedulerState = {\n ...schedulerState,\n lastDueAt: event.occurredAt,\n lastRunId: run.id,\n lastRunStatus: run.status,\n lastFiredEventEndAt: event.occurredAt,\n lastFiredEventId: event.id,\n updatedAt: new Date().toISOString(),\n };\n stateChanged = true;\n\n if (error) {\n this.logLifeOpsError(\"workflow_event_execution\", error, {\n workflowId: nextWorkflow.id,\n workflowRunId: run.id,\n eventId: event.id,\n eventEndAt: event.occurredAt,\n });\n }\n }\n }\n\n if (stateChanged) {\n nextWorkflow = this.withWorkflowSchedulerState(\n nextWorkflow,\n schedulerState,\n );\n await this.repository.updateWorkflow(nextWorkflow);\n }\n }\n\n return runs;\n }\n\n async listWorkflows(): Promise<LifeOpsWorkflowRecord[]> {\n const workflows = await this.repository.listWorkflows(this.agentId());\n const records: LifeOpsWorkflowRecord[] = [];\n for (const definition of workflows) {\n records.push({\n definition,\n runs: await this.repository.listWorkflowRuns(\n this.agentId(),\n definition.id,\n ),\n });\n }\n return records;\n }\n\n async getWorkflow(workflowId: string): Promise<LifeOpsWorkflowRecord> {\n const definition = await this.getWorkflowDefinition(workflowId);\n return {\n definition,\n runs: await this.repository.listWorkflowRuns(\n this.agentId(),\n workflowId,\n ),\n };\n }\n\n async createWorkflow(\n request: CreateLifeOpsWorkflowRequest,\n ): Promise<LifeOpsWorkflowRecord> {\n const triggerType = normalizeWorkflowTriggerType(request.triggerType);\n const ownership = this.normalizeOwnership(request.ownership);\n let definition = createLifeOpsWorkflowDefinition({\n agentId: this.agentId(),\n ...ownership,\n title: requireNonEmptyString(request.title, \"title\"),\n triggerType,\n schedule: normalizeWorkflowSchedule(request.schedule, triggerType),\n actionPlan: normalizeWorkflowActionPlan(request.actionPlan),\n permissionPolicy: normalizeWorkflowPermissionPolicy(\n request.permissionPolicy,\n ),\n status:\n request.status === undefined\n ? \"active\"\n : normalizeEnumValue(\n request.status,\n \"status\",\n LIFEOPS_WORKFLOW_STATUSES,\n ),\n createdBy:\n request.createdBy === undefined\n ? \"user\"\n : normalizeEnumValue(request.createdBy, \"createdBy\", [\n \"agent\",\n \"user\",\n \"workflow\",\n \"connector\",\n ] as const),\n metadata: normalizeOptionalRecord(request.metadata, \"metadata\") ?? {},\n });\n definition = this.initializeWorkflowSchedulerState(definition);\n await this.repository.createWorkflow(definition);\n await this.recordWorkflowAudit(\n \"workflow_created\",\n definition.id,\n \"user\",\n \"workflow created\",\n { request },\n {\n triggerType: definition.triggerType,\n status: definition.status,\n },\n );\n return {\n definition,\n runs: [],\n };\n }\n\n async updateWorkflow(\n workflowId: string,\n request: UpdateLifeOpsWorkflowRequest,\n ): Promise<LifeOpsWorkflowRecord> {\n const current = await this.getWorkflowDefinition(workflowId);\n const ownership = this.normalizeOwnership(request.ownership, current);\n const nextTriggerType =\n request.triggerType === undefined\n ? current.triggerType\n : normalizeWorkflowTriggerType(request.triggerType);\n let nextDefinition: LifeOpsWorkflowDefinition = {\n ...current,\n ...ownership,\n title:\n request.title === undefined\n ? current.title\n : requireNonEmptyString(request.title, \"title\"),\n triggerType: nextTriggerType,\n schedule:\n request.schedule === undefined\n ? current.schedule\n : normalizeWorkflowSchedule(request.schedule, nextTriggerType),\n actionPlan:\n request.actionPlan === undefined\n ? current.actionPlan\n : normalizeWorkflowActionPlan(request.actionPlan),\n permissionPolicy: normalizeWorkflowPermissionPolicy(\n request.permissionPolicy,\n current.permissionPolicy,\n ),\n status:\n request.status === undefined\n ? current.status\n : normalizeEnumValue(\n request.status,\n \"status\",\n LIFEOPS_WORKFLOW_STATUSES,\n ),\n metadata:\n request.metadata === undefined\n ? current.metadata\n : {\n ...current.metadata,\n ...requireRecord(request.metadata, \"metadata\"),\n },\n updatedAt: new Date().toISOString(),\n };\n if (\n request.triggerType !== undefined ||\n request.schedule !== undefined ||\n this.readWorkflowSchedulerState(nextDefinition) === null\n ) {\n nextDefinition = this.initializeWorkflowSchedulerState(nextDefinition);\n }\n await this.repository.updateWorkflow(nextDefinition);\n await this.recordWorkflowAudit(\n \"workflow_updated\",\n nextDefinition.id,\n \"user\",\n \"workflow updated\",\n { request },\n {\n triggerType: nextDefinition.triggerType,\n status: nextDefinition.status,\n },\n );\n return this.getWorkflow(nextDefinition.id);\n }\n\n public async executeWorkflowDefinition(\n definition: LifeOpsWorkflowDefinition,\n args: {\n startedAt: string;\n confirmBrowserActions: boolean;\n request: Record<string, unknown>;\n },\n ): Promise<ExecuteWorkflowResult> {\n const outputs: Record<string, unknown> = {};\n const steps: Array<Record<string, unknown>> = [];\n let status: LifeOpsWorkflowRun[\"status\"] = \"success\";\n\n const registry = getWorkflowStepRegistry(this.runtime);\n if (!registry) {\n throw new Error(\n \"WorkflowStepRegistry not registered on runtime — call registerDefaultWorkflowStepPack() in plugin init\",\n );\n }\n const ctx = this as unknown as WorkflowStepExecuteContext;\n\n try {\n for (const [index, step] of definition.actionPlan.steps.entries()) {\n const contribution = registry.get(step.kind);\n if (!contribution) {\n throw new UnknownWorkflowStepError(\n step.kind,\n registry.list().map((c) => c.kind),\n );\n }\n const validated = contribution.paramSchema.parse(step);\n const stepArgs: WorkflowStepExecuteArgs = {\n definition,\n startedAt: args.startedAt,\n confirmBrowserActions: args.confirmBrowserActions,\n request: args.request,\n outputs,\n previousStepValue: steps.at(-1)?.value ?? null,\n };\n const value = await contribution.execute(validated, stepArgs, ctx);\n const stepRecord = {\n index,\n kind: step.kind,\n resultKey: step.resultKey ?? null,\n value,\n };\n if (step.resultKey) {\n outputs[step.resultKey] = value;\n }\n steps.push(stepRecord);\n }\n } catch (error) {\n status = \"failed\";\n steps.push({\n error: error instanceof Error ? error.message : String(error),\n });\n const audit = await this.recordWorkflowAudit(\n \"workflow_run\",\n definition.id,\n \"workflow\",\n \"workflow run failed\",\n {\n request: args.request,\n },\n {\n status,\n steps,\n },\n );\n const run = createLifeOpsWorkflowRun({\n agentId: this.agentId(),\n workflowId: definition.id,\n startedAt: args.startedAt,\n finishedAt: new Date().toISOString(),\n status,\n result: { steps, outputs },\n auditRef: audit.id,\n });\n await this.repository.createWorkflowRun(run);\n return {\n run,\n error,\n };\n }\n\n const audit = await this.recordWorkflowAudit(\n \"workflow_run\",\n definition.id,\n \"workflow\",\n \"workflow run succeeded\",\n {\n request: args.request,\n },\n {\n status,\n steps,\n },\n );\n const run = createLifeOpsWorkflowRun({\n agentId: this.agentId(),\n workflowId: definition.id,\n startedAt: args.startedAt,\n finishedAt: new Date().toISOString(),\n status,\n result: { steps, outputs },\n auditRef: audit.id,\n });\n await this.repository.createWorkflowRun(run);\n return {\n run,\n error: null,\n };\n }\n\n async runWorkflow(\n workflowId: string,\n request: { now?: string; confirmBrowserActions?: boolean } = {},\n ): Promise<LifeOpsWorkflowRun> {\n const definition = await this.getWorkflowDefinition(workflowId);\n if (definition.status !== \"active\") {\n fail(409, `workflow cannot run from status ${definition.status}`);\n }\n const startedAt =\n request.now === undefined\n ? new Date().toISOString()\n : normalizeIsoString(request.now, \"now\");\n const confirmBrowserActions =\n normalizeOptionalBoolean(\n request.confirmBrowserActions,\n \"confirmBrowserActions\",\n ) ?? false;\n const result = await this.executeWorkflowDefinition(definition, {\n startedAt,\n confirmBrowserActions,\n request: request as Record<string, unknown>,\n });\n if (result.error instanceof LifeOpsServiceError) {\n throw result.error;\n }\n if (result.error) {\n throw result.error;\n }\n return result.run;\n }\n }\n\n return LifeOpsWorkflowServiceMixin as unknown as MixinClass<\n TBase,\n LifeOpsWorkflowService\n >;\n}\n"],"mappings":"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","names":["audit","run"]}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { LifeOpsXDm, LifeOpsXFeedItem, LifeOpsXFeedType } from "@elizaos/shared";
|
|
2
|
+
import type { Constructor, LifeOpsServiceBase, MixinClass } from "./service-mixin-core.js";
|
|
3
|
+
type XReadOpts = {
|
|
4
|
+
limit?: number;
|
|
5
|
+
};
|
|
6
|
+
type XFeedReadOpts = XReadOpts & {
|
|
7
|
+
query?: string;
|
|
8
|
+
};
|
|
9
|
+
export interface LifeOpsXReadService {
|
|
10
|
+
syncXDms(opts?: XReadOpts): Promise<{
|
|
11
|
+
synced: number;
|
|
12
|
+
}>;
|
|
13
|
+
syncXFeed(feedType: LifeOpsXFeedType, opts?: XFeedReadOpts): Promise<{
|
|
14
|
+
synced: number;
|
|
15
|
+
}>;
|
|
16
|
+
searchXPosts(query: string, opts?: XReadOpts): Promise<LifeOpsXFeedItem[]>;
|
|
17
|
+
getXDms(opts?: {
|
|
18
|
+
conversationId?: string;
|
|
19
|
+
limit?: number;
|
|
20
|
+
}): Promise<LifeOpsXDm[]>;
|
|
21
|
+
getXFeedItems(feedType: LifeOpsXFeedType, opts?: {
|
|
22
|
+
limit?: number;
|
|
23
|
+
}): Promise<LifeOpsXFeedItem[]>;
|
|
24
|
+
readXInboundDms(opts?: {
|
|
25
|
+
limit?: number;
|
|
26
|
+
}): Promise<LifeOpsXDm[]>;
|
|
27
|
+
}
|
|
28
|
+
/** @internal */
|
|
29
|
+
export declare function withXRead<TBase extends Constructor<LifeOpsServiceBase>>(Base: TBase): MixinClass<TBase, LifeOpsXReadService>;
|
|
30
|
+
export {};
|
|
31
|
+
//# sourceMappingURL=service-mixin-x-read.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-mixin-x-read.d.ts","sourceRoot":"","sources":["../../src/lifeops/service-mixin-x-read.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAEV,UAAU,EACV,gBAAgB,EAChB,gBAAgB,EACjB,MAAM,iBAAiB,CAAC;AAMzB,OAAO,KAAK,EACV,WAAW,EACX,kBAAkB,EAClB,UAAU,EACX,MAAM,yBAAyB,CAAC;AAGjC,KAAK,SAAS,GAAG;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,KAAK,aAAa,GAAG,SAAS,GAAG;IAC/B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAMF,MAAM,WAAW,mBAAmB;IAClC,QAAQ,CAAC,IAAI,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACxD,SAAS,CACP,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,CAAC,EAAE,aAAa,GACnB,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC/B,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC3E,OAAO,CAAC,IAAI,CAAC,EAAE;QACb,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;IAC1B,aAAa,CACX,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GACxB,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC/B,eAAe,CAAC,IAAI,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;CACnE;AA+LD,gBAAgB;AAChB,wBAAgB,SAAS,CAAC,KAAK,SAAS,WAAW,CAAC,kBAAkB,CAAC,EACrE,IAAI,EAAE,KAAK,GACV,UAAU,CAAC,KAAK,EAAE,mBAAmB,CAAC,CAmJxC"}
|
|
@@ -0,0 +1,267 @@
|
|
|
1
|
+
import crypto from "node:crypto";
|
|
2
|
+
import {
|
|
3
|
+
fetchXDirectMessagesWithRuntimeService,
|
|
4
|
+
fetchXFeedWithRuntimeService,
|
|
5
|
+
searchXPostsWithRuntimeService
|
|
6
|
+
} from "./runtime-service-delegates.js";
|
|
7
|
+
import { fail } from "./service-normalize.js";
|
|
8
|
+
async function resolveOptionalXGrant(service) {
|
|
9
|
+
if (typeof service.resolveXGrant !== "function") {
|
|
10
|
+
return null;
|
|
11
|
+
}
|
|
12
|
+
return service.resolveXGrant();
|
|
13
|
+
}
|
|
14
|
+
function record(value) {
|
|
15
|
+
return value && typeof value === "object" ? value : {};
|
|
16
|
+
}
|
|
17
|
+
function stringField(value, fallback = "") {
|
|
18
|
+
return typeof value === "string" && value.length > 0 ? value : fallback;
|
|
19
|
+
}
|
|
20
|
+
function isoFromMemory(memory, fallback) {
|
|
21
|
+
const createdAt = Number(memory.createdAt);
|
|
22
|
+
return Number.isFinite(createdAt) && createdAt > 0 ? new Date(createdAt).toISOString() : fallback;
|
|
23
|
+
}
|
|
24
|
+
function lifeOpsReadDelegationFailed(operation, result) {
|
|
25
|
+
const detail = result.error instanceof Error ? result.error.message : result.error ? String(result.error) : result.reason;
|
|
26
|
+
fail(
|
|
27
|
+
result.reason.includes("not registered") ? 409 : 502,
|
|
28
|
+
`[${operation}] ${detail}`
|
|
29
|
+
);
|
|
30
|
+
}
|
|
31
|
+
function memoryToLifeOpsXDm(args) {
|
|
32
|
+
const metadata = record(args.memory.metadata);
|
|
33
|
+
const x = record(metadata.x);
|
|
34
|
+
const sender = record(metadata.sender);
|
|
35
|
+
const externalDmId = stringField(
|
|
36
|
+
x.dmEventId ?? metadata.messageIdFull ?? args.memory.id,
|
|
37
|
+
crypto.randomUUID()
|
|
38
|
+
);
|
|
39
|
+
const senderId = stringField(
|
|
40
|
+
x.senderId ?? sender.id ?? args.memory.entityId,
|
|
41
|
+
"unknown"
|
|
42
|
+
);
|
|
43
|
+
const senderHandle = stringField(
|
|
44
|
+
x.senderUsername ?? sender.username ?? sender.name
|
|
45
|
+
);
|
|
46
|
+
const receivedAt = isoFromMemory(args.memory, args.syncedAt);
|
|
47
|
+
return {
|
|
48
|
+
id: `${args.agentId}:x:${externalDmId}`,
|
|
49
|
+
agentId: args.agentId,
|
|
50
|
+
externalDmId,
|
|
51
|
+
conversationId: stringField(
|
|
52
|
+
x.conversationId ?? args.memory.roomId,
|
|
53
|
+
`dm:${senderId}`
|
|
54
|
+
),
|
|
55
|
+
senderHandle,
|
|
56
|
+
senderId,
|
|
57
|
+
isInbound: typeof x.isInbound === "boolean" ? x.isInbound : metadata.fromBot !== true,
|
|
58
|
+
text: stringField(args.memory.content.text),
|
|
59
|
+
receivedAt,
|
|
60
|
+
readAt: null,
|
|
61
|
+
repliedAt: null,
|
|
62
|
+
metadata: {
|
|
63
|
+
...metadata,
|
|
64
|
+
source: "plugin-x-runtime"
|
|
65
|
+
},
|
|
66
|
+
syncedAt: args.syncedAt,
|
|
67
|
+
updatedAt: args.syncedAt
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
function memoryToLifeOpsXFeedItem(args) {
|
|
71
|
+
const metadata = record(args.memory.metadata);
|
|
72
|
+
const x = record(metadata.x);
|
|
73
|
+
const sender = record(metadata.sender);
|
|
74
|
+
const externalTweetId = stringField(
|
|
75
|
+
x.tweetId ?? metadata.messageIdFull ?? args.memory.id,
|
|
76
|
+
crypto.randomUUID()
|
|
77
|
+
);
|
|
78
|
+
const authorId = stringField(
|
|
79
|
+
x.userId ?? sender.id ?? args.memory.entityId,
|
|
80
|
+
"unknown"
|
|
81
|
+
);
|
|
82
|
+
return {
|
|
83
|
+
id: `${args.agentId}:x-feed:${args.feedType}:${externalTweetId}`,
|
|
84
|
+
agentId: args.agentId,
|
|
85
|
+
externalTweetId,
|
|
86
|
+
authorHandle: stringField(x.username ?? sender.username),
|
|
87
|
+
authorId,
|
|
88
|
+
text: stringField(args.memory.content.text),
|
|
89
|
+
createdAtSource: isoFromMemory(args.memory, args.syncedAt),
|
|
90
|
+
feedType: args.feedType,
|
|
91
|
+
metadata: {
|
|
92
|
+
...metadata,
|
|
93
|
+
source: "plugin-x-runtime"
|
|
94
|
+
},
|
|
95
|
+
syncedAt: args.syncedAt,
|
|
96
|
+
updatedAt: args.syncedAt
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
function cachedLimit(opts) {
|
|
100
|
+
return Math.max(opts.limit ?? 20, 20);
|
|
101
|
+
}
|
|
102
|
+
async function hasCachedXDms(service, opts) {
|
|
103
|
+
const cached = await service.repository.listXDms(service.agentId(), {
|
|
104
|
+
limit: opts.limit ?? 1
|
|
105
|
+
});
|
|
106
|
+
return cached.length > 0;
|
|
107
|
+
}
|
|
108
|
+
async function hasCachedXFeed(service, feedType, opts) {
|
|
109
|
+
const cached = await service.repository.listXFeedItems(
|
|
110
|
+
service.agentId(),
|
|
111
|
+
feedType,
|
|
112
|
+
{ limit: opts.limit ?? 1 }
|
|
113
|
+
);
|
|
114
|
+
return cached.length > 0;
|
|
115
|
+
}
|
|
116
|
+
function matchesCachedXSearchQuery(item, query) {
|
|
117
|
+
const terms = query.toLowerCase().split(/\s+/).map((term) => term.trim()).filter((term) => term.length > 0);
|
|
118
|
+
if (terms.length === 0) {
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
121
|
+
const haystack = [
|
|
122
|
+
item.authorHandle,
|
|
123
|
+
item.authorId,
|
|
124
|
+
item.text,
|
|
125
|
+
JSON.stringify(item.metadata)
|
|
126
|
+
].join(" ").toLowerCase();
|
|
127
|
+
return terms.every((term) => haystack.includes(term));
|
|
128
|
+
}
|
|
129
|
+
function dedupeCachedSearchResults(items) {
|
|
130
|
+
const seen = /* @__PURE__ */ new Set();
|
|
131
|
+
const unique = [];
|
|
132
|
+
for (const item of items) {
|
|
133
|
+
if (seen.has(item.externalTweetId)) {
|
|
134
|
+
continue;
|
|
135
|
+
}
|
|
136
|
+
seen.add(item.externalTweetId);
|
|
137
|
+
unique.push(item);
|
|
138
|
+
}
|
|
139
|
+
return unique;
|
|
140
|
+
}
|
|
141
|
+
function withXRead(Base) {
|
|
142
|
+
const XReadBase = Base;
|
|
143
|
+
class LifeOpsXReadServiceMixin extends XReadBase {
|
|
144
|
+
async syncXDms(opts = {}) {
|
|
145
|
+
const grant = await resolveOptionalXGrant(this);
|
|
146
|
+
const delegated = await fetchXDirectMessagesWithRuntimeService({
|
|
147
|
+
runtime: this.runtime,
|
|
148
|
+
grant,
|
|
149
|
+
limit: opts.limit
|
|
150
|
+
});
|
|
151
|
+
if (delegated.status !== "handled") {
|
|
152
|
+
if (await hasCachedXDms(this, opts)) {
|
|
153
|
+
return { synced: 0 };
|
|
154
|
+
}
|
|
155
|
+
lifeOpsReadDelegationFailed("x_read_dms", delegated);
|
|
156
|
+
}
|
|
157
|
+
const syncedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
158
|
+
for (const memory of delegated.value) {
|
|
159
|
+
await this.repository.upsertXDm(
|
|
160
|
+
memoryToLifeOpsXDm({
|
|
161
|
+
agentId: this.agentId(),
|
|
162
|
+
memory,
|
|
163
|
+
syncedAt
|
|
164
|
+
})
|
|
165
|
+
);
|
|
166
|
+
}
|
|
167
|
+
return { synced: delegated.value.length };
|
|
168
|
+
}
|
|
169
|
+
async syncXFeed(feedType, opts = {}) {
|
|
170
|
+
const grant = await resolveOptionalXGrant(this);
|
|
171
|
+
const delegated = await fetchXFeedWithRuntimeService({
|
|
172
|
+
runtime: this.runtime,
|
|
173
|
+
grant,
|
|
174
|
+
feedType,
|
|
175
|
+
limit: opts.limit
|
|
176
|
+
});
|
|
177
|
+
if (delegated.status !== "handled") {
|
|
178
|
+
if (await hasCachedXFeed(this, feedType, opts)) {
|
|
179
|
+
return { synced: 0 };
|
|
180
|
+
}
|
|
181
|
+
lifeOpsReadDelegationFailed(`x_read_feed_${feedType}`, delegated);
|
|
182
|
+
}
|
|
183
|
+
const syncedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
184
|
+
for (const memory of delegated.value) {
|
|
185
|
+
await this.repository.upsertXFeedItem(
|
|
186
|
+
memoryToLifeOpsXFeedItem({
|
|
187
|
+
agentId: this.agentId(),
|
|
188
|
+
feedType,
|
|
189
|
+
memory,
|
|
190
|
+
syncedAt
|
|
191
|
+
})
|
|
192
|
+
);
|
|
193
|
+
}
|
|
194
|
+
await this.repository.upsertXSyncState({
|
|
195
|
+
id: `${this.agentId()}:x:${feedType}`,
|
|
196
|
+
agentId: this.agentId(),
|
|
197
|
+
feedType,
|
|
198
|
+
lastCursor: null,
|
|
199
|
+
syncedAt,
|
|
200
|
+
updatedAt: syncedAt
|
|
201
|
+
});
|
|
202
|
+
return { synced: delegated.value.length };
|
|
203
|
+
}
|
|
204
|
+
async searchXPosts(query, opts = {}) {
|
|
205
|
+
const trimmed = query.trim();
|
|
206
|
+
if (trimmed.length === 0) {
|
|
207
|
+
fail(400, "searchXPosts requires a non-empty query.");
|
|
208
|
+
}
|
|
209
|
+
const grant = await resolveOptionalXGrant(this);
|
|
210
|
+
const delegated = await searchXPostsWithRuntimeService({
|
|
211
|
+
runtime: this.runtime,
|
|
212
|
+
grant,
|
|
213
|
+
query: trimmed,
|
|
214
|
+
limit: opts.limit
|
|
215
|
+
});
|
|
216
|
+
if (delegated.status !== "handled") {
|
|
217
|
+
const searchLimit = cachedLimit(opts);
|
|
218
|
+
const cached = dedupeCachedSearchResults([
|
|
219
|
+
...await this.repository.listXFeedItems(this.agentId(), "search", {
|
|
220
|
+
limit: searchLimit
|
|
221
|
+
}),
|
|
222
|
+
...await this.repository.listXFeedItems(
|
|
223
|
+
this.agentId(),
|
|
224
|
+
"home_timeline",
|
|
225
|
+
{ limit: searchLimit }
|
|
226
|
+
),
|
|
227
|
+
...await this.repository.listXFeedItems(this.agentId(), "mentions", {
|
|
228
|
+
limit: searchLimit
|
|
229
|
+
})
|
|
230
|
+
]).filter((item) => matchesCachedXSearchQuery(item, trimmed));
|
|
231
|
+
if (cached.length > 0) {
|
|
232
|
+
return cached.slice(0, opts.limit ?? cached.length);
|
|
233
|
+
}
|
|
234
|
+
lifeOpsReadDelegationFailed("x_search", delegated);
|
|
235
|
+
}
|
|
236
|
+
const syncedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
237
|
+
const items = [];
|
|
238
|
+
for (const memory of delegated.value) {
|
|
239
|
+
const item = memoryToLifeOpsXFeedItem({
|
|
240
|
+
agentId: this.agentId(),
|
|
241
|
+
feedType: "search",
|
|
242
|
+
memory,
|
|
243
|
+
syncedAt
|
|
244
|
+
});
|
|
245
|
+
await this.repository.upsertXFeedItem(item);
|
|
246
|
+
items.push(item);
|
|
247
|
+
}
|
|
248
|
+
return items;
|
|
249
|
+
}
|
|
250
|
+
async getXDms(opts = {}) {
|
|
251
|
+
return this.repository.listXDms(this.agentId(), opts);
|
|
252
|
+
}
|
|
253
|
+
async getXFeedItems(feedType, opts = {}) {
|
|
254
|
+
return this.repository.listXFeedItems(this.agentId(), feedType, opts);
|
|
255
|
+
}
|
|
256
|
+
async readXInboundDms(opts = {}) {
|
|
257
|
+
await this.syncXDms(opts);
|
|
258
|
+
const all = await this.repository.listXDms(this.agentId(), opts);
|
|
259
|
+
return all.filter((dm) => dm.isInbound);
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
return LifeOpsXReadServiceMixin;
|
|
263
|
+
}
|
|
264
|
+
export {
|
|
265
|
+
withXRead
|
|
266
|
+
};
|
|
267
|
+
//# sourceMappingURL=service-mixin-x-read.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lifeops/service-mixin-x-read.ts"],"sourcesContent":["import crypto from \"node:crypto\";\nimport type { Memory } from \"@elizaos/core\";\nimport type {\n LifeOpsConnectorGrant,\n LifeOpsXDm,\n LifeOpsXFeedItem,\n LifeOpsXFeedType,\n} from \"@elizaos/shared\";\nimport {\n fetchXDirectMessagesWithRuntimeService,\n fetchXFeedWithRuntimeService,\n searchXPostsWithRuntimeService,\n} from \"./runtime-service-delegates.js\";\nimport type {\n Constructor,\n LifeOpsServiceBase,\n MixinClass,\n} from \"./service-mixin-core.js\";\nimport { fail } from \"./service-normalize.js\";\n\ntype XReadOpts = {\n limit?: number;\n};\n\ntype XFeedReadOpts = XReadOpts & {\n query?: string;\n};\n\ntype OptionalXGrantResolver = {\n resolveXGrant?: () => Promise<LifeOpsConnectorGrant | null>;\n};\n\nexport interface LifeOpsXReadService {\n syncXDms(opts?: XReadOpts): Promise<{ synced: number }>;\n syncXFeed(\n feedType: LifeOpsXFeedType,\n opts?: XFeedReadOpts,\n ): Promise<{ synced: number }>;\n searchXPosts(query: string, opts?: XReadOpts): Promise<LifeOpsXFeedItem[]>;\n getXDms(opts?: {\n conversationId?: string;\n limit?: number;\n }): Promise<LifeOpsXDm[]>;\n getXFeedItems(\n feedType: LifeOpsXFeedType,\n opts?: { limit?: number },\n ): Promise<LifeOpsXFeedItem[]>;\n readXInboundDms(opts?: { limit?: number }): Promise<LifeOpsXDm[]>;\n}\n\nasync function resolveOptionalXGrant(\n service: OptionalXGrantResolver,\n): Promise<LifeOpsConnectorGrant | null> {\n if (typeof service.resolveXGrant !== \"function\") {\n return null;\n }\n return service.resolveXGrant();\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, fallback: string): string {\n const createdAt = Number(memory.createdAt);\n return Number.isFinite(createdAt) && createdAt > 0\n ? new Date(createdAt).toISOString()\n : fallback;\n}\n\nfunction lifeOpsReadDelegationFailed(\n operation: string,\n result: { reason: string; error?: unknown },\n): never {\n const detail =\n result.error instanceof Error\n ? result.error.message\n : result.error\n ? String(result.error)\n : result.reason;\n fail(\n result.reason.includes(\"not registered\") ? 409 : 502,\n `[${operation}] ${detail}`,\n );\n}\n\nfunction memoryToLifeOpsXDm(args: {\n agentId: string;\n memory: Memory;\n syncedAt: string;\n}): LifeOpsXDm {\n const metadata = record(args.memory.metadata);\n const x = record(metadata.x);\n const sender = record(metadata.sender);\n const externalDmId = stringField(\n x.dmEventId ?? metadata.messageIdFull ?? args.memory.id,\n crypto.randomUUID(),\n );\n const senderId = stringField(\n x.senderId ?? sender.id ?? args.memory.entityId,\n \"unknown\",\n );\n const senderHandle = stringField(\n x.senderUsername ?? sender.username ?? sender.name,\n );\n const receivedAt = isoFromMemory(args.memory, args.syncedAt);\n return {\n id: `${args.agentId}:x:${externalDmId}`,\n agentId: args.agentId,\n externalDmId,\n conversationId: stringField(\n x.conversationId ?? args.memory.roomId,\n `dm:${senderId}`,\n ),\n senderHandle,\n senderId,\n isInbound:\n typeof x.isInbound === \"boolean\"\n ? x.isInbound\n : metadata.fromBot !== true,\n text: stringField(args.memory.content.text),\n receivedAt,\n readAt: null,\n repliedAt: null,\n metadata: {\n ...metadata,\n source: \"plugin-x-runtime\",\n },\n syncedAt: args.syncedAt,\n updatedAt: args.syncedAt,\n };\n}\n\nfunction memoryToLifeOpsXFeedItem(args: {\n agentId: string;\n feedType: LifeOpsXFeedType;\n memory: Memory;\n syncedAt: string;\n}): LifeOpsXFeedItem {\n const metadata = record(args.memory.metadata);\n const x = record(metadata.x);\n const sender = record(metadata.sender);\n const externalTweetId = stringField(\n x.tweetId ?? metadata.messageIdFull ?? args.memory.id,\n crypto.randomUUID(),\n );\n const authorId = stringField(\n x.userId ?? sender.id ?? args.memory.entityId,\n \"unknown\",\n );\n return {\n id: `${args.agentId}:x-feed:${args.feedType}:${externalTweetId}`,\n agentId: args.agentId,\n externalTweetId,\n authorHandle: stringField(x.username ?? sender.username),\n authorId,\n text: stringField(args.memory.content.text),\n createdAtSource: isoFromMemory(args.memory, args.syncedAt),\n feedType: args.feedType,\n metadata: {\n ...metadata,\n source: \"plugin-x-runtime\",\n },\n syncedAt: args.syncedAt,\n updatedAt: args.syncedAt,\n };\n}\n\nfunction cachedLimit(opts: XReadOpts): number {\n return Math.max(opts.limit ?? 20, 20);\n}\n\nasync function hasCachedXDms(\n service: LifeOpsServiceBase,\n opts: XReadOpts,\n): Promise<boolean> {\n const cached = await service.repository.listXDms(service.agentId(), {\n limit: opts.limit ?? 1,\n });\n return cached.length > 0;\n}\n\nasync function hasCachedXFeed(\n service: LifeOpsServiceBase,\n feedType: LifeOpsXFeedType,\n opts: XReadOpts,\n): Promise<boolean> {\n const cached = await service.repository.listXFeedItems(\n service.agentId(),\n feedType,\n { limit: opts.limit ?? 1 },\n );\n return cached.length > 0;\n}\n\nfunction matchesCachedXSearchQuery(\n item: LifeOpsXFeedItem,\n query: string,\n): boolean {\n const terms = query\n .toLowerCase()\n .split(/\\s+/)\n .map((term) => term.trim())\n .filter((term) => term.length > 0);\n if (terms.length === 0) {\n return false;\n }\n const haystack = [\n item.authorHandle,\n item.authorId,\n item.text,\n JSON.stringify(item.metadata),\n ]\n .join(\" \")\n .toLowerCase();\n return terms.every((term) => haystack.includes(term));\n}\n\nfunction dedupeCachedSearchResults(\n items: LifeOpsXFeedItem[],\n): LifeOpsXFeedItem[] {\n const seen = new Set<string>();\n const unique: LifeOpsXFeedItem[] = [];\n for (const item of items) {\n if (seen.has(item.externalTweetId)) {\n continue;\n }\n seen.add(item.externalTweetId);\n unique.push(item);\n }\n return unique;\n}\n\n/** @internal */\nexport function withXRead<TBase extends Constructor<LifeOpsServiceBase>>(\n Base: TBase,\n): MixinClass<TBase, LifeOpsXReadService> {\n const XReadBase = Base as unknown as Constructor<\n LifeOpsServiceBase & OptionalXGrantResolver\n >;\n\n class LifeOpsXReadServiceMixin extends XReadBase {\n async syncXDms(opts: XReadOpts = {}): Promise<{ synced: number }> {\n const grant = await resolveOptionalXGrant(this);\n const delegated = await fetchXDirectMessagesWithRuntimeService({\n runtime: this.runtime,\n grant,\n limit: opts.limit,\n });\n if (delegated.status !== \"handled\") {\n if (await hasCachedXDms(this, opts)) {\n return { synced: 0 };\n }\n lifeOpsReadDelegationFailed(\"x_read_dms\", delegated);\n }\n const syncedAt = new Date().toISOString();\n for (const memory of delegated.value) {\n await this.repository.upsertXDm(\n memoryToLifeOpsXDm({\n agentId: this.agentId(),\n memory,\n syncedAt,\n }),\n );\n }\n return { synced: delegated.value.length };\n }\n\n async syncXFeed(\n feedType: LifeOpsXFeedType,\n opts: XFeedReadOpts = {},\n ): Promise<{ synced: number }> {\n const grant = await resolveOptionalXGrant(this);\n const delegated = await fetchXFeedWithRuntimeService({\n runtime: this.runtime,\n grant,\n feedType,\n limit: opts.limit,\n });\n if (delegated.status !== \"handled\") {\n if (await hasCachedXFeed(this, feedType, opts)) {\n return { synced: 0 };\n }\n lifeOpsReadDelegationFailed(`x_read_feed_${feedType}`, delegated);\n }\n const syncedAt = new Date().toISOString();\n for (const memory of delegated.value) {\n await this.repository.upsertXFeedItem(\n memoryToLifeOpsXFeedItem({\n agentId: this.agentId(),\n feedType,\n memory,\n syncedAt,\n }),\n );\n }\n await this.repository.upsertXSyncState({\n id: `${this.agentId()}:x:${feedType}`,\n agentId: this.agentId(),\n feedType,\n lastCursor: null,\n syncedAt,\n updatedAt: syncedAt,\n });\n return { synced: delegated.value.length };\n }\n\n async searchXPosts(\n query: string,\n opts: XReadOpts = {},\n ): Promise<LifeOpsXFeedItem[]> {\n const trimmed = query.trim();\n if (trimmed.length === 0) {\n fail(400, \"searchXPosts requires a non-empty query.\");\n }\n const grant = await resolveOptionalXGrant(this);\n const delegated = await searchXPostsWithRuntimeService({\n runtime: this.runtime,\n grant,\n query: trimmed,\n limit: opts.limit,\n });\n if (delegated.status !== \"handled\") {\n const searchLimit = cachedLimit(opts);\n const cached = dedupeCachedSearchResults([\n ...(await this.repository.listXFeedItems(this.agentId(), \"search\", {\n limit: searchLimit,\n })),\n ...(await this.repository.listXFeedItems(\n this.agentId(),\n \"home_timeline\",\n { limit: searchLimit },\n )),\n ...(await this.repository.listXFeedItems(this.agentId(), \"mentions\", {\n limit: searchLimit,\n })),\n ]).filter((item) => matchesCachedXSearchQuery(item, trimmed));\n if (cached.length > 0) {\n return cached.slice(0, opts.limit ?? cached.length);\n }\n lifeOpsReadDelegationFailed(\"x_search\", delegated);\n }\n const syncedAt = new Date().toISOString();\n const items: LifeOpsXFeedItem[] = [];\n for (const memory of delegated.value) {\n const item = memoryToLifeOpsXFeedItem({\n agentId: this.agentId(),\n feedType: \"search\",\n memory,\n syncedAt,\n });\n await this.repository.upsertXFeedItem(item);\n items.push(item);\n }\n return items;\n }\n\n async getXDms(\n opts: { conversationId?: string; limit?: number } = {},\n ): Promise<LifeOpsXDm[]> {\n return this.repository.listXDms(this.agentId(), opts);\n }\n\n async getXFeedItems(\n feedType: LifeOpsXFeedType,\n opts: { limit?: number } = {},\n ): Promise<LifeOpsXFeedItem[]> {\n return this.repository.listXFeedItems(this.agentId(), feedType, opts);\n }\n\n async readXInboundDms(\n opts: { limit?: number } = {},\n ): Promise<LifeOpsXDm[]> {\n await this.syncXDms(opts);\n const all = await this.repository.listXDms(this.agentId(), opts);\n return all.filter((dm) => dm.isInbound);\n }\n }\n\n return LifeOpsXReadServiceMixin as unknown as MixinClass<\n TBase,\n LifeOpsXReadService\n >;\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import type { CreateLifeOpsXPostRequest, LifeOpsConnectorGrant, LifeOpsConnectorMode, LifeOpsConnectorSide, LifeOpsXConnectorStatus, LifeOpsXDm, LifeOpsXPostResponse } from "../contracts/index.js";
|
|
2
|
+
import type { Constructor, LifeOpsServiceBase, MixinClass } from "./service-mixin-core.js";
|
|
3
|
+
export interface LifeOpsXService {
|
|
4
|
+
resolveXGrant(requestedMode?: LifeOpsConnectorMode, requestedSide?: LifeOpsConnectorSide, requestedAccountId?: string | null): Promise<LifeOpsConnectorGrant | null>;
|
|
5
|
+
getXConnectorStatus(requestedMode?: LifeOpsConnectorMode, requestedSide?: LifeOpsConnectorSide, requestedAccountId?: string | null): Promise<LifeOpsXConnectorStatus>;
|
|
6
|
+
createXPost(request: CreateLifeOpsXPostRequest): Promise<LifeOpsXPostResponse>;
|
|
7
|
+
getXDmDigest(opts?: {
|
|
8
|
+
accountId?: string;
|
|
9
|
+
limit?: number;
|
|
10
|
+
conversationId?: string;
|
|
11
|
+
}): Promise<{
|
|
12
|
+
generatedAt: string;
|
|
13
|
+
conversationId: string | null;
|
|
14
|
+
unreadCount: number;
|
|
15
|
+
readCount: number;
|
|
16
|
+
repliedCount: number;
|
|
17
|
+
recent: LifeOpsXDm[];
|
|
18
|
+
}>;
|
|
19
|
+
curateXDms(request: {
|
|
20
|
+
messageIds?: string[];
|
|
21
|
+
conversationId?: string;
|
|
22
|
+
markRead?: boolean;
|
|
23
|
+
markReplied?: boolean;
|
|
24
|
+
}): Promise<{
|
|
25
|
+
curated: number;
|
|
26
|
+
}>;
|
|
27
|
+
sendXDirectMessage(request: {
|
|
28
|
+
participantId: string;
|
|
29
|
+
text: string;
|
|
30
|
+
confirmSend?: boolean;
|
|
31
|
+
mode?: LifeOpsConnectorMode;
|
|
32
|
+
side?: LifeOpsConnectorSide;
|
|
33
|
+
accountId?: string;
|
|
34
|
+
}): Promise<{
|
|
35
|
+
ok: boolean;
|
|
36
|
+
status: number | null;
|
|
37
|
+
error?: string;
|
|
38
|
+
}>;
|
|
39
|
+
sendXConversationMessage(request: {
|
|
40
|
+
conversationId: string;
|
|
41
|
+
text: string;
|
|
42
|
+
confirmSend?: boolean;
|
|
43
|
+
mode?: LifeOpsConnectorMode;
|
|
44
|
+
side?: LifeOpsConnectorSide;
|
|
45
|
+
accountId?: string;
|
|
46
|
+
}): Promise<{
|
|
47
|
+
ok: boolean;
|
|
48
|
+
status: number | null;
|
|
49
|
+
error?: string;
|
|
50
|
+
}>;
|
|
51
|
+
createXDirectMessageGroup(request: {
|
|
52
|
+
participantIds: string[];
|
|
53
|
+
text: string;
|
|
54
|
+
confirmSend?: boolean;
|
|
55
|
+
mode?: LifeOpsConnectorMode;
|
|
56
|
+
side?: LifeOpsConnectorSide;
|
|
57
|
+
accountId?: string;
|
|
58
|
+
}): Promise<{
|
|
59
|
+
ok: boolean;
|
|
60
|
+
status: number | null;
|
|
61
|
+
conversationId: string | null;
|
|
62
|
+
error?: string;
|
|
63
|
+
}>;
|
|
64
|
+
}
|
|
65
|
+
export declare function withX<TBase extends Constructor<LifeOpsServiceBase>>(Base: TBase): MixinClass<TBase, LifeOpsXService>;
|
|
66
|
+
//# sourceMappingURL=service-mixin-x.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-mixin-x.d.ts","sourceRoot":"","sources":["../../src/lifeops/service-mixin-x.ts"],"names":[],"mappings":"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"}
|