@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,"file":"block-rule-schema.d.ts","sourceRoot":"","sources":["../../../src/website-blocker/chat-integration/block-rule-schema.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,eAAO,MAAM,iBAAiB,EAAG,8BAAuC,CAAC;AAEzE,MAAM,MAAM,iBAAiB,GACzB,gBAAgB,GAChB,YAAY,GACZ,WAAW,GACX,iBAAiB,CAAC;AAEtB,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,QAAQ,EAAE,iBAAiB,CAAC;IAC5B,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,MAAM,EAAE,OAAO,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;CAC/B;AAED,MAAM,WAAW,oBAAoB;IACnC,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,QAAQ,EAAE,iBAAiB,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,eAAe,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAClC;AAED,qBAAa,iBAAkB,SAAQ,KAAK;gBAC9B,OAAO,EAAE,MAAM;CAI5B;AA4GD,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,CAyBtE"}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
const BLOCK_RULES_TABLE = "app_lifeops.life_block_rules";
|
|
2
|
+
class BlockRuleRowError extends Error {
|
|
3
|
+
constructor(message) {
|
|
4
|
+
super(message);
|
|
5
|
+
this.name = "BlockRuleRowError";
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
function isGateType(value) {
|
|
9
|
+
return value === "fixed_duration" || value === "until_todo" || value === "until_iso" || value === "harsh_no_bypass";
|
|
10
|
+
}
|
|
11
|
+
function toStringArray(value) {
|
|
12
|
+
if (typeof value === "string") {
|
|
13
|
+
const parsed = JSON.parse(value);
|
|
14
|
+
if (!Array.isArray(parsed)) {
|
|
15
|
+
throw new BlockRuleRowError(
|
|
16
|
+
"life_block_rules.websites JSON is not an array"
|
|
17
|
+
);
|
|
18
|
+
}
|
|
19
|
+
return parsed.map((entry) => {
|
|
20
|
+
if (typeof entry !== "string") {
|
|
21
|
+
throw new BlockRuleRowError(
|
|
22
|
+
"life_block_rules.websites contains a non-string entry"
|
|
23
|
+
);
|
|
24
|
+
}
|
|
25
|
+
return entry;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
if (Array.isArray(value)) {
|
|
29
|
+
return value.map((entry) => {
|
|
30
|
+
if (typeof entry !== "string") {
|
|
31
|
+
throw new BlockRuleRowError(
|
|
32
|
+
"life_block_rules.websites contains a non-string entry"
|
|
33
|
+
);
|
|
34
|
+
}
|
|
35
|
+
return entry;
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
throw new BlockRuleRowError(
|
|
39
|
+
"life_block_rules.websites is neither string nor array"
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
function toNumberOrNull(value, field) {
|
|
43
|
+
if (value === null || value === void 0) return null;
|
|
44
|
+
if (typeof value === "number") {
|
|
45
|
+
if (!Number.isFinite(value)) {
|
|
46
|
+
throw new BlockRuleRowError(`life_block_rules.${field} is not finite`);
|
|
47
|
+
}
|
|
48
|
+
return value;
|
|
49
|
+
}
|
|
50
|
+
if (typeof value === "bigint") return Number(value);
|
|
51
|
+
if (typeof value === "string") {
|
|
52
|
+
const parsed = Number(value);
|
|
53
|
+
if (!Number.isFinite(parsed)) {
|
|
54
|
+
throw new BlockRuleRowError(
|
|
55
|
+
`life_block_rules.${field} could not be parsed as number`
|
|
56
|
+
);
|
|
57
|
+
}
|
|
58
|
+
return parsed;
|
|
59
|
+
}
|
|
60
|
+
throw new BlockRuleRowError(
|
|
61
|
+
`life_block_rules.${field} has unexpected type ${typeof value}`
|
|
62
|
+
);
|
|
63
|
+
}
|
|
64
|
+
function toRequiredNumber(value, field) {
|
|
65
|
+
const result = toNumberOrNull(value, field);
|
|
66
|
+
if (result === null) {
|
|
67
|
+
throw new BlockRuleRowError(`life_block_rules.${field} is NULL`);
|
|
68
|
+
}
|
|
69
|
+
return result;
|
|
70
|
+
}
|
|
71
|
+
function toStringOrNull(value, field) {
|
|
72
|
+
if (value === null || value === void 0) return null;
|
|
73
|
+
if (typeof value === "string") return value;
|
|
74
|
+
throw new BlockRuleRowError(
|
|
75
|
+
`life_block_rules.${field} has unexpected type ${typeof value}`
|
|
76
|
+
);
|
|
77
|
+
}
|
|
78
|
+
function toRequiredString(value, field) {
|
|
79
|
+
const result = toStringOrNull(value, field);
|
|
80
|
+
if (result === null) {
|
|
81
|
+
throw new BlockRuleRowError(`life_block_rules.${field} is NULL`);
|
|
82
|
+
}
|
|
83
|
+
return result;
|
|
84
|
+
}
|
|
85
|
+
function toBool(value, field) {
|
|
86
|
+
if (typeof value === "boolean") return value;
|
|
87
|
+
if (typeof value === "number") return value !== 0;
|
|
88
|
+
if (typeof value === "string") {
|
|
89
|
+
const normalized = value.trim().toLowerCase();
|
|
90
|
+
if (normalized === "true" || normalized === "t" || normalized === "1") {
|
|
91
|
+
return true;
|
|
92
|
+
}
|
|
93
|
+
if (normalized === "false" || normalized === "f" || normalized === "0") {
|
|
94
|
+
return false;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
if (value === null || value === void 0) return false;
|
|
98
|
+
throw new BlockRuleRowError(
|
|
99
|
+
`life_block_rules.${field} is not a boolean-compatible value`
|
|
100
|
+
);
|
|
101
|
+
}
|
|
102
|
+
function rowToBlockRule(row) {
|
|
103
|
+
const gateType = toRequiredString(row.gate_type, "gate_type");
|
|
104
|
+
if (!isGateType(gateType)) {
|
|
105
|
+
throw new BlockRuleRowError(
|
|
106
|
+
`life_block_rules.gate_type is invalid: ${gateType}`
|
|
107
|
+
);
|
|
108
|
+
}
|
|
109
|
+
return {
|
|
110
|
+
id: toRequiredString(row.id, "id"),
|
|
111
|
+
agentId: toRequiredString(row.agent_id, "agent_id"),
|
|
112
|
+
profile: toRequiredString(row.profile, "profile"),
|
|
113
|
+
websites: toStringArray(row.websites),
|
|
114
|
+
gateType,
|
|
115
|
+
gateTodoId: toStringOrNull(row.gate_todo_id, "gate_todo_id"),
|
|
116
|
+
gateUntilMs: toNumberOrNull(row.gate_until_ms, "gate_until_ms"),
|
|
117
|
+
fixedDurationMs: toNumberOrNull(row.fixed_duration_ms, "fixed_duration_ms"),
|
|
118
|
+
unlockDurationMs: toNumberOrNull(
|
|
119
|
+
row.unlock_duration_ms,
|
|
120
|
+
"unlock_duration_ms"
|
|
121
|
+
),
|
|
122
|
+
active: toBool(row.active, "active"),
|
|
123
|
+
createdAt: toRequiredNumber(row.created_at, "created_at"),
|
|
124
|
+
releasedAt: toNumberOrNull(row.released_at, "released_at"),
|
|
125
|
+
releasedReason: toStringOrNull(row.released_reason, "released_reason")
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
export {
|
|
129
|
+
BLOCK_RULES_TABLE,
|
|
130
|
+
BlockRuleRowError,
|
|
131
|
+
rowToBlockRule
|
|
132
|
+
};
|
|
133
|
+
//# sourceMappingURL=block-rule-schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/website-blocker/chat-integration/block-rule-schema.ts"],"sourcesContent":["/**\n * T7g — Website blocker chat integration (plan §6.8).\n *\n * Domain types for the `life_block_rules` table. The table is bootstrapped\n * in `LifeOpsRepository.bootstrapSchema`; this module only provides typed\n * shapes and narrow runtime decoders for rows read back from SQL.\n */\n\nexport const BLOCK_RULES_TABLE = \"app_lifeops.life_block_rules\" as const;\n\nexport type BlockRuleGateType =\n | \"fixed_duration\"\n | \"until_todo\"\n | \"until_iso\"\n | \"harsh_no_bypass\";\n\nexport interface BlockRule {\n id: string;\n agentId: string;\n profile: string;\n websites: string[];\n gateType: BlockRuleGateType;\n gateTodoId: string | null;\n gateUntilMs: number | null;\n fixedDurationMs: number | null;\n unlockDurationMs: number | null;\n active: boolean;\n createdAt: number;\n releasedAt: number | null;\n releasedReason: string | null;\n}\n\nexport interface CreateBlockRuleInput {\n id?: string;\n profile: string;\n websites: string[];\n gateType: BlockRuleGateType;\n gateTodoId?: string | null;\n gateUntilMs?: number | null;\n fixedDurationMs?: number | null;\n unlockDurationMs?: number | null;\n}\n\nexport class BlockRuleRowError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"BlockRuleRowError\";\n }\n}\n\nfunction isGateType(value: string): value is BlockRuleGateType {\n return (\n value === \"fixed_duration\" ||\n value === \"until_todo\" ||\n value === \"until_iso\" ||\n value === \"harsh_no_bypass\"\n );\n}\n\nfunction toStringArray(value: unknown): string[] {\n if (typeof value === \"string\") {\n const parsed: unknown = JSON.parse(value);\n if (!Array.isArray(parsed)) {\n throw new BlockRuleRowError(\n \"life_block_rules.websites JSON is not an array\",\n );\n }\n return parsed.map((entry) => {\n if (typeof entry !== \"string\") {\n throw new BlockRuleRowError(\n \"life_block_rules.websites contains a non-string entry\",\n );\n }\n return entry;\n });\n }\n if (Array.isArray(value)) {\n return value.map((entry) => {\n if (typeof entry !== \"string\") {\n throw new BlockRuleRowError(\n \"life_block_rules.websites contains a non-string entry\",\n );\n }\n return entry;\n });\n }\n throw new BlockRuleRowError(\n \"life_block_rules.websites is neither string nor array\",\n );\n}\n\nfunction toNumberOrNull(value: unknown, field: string): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === \"number\") {\n if (!Number.isFinite(value)) {\n throw new BlockRuleRowError(`life_block_rules.${field} is not finite`);\n }\n return value;\n }\n if (typeof value === \"bigint\") return Number(value);\n if (typeof value === \"string\") {\n const parsed = Number(value);\n if (!Number.isFinite(parsed)) {\n throw new BlockRuleRowError(\n `life_block_rules.${field} could not be parsed as number`,\n );\n }\n return parsed;\n }\n throw new BlockRuleRowError(\n `life_block_rules.${field} has unexpected type ${typeof value}`,\n );\n}\n\nfunction toRequiredNumber(value: unknown, field: string): number {\n const result = toNumberOrNull(value, field);\n if (result === null) {\n throw new BlockRuleRowError(`life_block_rules.${field} is NULL`);\n }\n return result;\n}\n\nfunction toStringOrNull(value: unknown, field: string): string | null {\n if (value === null || value === undefined) return null;\n if (typeof value === \"string\") return value;\n throw new BlockRuleRowError(\n `life_block_rules.${field} has unexpected type ${typeof value}`,\n );\n}\n\nfunction toRequiredString(value: unknown, field: string): string {\n const result = toStringOrNull(value, field);\n if (result === null) {\n throw new BlockRuleRowError(`life_block_rules.${field} is NULL`);\n }\n return result;\n}\n\nfunction toBool(value: unknown, field: string): boolean {\n if (typeof value === \"boolean\") return value;\n if (typeof value === \"number\") return value !== 0;\n if (typeof value === \"string\") {\n const normalized = value.trim().toLowerCase();\n if (normalized === \"true\" || normalized === \"t\" || normalized === \"1\") {\n return true;\n }\n if (normalized === \"false\" || normalized === \"f\" || normalized === \"0\") {\n return false;\n }\n }\n if (value === null || value === undefined) return false;\n throw new BlockRuleRowError(\n `life_block_rules.${field} is not a boolean-compatible value`,\n );\n}\n\nexport function rowToBlockRule(row: Record<string, unknown>): BlockRule {\n const gateType = toRequiredString(row.gate_type, \"gate_type\");\n if (!isGateType(gateType)) {\n throw new BlockRuleRowError(\n `life_block_rules.gate_type is invalid: ${gateType}`,\n );\n }\n return {\n id: toRequiredString(row.id, \"id\"),\n agentId: toRequiredString(row.agent_id, \"agent_id\"),\n profile: toRequiredString(row.profile, \"profile\"),\n websites: toStringArray(row.websites),\n gateType,\n gateTodoId: toStringOrNull(row.gate_todo_id, \"gate_todo_id\"),\n gateUntilMs: toNumberOrNull(row.gate_until_ms, \"gate_until_ms\"),\n fixedDurationMs: toNumberOrNull(row.fixed_duration_ms, \"fixed_duration_ms\"),\n unlockDurationMs: toNumberOrNull(\n row.unlock_duration_ms,\n \"unlock_duration_ms\",\n ),\n active: toBool(row.active, \"active\"),\n createdAt: toRequiredNumber(row.created_at, \"created_at\"),\n releasedAt: toNumberOrNull(row.released_at, \"released_at\"),\n releasedReason: toStringOrNull(row.released_reason, \"released_reason\"),\n };\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { IAgentRuntime } from "@elizaos/core";
|
|
2
|
+
import { type BlockRule, type CreateBlockRuleInput } from "./block-rule-schema.js";
|
|
3
|
+
export declare class BlockRuleWriter {
|
|
4
|
+
private readonly runtime;
|
|
5
|
+
constructor(runtime: IAgentRuntime);
|
|
6
|
+
createBlockRule(input: CreateBlockRuleInput): Promise<string>;
|
|
7
|
+
releaseBlockRule(id: string, options: {
|
|
8
|
+
confirmed: boolean;
|
|
9
|
+
reason?: string;
|
|
10
|
+
}): Promise<void>;
|
|
11
|
+
updateGateFulfilled(id: string, reason: string): Promise<void>;
|
|
12
|
+
}
|
|
13
|
+
export declare class BlockRuleReader {
|
|
14
|
+
private readonly runtime;
|
|
15
|
+
constructor(runtime: IAgentRuntime);
|
|
16
|
+
listActiveBlocks(): Promise<BlockRule[]>;
|
|
17
|
+
findBlocksGatedByTodo(todoId: string): Promise<BlockRule[]>;
|
|
18
|
+
isBlockActive(profile: string): Promise<boolean>;
|
|
19
|
+
getBlockRuleById(id: string): Promise<BlockRule | null>;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=block-rule-service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"block-rule-service.d.ts","sourceRoot":"","sources":["../../../src/website-blocker/chat-integration/block-rule-service.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAInD,OAAO,EAEL,KAAK,SAAS,EAEd,KAAK,oBAAoB,EAE1B,MAAM,wBAAwB,CAAC;AAkFhC,qBAAa,eAAe;IACd,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAAP,OAAO,EAAE,aAAa;IAE7C,eAAe,CAAC,KAAK,EAAE,oBAAoB,GAAG,OAAO,CAAC,MAAM,CAAC;IAqD7D,gBAAgB,CACpB,EAAE,EAAE,MAAM,EACV,OAAO,EAAE;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,GAC/C,OAAO,CAAC,IAAI,CAAC;IA0CV,mBAAmB,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAarE;AAED,qBAAa,eAAe;IACd,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAAP,OAAO,EAAE,aAAa;IAE7C,gBAAgB,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAYxC,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IAa3D,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAahD,gBAAgB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;CAa9D"}
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
import crypto from "node:crypto";
|
|
2
|
+
import { logger } from "@elizaos/core";
|
|
3
|
+
import { executeRawSql, sqlQuote, sqlText } from "../../lifeops/sql.js";
|
|
4
|
+
import { activateBlockRule } from "./block-activator.js";
|
|
5
|
+
import {
|
|
6
|
+
BLOCK_RULES_TABLE,
|
|
7
|
+
rowToBlockRule
|
|
8
|
+
} from "./block-rule-schema.js";
|
|
9
|
+
function nowMs() {
|
|
10
|
+
return Date.now();
|
|
11
|
+
}
|
|
12
|
+
function newBlockRuleId() {
|
|
13
|
+
const maybeCrypto = globalThis.crypto;
|
|
14
|
+
if (maybeCrypto?.randomUUID) return maybeCrypto.randomUUID();
|
|
15
|
+
return crypto.randomUUID();
|
|
16
|
+
}
|
|
17
|
+
function sqlBigint(value) {
|
|
18
|
+
if (value === null || value === void 0) return "NULL";
|
|
19
|
+
if (!Number.isFinite(value)) {
|
|
20
|
+
throw new Error(`[BlockRuleWriter] non-finite numeric: ${String(value)}`);
|
|
21
|
+
}
|
|
22
|
+
return String(Math.trunc(value));
|
|
23
|
+
}
|
|
24
|
+
function sqlJsonArray(values) {
|
|
25
|
+
return sqlQuote(JSON.stringify([...values]));
|
|
26
|
+
}
|
|
27
|
+
function assertValidGateType(gateType) {
|
|
28
|
+
switch (gateType) {
|
|
29
|
+
case "fixed_duration":
|
|
30
|
+
case "until_todo":
|
|
31
|
+
case "until_iso":
|
|
32
|
+
case "harsh_no_bypass":
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
function assertCreateInput(input) {
|
|
37
|
+
if (!input.profile.trim()) {
|
|
38
|
+
throw new Error("[BlockRuleWriter] profile is required");
|
|
39
|
+
}
|
|
40
|
+
if (input.websites.length === 0) {
|
|
41
|
+
throw new Error("[BlockRuleWriter] websites must not be empty");
|
|
42
|
+
}
|
|
43
|
+
assertValidGateType(input.gateType);
|
|
44
|
+
if (input.gateType === "until_todo" && !input.gateTodoId) {
|
|
45
|
+
throw new Error("[BlockRuleWriter] until_todo gate requires gateTodoId");
|
|
46
|
+
}
|
|
47
|
+
if (input.gateType === "until_iso" && input.gateUntilMs === void 0) {
|
|
48
|
+
throw new Error("[BlockRuleWriter] until_iso gate requires gateUntilMs");
|
|
49
|
+
}
|
|
50
|
+
if (input.gateType === "fixed_duration" && (input.fixedDurationMs === void 0 || input.fixedDurationMs === null)) {
|
|
51
|
+
throw new Error(
|
|
52
|
+
"[BlockRuleWriter] fixed_duration gate requires fixedDurationMs"
|
|
53
|
+
);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
function computeActivationDurationMinutes(input) {
|
|
57
|
+
if (input.gateType === "fixed_duration") {
|
|
58
|
+
if (input.fixedDurationMs === null || input.fixedDurationMs === void 0) {
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
return Math.max(1, Math.round(input.fixedDurationMs / 6e4));
|
|
62
|
+
}
|
|
63
|
+
if (input.gateType === "until_iso" && input.gateUntilMs != null) {
|
|
64
|
+
const remaining = input.gateUntilMs - nowMs();
|
|
65
|
+
return remaining > 0 ? Math.max(1, Math.round(remaining / 6e4)) : 1;
|
|
66
|
+
}
|
|
67
|
+
return null;
|
|
68
|
+
}
|
|
69
|
+
class BlockRuleWriter {
|
|
70
|
+
constructor(runtime) {
|
|
71
|
+
this.runtime = runtime;
|
|
72
|
+
}
|
|
73
|
+
runtime;
|
|
74
|
+
async createBlockRule(input) {
|
|
75
|
+
assertCreateInput(input);
|
|
76
|
+
const id = input.id ?? newBlockRuleId();
|
|
77
|
+
const agentId = String(this.runtime.agentId);
|
|
78
|
+
const createdAt = nowMs();
|
|
79
|
+
await executeRawSql(
|
|
80
|
+
this.runtime,
|
|
81
|
+
`INSERT INTO ${BLOCK_RULES_TABLE} (
|
|
82
|
+
id, agent_id, profile, websites, gate_type, gate_todo_id,
|
|
83
|
+
gate_until_ms, fixed_duration_ms, unlock_duration_ms,
|
|
84
|
+
active, created_at, released_at, released_reason
|
|
85
|
+
) VALUES (
|
|
86
|
+
${sqlQuote(id)},
|
|
87
|
+
${sqlQuote(agentId)},
|
|
88
|
+
${sqlQuote(input.profile)},
|
|
89
|
+
${sqlJsonArray(input.websites)},
|
|
90
|
+
${sqlQuote(input.gateType)},
|
|
91
|
+
${sqlText(input.gateTodoId ?? null)},
|
|
92
|
+
${sqlBigint(input.gateUntilMs ?? null)},
|
|
93
|
+
${sqlBigint(input.fixedDurationMs ?? null)},
|
|
94
|
+
${sqlBigint(input.unlockDurationMs ?? null)},
|
|
95
|
+
TRUE,
|
|
96
|
+
${sqlBigint(createdAt)},
|
|
97
|
+
NULL,
|
|
98
|
+
NULL
|
|
99
|
+
)`
|
|
100
|
+
);
|
|
101
|
+
const durationMinutes = computeActivationDurationMinutes(input);
|
|
102
|
+
const activation = await activateBlockRule({
|
|
103
|
+
runtime: this.runtime,
|
|
104
|
+
websites: input.websites,
|
|
105
|
+
durationMinutes
|
|
106
|
+
});
|
|
107
|
+
if (activation.success === false) {
|
|
108
|
+
logger.warn(
|
|
109
|
+
`[BlockRuleWriter] SelfControl activation did not complete for rule ${id}: ${activation.error}`
|
|
110
|
+
);
|
|
111
|
+
}
|
|
112
|
+
logger.info(
|
|
113
|
+
`[BlockRuleWriter] Created block rule ${id} (${input.gateType}) for ${input.websites.join(", ")}`
|
|
114
|
+
);
|
|
115
|
+
return id;
|
|
116
|
+
}
|
|
117
|
+
async releaseBlockRule(id, options) {
|
|
118
|
+
if (!options.confirmed) {
|
|
119
|
+
throw new Error(
|
|
120
|
+
"[BlockRuleWriter] releaseBlockRule requires confirmed:true"
|
|
121
|
+
);
|
|
122
|
+
}
|
|
123
|
+
const agentId = String(this.runtime.agentId);
|
|
124
|
+
const rows = await executeRawSql(
|
|
125
|
+
this.runtime,
|
|
126
|
+
`SELECT * FROM ${BLOCK_RULES_TABLE}
|
|
127
|
+
WHERE id = ${sqlQuote(id)}
|
|
128
|
+
AND agent_id = ${sqlQuote(agentId)}`
|
|
129
|
+
);
|
|
130
|
+
if (rows.length === 0) {
|
|
131
|
+
throw new Error(`[BlockRuleWriter] block rule ${id} not found`);
|
|
132
|
+
}
|
|
133
|
+
const row = rows[0];
|
|
134
|
+
if (!row) {
|
|
135
|
+
throw new Error(`[BlockRuleWriter] block rule ${id} not found`);
|
|
136
|
+
}
|
|
137
|
+
const rule = rowToBlockRule(row);
|
|
138
|
+
if (rule.gateType === "harsh_no_bypass") {
|
|
139
|
+
throw new Error(
|
|
140
|
+
`[BlockRuleWriter] block rule ${id} is harsh_no_bypass and cannot be released by user confirmation`
|
|
141
|
+
);
|
|
142
|
+
}
|
|
143
|
+
if (!rule.active) {
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
const reason = options.reason ?? "user_confirmed";
|
|
147
|
+
await executeRawSql(
|
|
148
|
+
this.runtime,
|
|
149
|
+
`UPDATE ${BLOCK_RULES_TABLE}
|
|
150
|
+
SET active = FALSE,
|
|
151
|
+
released_at = ${sqlBigint(nowMs())},
|
|
152
|
+
released_reason = ${sqlQuote(reason)}
|
|
153
|
+
WHERE id = ${sqlQuote(id)}
|
|
154
|
+
AND agent_id = ${sqlQuote(agentId)}`
|
|
155
|
+
);
|
|
156
|
+
logger.info(`[BlockRuleWriter] Released block rule ${id} (${reason})`);
|
|
157
|
+
}
|
|
158
|
+
async updateGateFulfilled(id, reason) {
|
|
159
|
+
const agentId = String(this.runtime.agentId);
|
|
160
|
+
await executeRawSql(
|
|
161
|
+
this.runtime,
|
|
162
|
+
`UPDATE ${BLOCK_RULES_TABLE}
|
|
163
|
+
SET active = FALSE,
|
|
164
|
+
released_at = ${sqlBigint(nowMs())},
|
|
165
|
+
released_reason = ${sqlQuote(reason)}
|
|
166
|
+
WHERE id = ${sqlQuote(id)}
|
|
167
|
+
AND agent_id = ${sqlQuote(agentId)}
|
|
168
|
+
AND active = TRUE`
|
|
169
|
+
);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
class BlockRuleReader {
|
|
173
|
+
constructor(runtime) {
|
|
174
|
+
this.runtime = runtime;
|
|
175
|
+
}
|
|
176
|
+
runtime;
|
|
177
|
+
async listActiveBlocks() {
|
|
178
|
+
const agentId = String(this.runtime.agentId);
|
|
179
|
+
const rows = await executeRawSql(
|
|
180
|
+
this.runtime,
|
|
181
|
+
`SELECT * FROM ${BLOCK_RULES_TABLE}
|
|
182
|
+
WHERE agent_id = ${sqlQuote(agentId)}
|
|
183
|
+
AND active = TRUE
|
|
184
|
+
ORDER BY created_at ASC`
|
|
185
|
+
);
|
|
186
|
+
return rows.map(rowToBlockRule);
|
|
187
|
+
}
|
|
188
|
+
async findBlocksGatedByTodo(todoId) {
|
|
189
|
+
const agentId = String(this.runtime.agentId);
|
|
190
|
+
const rows = await executeRawSql(
|
|
191
|
+
this.runtime,
|
|
192
|
+
`SELECT * FROM ${BLOCK_RULES_TABLE}
|
|
193
|
+
WHERE agent_id = ${sqlQuote(agentId)}
|
|
194
|
+
AND active = TRUE
|
|
195
|
+
AND gate_type = 'until_todo'
|
|
196
|
+
AND gate_todo_id = ${sqlQuote(todoId)}`
|
|
197
|
+
);
|
|
198
|
+
return rows.map(rowToBlockRule);
|
|
199
|
+
}
|
|
200
|
+
async isBlockActive(profile) {
|
|
201
|
+
const agentId = String(this.runtime.agentId);
|
|
202
|
+
const rows = await executeRawSql(
|
|
203
|
+
this.runtime,
|
|
204
|
+
`SELECT 1 AS ok FROM ${BLOCK_RULES_TABLE}
|
|
205
|
+
WHERE agent_id = ${sqlQuote(agentId)}
|
|
206
|
+
AND active = TRUE
|
|
207
|
+
AND profile = ${sqlQuote(profile)}
|
|
208
|
+
LIMIT 1`
|
|
209
|
+
);
|
|
210
|
+
return rows.length > 0;
|
|
211
|
+
}
|
|
212
|
+
async getBlockRuleById(id) {
|
|
213
|
+
const agentId = String(this.runtime.agentId);
|
|
214
|
+
const rows = await executeRawSql(
|
|
215
|
+
this.runtime,
|
|
216
|
+
`SELECT * FROM ${BLOCK_RULES_TABLE}
|
|
217
|
+
WHERE id = ${sqlQuote(id)}
|
|
218
|
+
AND agent_id = ${sqlQuote(agentId)}
|
|
219
|
+
LIMIT 1`
|
|
220
|
+
);
|
|
221
|
+
if (rows.length === 0) return null;
|
|
222
|
+
const row = rows[0];
|
|
223
|
+
return row ? rowToBlockRule(row) : null;
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
export {
|
|
227
|
+
BlockRuleReader,
|
|
228
|
+
BlockRuleWriter
|
|
229
|
+
};
|
|
230
|
+
//# sourceMappingURL=block-rule-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/website-blocker/chat-integration/block-rule-service.ts"],"sourcesContent":["import crypto from \"node:crypto\";\nimport type { IAgentRuntime } from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport { executeRawSql, sqlQuote, sqlText } from \"../../lifeops/sql.js\";\nimport { activateBlockRule } from \"./block-activator.js\";\nimport {\n BLOCK_RULES_TABLE,\n type BlockRule,\n type BlockRuleGateType,\n type CreateBlockRuleInput,\n rowToBlockRule,\n} from \"./block-rule-schema.js\";\n\n/**\n * CQRS: writers only mutate. They return the new id or void. Readers return\n * domain objects. Both live in the same module because they share the table\n * encoders, but they are separate classes so tests exercise the pipelines\n * independently.\n */\n\nfunction nowMs(): number {\n return Date.now();\n}\n\nfunction newBlockRuleId(): string {\n const maybeCrypto = (globalThis as { crypto?: { randomUUID?: () => string } })\n .crypto;\n if (maybeCrypto?.randomUUID) return maybeCrypto.randomUUID();\n return crypto.randomUUID();\n}\n\nfunction sqlBigint(value: number | null | undefined): string {\n if (value === null || value === undefined) return \"NULL\";\n if (!Number.isFinite(value)) {\n throw new Error(`[BlockRuleWriter] non-finite numeric: ${String(value)}`);\n }\n return String(Math.trunc(value));\n}\n\nfunction sqlJsonArray(values: readonly string[]): string {\n return sqlQuote(JSON.stringify([...values]));\n}\n\nfunction assertValidGateType(gateType: BlockRuleGateType): void {\n switch (gateType) {\n case \"fixed_duration\":\n case \"until_todo\":\n case \"until_iso\":\n case \"harsh_no_bypass\":\n return;\n }\n}\n\nfunction assertCreateInput(input: CreateBlockRuleInput): void {\n if (!input.profile.trim()) {\n throw new Error(\"[BlockRuleWriter] profile is required\");\n }\n if (input.websites.length === 0) {\n throw new Error(\"[BlockRuleWriter] websites must not be empty\");\n }\n assertValidGateType(input.gateType);\n if (input.gateType === \"until_todo\" && !input.gateTodoId) {\n throw new Error(\"[BlockRuleWriter] until_todo gate requires gateTodoId\");\n }\n if (input.gateType === \"until_iso\" && input.gateUntilMs === undefined) {\n throw new Error(\"[BlockRuleWriter] until_iso gate requires gateUntilMs\");\n }\n if (\n input.gateType === \"fixed_duration\" &&\n (input.fixedDurationMs === undefined || input.fixedDurationMs === null)\n ) {\n throw new Error(\n \"[BlockRuleWriter] fixed_duration gate requires fixedDurationMs\",\n );\n }\n}\n\nfunction computeActivationDurationMinutes(\n input: CreateBlockRuleInput,\n): number | null {\n if (input.gateType === \"fixed_duration\") {\n if (input.fixedDurationMs === null || input.fixedDurationMs === undefined) {\n return null;\n }\n return Math.max(1, Math.round(input.fixedDurationMs / 60_000));\n }\n if (input.gateType === \"until_iso\" && input.gateUntilMs != null) {\n const remaining = input.gateUntilMs - nowMs();\n return remaining > 0 ? Math.max(1, Math.round(remaining / 60_000)) : 1;\n }\n return null;\n}\n\nexport class BlockRuleWriter {\n constructor(private readonly runtime: IAgentRuntime) {}\n\n async createBlockRule(input: CreateBlockRuleInput): Promise<string> {\n assertCreateInput(input);\n const id = input.id ?? newBlockRuleId();\n const agentId = String(this.runtime.agentId);\n const createdAt = nowMs();\n\n await executeRawSql(\n this.runtime,\n `INSERT INTO ${BLOCK_RULES_TABLE} (\n id, agent_id, profile, websites, gate_type, gate_todo_id,\n gate_until_ms, fixed_duration_ms, unlock_duration_ms,\n active, created_at, released_at, released_reason\n ) VALUES (\n ${sqlQuote(id)},\n ${sqlQuote(agentId)},\n ${sqlQuote(input.profile)},\n ${sqlJsonArray(input.websites)},\n ${sqlQuote(input.gateType)},\n ${sqlText(input.gateTodoId ?? null)},\n ${sqlBigint(input.gateUntilMs ?? null)},\n ${sqlBigint(input.fixedDurationMs ?? null)},\n ${sqlBigint(input.unlockDurationMs ?? null)},\n TRUE,\n ${sqlBigint(createdAt)},\n NULL,\n NULL\n )`,\n );\n\n const durationMinutes = computeActivationDurationMinutes(input);\n const activation = await activateBlockRule({\n runtime: this.runtime,\n websites: input.websites,\n durationMinutes,\n });\n\n if (activation.success === false) {\n // The rule is the source of truth. Activation failures\n // (missing admin permission, unsupported platform, no helper binary)\n // are logged but do not tear down the rule — the reconciler keeps\n // the lifecycle and a retry on rule creation will re-attempt\n // activation.\n logger.warn(\n `[BlockRuleWriter] SelfControl activation did not complete for rule ${id}: ${activation.error}`,\n );\n }\n\n logger.info(\n `[BlockRuleWriter] Created block rule ${id} (${input.gateType}) for ${input.websites.join(\", \")}`,\n );\n return id;\n }\n\n async releaseBlockRule(\n id: string,\n options: { confirmed: boolean; reason?: string },\n ): Promise<void> {\n if (!options.confirmed) {\n throw new Error(\n \"[BlockRuleWriter] releaseBlockRule requires confirmed:true\",\n );\n }\n const agentId = String(this.runtime.agentId);\n const rows = await executeRawSql(\n this.runtime,\n `SELECT * FROM ${BLOCK_RULES_TABLE}\n WHERE id = ${sqlQuote(id)}\n AND agent_id = ${sqlQuote(agentId)}`,\n );\n if (rows.length === 0) {\n throw new Error(`[BlockRuleWriter] block rule ${id} not found`);\n }\n const row = rows[0];\n if (!row) {\n throw new Error(`[BlockRuleWriter] block rule ${id} not found`);\n }\n const rule = rowToBlockRule(row);\n if (rule.gateType === \"harsh_no_bypass\") {\n throw new Error(\n `[BlockRuleWriter] block rule ${id} is harsh_no_bypass and cannot be released by user confirmation`,\n );\n }\n if (!rule.active) {\n return;\n }\n const reason = options.reason ?? \"user_confirmed\";\n await executeRawSql(\n this.runtime,\n `UPDATE ${BLOCK_RULES_TABLE}\n SET active = FALSE,\n released_at = ${sqlBigint(nowMs())},\n released_reason = ${sqlQuote(reason)}\n WHERE id = ${sqlQuote(id)}\n AND agent_id = ${sqlQuote(agentId)}`,\n );\n logger.info(`[BlockRuleWriter] Released block rule ${id} (${reason})`);\n }\n\n async updateGateFulfilled(id: string, reason: string): Promise<void> {\n const agentId = String(this.runtime.agentId);\n await executeRawSql(\n this.runtime,\n `UPDATE ${BLOCK_RULES_TABLE}\n SET active = FALSE,\n released_at = ${sqlBigint(nowMs())},\n released_reason = ${sqlQuote(reason)}\n WHERE id = ${sqlQuote(id)}\n AND agent_id = ${sqlQuote(agentId)}\n AND active = TRUE`,\n );\n }\n}\n\nexport class BlockRuleReader {\n constructor(private readonly runtime: IAgentRuntime) {}\n\n async listActiveBlocks(): Promise<BlockRule[]> {\n const agentId = String(this.runtime.agentId);\n const rows = await executeRawSql(\n this.runtime,\n `SELECT * FROM ${BLOCK_RULES_TABLE}\n WHERE agent_id = ${sqlQuote(agentId)}\n AND active = TRUE\n ORDER BY created_at ASC`,\n );\n return rows.map(rowToBlockRule);\n }\n\n async findBlocksGatedByTodo(todoId: string): Promise<BlockRule[]> {\n const agentId = String(this.runtime.agentId);\n const rows = await executeRawSql(\n this.runtime,\n `SELECT * FROM ${BLOCK_RULES_TABLE}\n WHERE agent_id = ${sqlQuote(agentId)}\n AND active = TRUE\n AND gate_type = 'until_todo'\n AND gate_todo_id = ${sqlQuote(todoId)}`,\n );\n return rows.map(rowToBlockRule);\n }\n\n async isBlockActive(profile: string): Promise<boolean> {\n const agentId = String(this.runtime.agentId);\n const rows = await executeRawSql(\n this.runtime,\n `SELECT 1 AS ok FROM ${BLOCK_RULES_TABLE}\n WHERE agent_id = ${sqlQuote(agentId)}\n AND active = TRUE\n AND profile = ${sqlQuote(profile)}\n LIMIT 1`,\n );\n return rows.length > 0;\n }\n\n async getBlockRuleById(id: string): Promise<BlockRule | null> {\n const agentId = String(this.runtime.agentId);\n const rows = await executeRawSql(\n this.runtime,\n `SELECT * FROM ${BLOCK_RULES_TABLE}\n WHERE id = ${sqlQuote(id)}\n AND agent_id = ${sqlQuote(agentId)}\n LIMIT 1`,\n );\n if (rows.length === 0) return null;\n const row = rows[0];\n return row ? rowToBlockRule(row) : null;\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { IAgentRuntime } from "@elizaos/core";
|
|
2
|
+
/**
|
|
3
|
+
* Returns true when the agent has at least one active `harsh_no_bypass`
|
|
4
|
+
* rule. Used by the website-block unblock flow to refuse a soft hosts-file
|
|
5
|
+
* restore that the reconciler would re-create on its 60s tick anyway, leaving
|
|
6
|
+
* a window of unprotected state.
|
|
7
|
+
*
|
|
8
|
+
* Returns false when the runtime database adapter is unavailable
|
|
9
|
+
* (e.g. unit tests with a minimal runtime fixture). The hosts-file engine has no
|
|
10
|
+
* rule store of its own, so an unconfigured runtime cannot have rules.
|
|
11
|
+
*/
|
|
12
|
+
export declare function hasActiveHarshNoBypassRule(runtime: IAgentRuntime): Promise<boolean>;
|
|
13
|
+
//# sourceMappingURL=harsh-mode-check.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"harsh-mode-check.d.ts","sourceRoot":"","sources":["../../../src/website-blocker/chat-integration/harsh-mode-check.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAInD;;;;;;;;;GASG;AACH,wBAAsB,0BAA0B,CAC9C,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,OAAO,CAAC,CAelB"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { executeRawSql, sqlQuote } from "../../lifeops/sql.js";
|
|
2
|
+
import { BLOCK_RULES_TABLE } from "./block-rule-schema.js";
|
|
3
|
+
async function hasActiveHarshNoBypassRule(runtime) {
|
|
4
|
+
const db = runtime.adapter?.db;
|
|
5
|
+
if (!db || typeof db.execute !== "function") {
|
|
6
|
+
return false;
|
|
7
|
+
}
|
|
8
|
+
const agentId = String(runtime.agentId);
|
|
9
|
+
const rows = await executeRawSql(
|
|
10
|
+
runtime,
|
|
11
|
+
`SELECT 1 AS ok FROM ${BLOCK_RULES_TABLE}
|
|
12
|
+
WHERE agent_id = ${sqlQuote(agentId)}
|
|
13
|
+
AND active = TRUE
|
|
14
|
+
AND gate_type = 'harsh_no_bypass'
|
|
15
|
+
LIMIT 1`
|
|
16
|
+
);
|
|
17
|
+
return rows.length > 0;
|
|
18
|
+
}
|
|
19
|
+
export {
|
|
20
|
+
hasActiveHarshNoBypassRule
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=harsh-mode-check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/website-blocker/chat-integration/harsh-mode-check.ts"],"sourcesContent":["import type { IAgentRuntime } from \"@elizaos/core\";\nimport { executeRawSql, sqlQuote } from \"../../lifeops/sql.js\";\nimport { BLOCK_RULES_TABLE } from \"./block-rule-schema.js\";\n\n/**\n * Returns true when the agent has at least one active `harsh_no_bypass`\n * rule. Used by the website-block unblock flow to refuse a soft hosts-file\n * restore that the reconciler would re-create on its 60s tick anyway, leaving\n * a window of unprotected state.\n *\n * Returns false when the runtime database adapter is unavailable\n * (e.g. unit tests with a minimal runtime fixture). The hosts-file engine has no\n * rule store of its own, so an unconfigured runtime cannot have rules.\n */\nexport async function hasActiveHarshNoBypassRule(\n runtime: IAgentRuntime,\n): Promise<boolean> {\n const db = (runtime as { adapter?: { db?: unknown } }).adapter?.db;\n if (!db || typeof (db as { execute?: unknown }).execute !== \"function\") {\n return false;\n }\n const agentId = String(runtime.agentId);\n const rows = await executeRawSql(\n runtime,\n `SELECT 1 AS ok FROM ${BLOCK_RULES_TABLE}\n WHERE agent_id = ${sqlQuote(agentId)}\n AND active = TRUE\n AND gate_type = 'harsh_no_bypass'\n LIMIT 1`,\n );\n return rows.length > 0;\n}\n"],"mappings":"AACA,SAAS,eAAe,gBAAgB;AACxC,SAAS,yBAAyB;AAYlC,eAAsB,2BACpB,SACkB;AAClB,QAAM,KAAM,QAA2C,SAAS;AAChE,MAAI,CAAC,MAAM,OAAQ,GAA6B,YAAY,YAAY;AACtE,WAAO;AAAA,EACT;AACA,QAAM,UAAU,OAAO,QAAQ,OAAO;AACtC,QAAM,OAAO,MAAM;AAAA,IACjB;AAAA,IACA,uBAAuB,iBAAiB;AAAA,0BAClB,SAAS,OAAO,CAAC;AAAA;AAAA;AAAA;AAAA,EAIzC;AACA,SAAO,KAAK,SAAS;AACvB;","names":[]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { BLOCK_RULE_RECONCILE_INTERVAL_MS, BLOCK_RULE_RECONCILE_TASK_NAME, BLOCK_RULE_RECONCILE_TASK_TAGS, reconcileBlockRulesOnce, registerBlockRuleReconcilerWorker, } from "./block-rule-reconciler.js";
|
|
2
|
+
export type { BlockRule, BlockRuleGateType, CreateBlockRuleInput, } from "./block-rule-schema.js";
|
|
3
|
+
export { BLOCK_RULES_TABLE, BlockRuleRowError, rowToBlockRule, } from "./block-rule-schema.js";
|
|
4
|
+
export { BlockRuleReader, BlockRuleWriter } from "./block-rule-service.js";
|
|
5
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/website-blocker/chat-integration/index.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,gCAAgC,EAChC,8BAA8B,EAC9B,8BAA8B,EAC9B,uBAAuB,EACvB,iCAAiC,GAClC,MAAM,4BAA4B,CAAC;AACpC,YAAY,EACV,SAAS,EACT,iBAAiB,EACjB,oBAAoB,GACrB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EACL,iBAAiB,EACjB,iBAAiB,EACjB,cAAc,GACf,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import {
|
|
2
|
+
BLOCK_RULE_RECONCILE_INTERVAL_MS,
|
|
3
|
+
BLOCK_RULE_RECONCILE_TASK_NAME,
|
|
4
|
+
BLOCK_RULE_RECONCILE_TASK_TAGS,
|
|
5
|
+
reconcileBlockRulesOnce,
|
|
6
|
+
registerBlockRuleReconcilerWorker
|
|
7
|
+
} from "./block-rule-reconciler.js";
|
|
8
|
+
import {
|
|
9
|
+
BLOCK_RULES_TABLE,
|
|
10
|
+
BlockRuleRowError,
|
|
11
|
+
rowToBlockRule
|
|
12
|
+
} from "./block-rule-schema.js";
|
|
13
|
+
import { BlockRuleReader, BlockRuleWriter } from "./block-rule-service.js";
|
|
14
|
+
export {
|
|
15
|
+
BLOCK_RULES_TABLE,
|
|
16
|
+
BLOCK_RULE_RECONCILE_INTERVAL_MS,
|
|
17
|
+
BLOCK_RULE_RECONCILE_TASK_NAME,
|
|
18
|
+
BLOCK_RULE_RECONCILE_TASK_TAGS,
|
|
19
|
+
BlockRuleReader,
|
|
20
|
+
BlockRuleRowError,
|
|
21
|
+
BlockRuleWriter,
|
|
22
|
+
reconcileBlockRulesOnce,
|
|
23
|
+
registerBlockRuleReconcilerWorker,
|
|
24
|
+
rowToBlockRule
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/website-blocker/chat-integration/index.ts"],"sourcesContent":["// Reader/writer support BLOCK action=list_active/release without owning the\n// planner-facing action envelope.\nexport {\n BLOCK_RULE_RECONCILE_INTERVAL_MS,\n BLOCK_RULE_RECONCILE_TASK_NAME,\n BLOCK_RULE_RECONCILE_TASK_TAGS,\n reconcileBlockRulesOnce,\n registerBlockRuleReconcilerWorker,\n} from \"./block-rule-reconciler.js\";\nexport type {\n BlockRule,\n BlockRuleGateType,\n CreateBlockRuleInput,\n} from \"./block-rule-schema.js\";\nexport {\n BLOCK_RULES_TABLE,\n BlockRuleRowError,\n rowToBlockRule,\n} from \"./block-rule-schema.js\";\nexport { BlockRuleReader, BlockRuleWriter } from \"./block-rule-service.js\";\n"],"mappings":"AAEA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAMP;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,iBAAiB,uBAAuB;","names":[]}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Proactive browser-focus → block bridge.
|
|
3
|
+
*
|
|
4
|
+
* Closes the gap called out in `/tmp/lifeops-assessment/07-on-demand-block.md`:
|
|
5
|
+
* the browser extension already records per-domain focus windows
|
|
6
|
+
* (`plugins/plugin-personal-assistant/src/lifeops/browser-extension-store.ts`) and the
|
|
7
|
+
* website-blocker engine can sinkhole hosts on demand
|
|
8
|
+
* (`startSelfControlBlock`), but nothing previously consumed the focus
|
|
9
|
+
* stream to enforce a standing "don't let me use X" rule.
|
|
10
|
+
*
|
|
11
|
+
* This bridge runs from `recordBrowserFocusWindow`. On every focus
|
|
12
|
+
* report it asks two questions:
|
|
13
|
+
* 1. Is the agent currently inside an `enforcement-windows.ts`
|
|
14
|
+
* window (morning / night by default)? If not, do nothing —
|
|
15
|
+
* "don't let me use X this evening" should not fire at noon.
|
|
16
|
+
* 2. Does any active `life_block_rules` row match the focused
|
|
17
|
+
* domain (using the same policy expansion the engine itself uses,
|
|
18
|
+
* so a rule for `x.com` matches a focused `twitter.com` tab)?
|
|
19
|
+
*
|
|
20
|
+
* On match it calls `startSelfControlBlock` and emits a user-facing
|
|
21
|
+
* chat alert that names the domain. The bridge is the first runtime
|
|
22
|
+
* consumer of `enforcement-windows.ts` outside the reminder pipeline,
|
|
23
|
+
* which until now was the only call site.
|
|
24
|
+
*/
|
|
25
|
+
import type { IAgentRuntime } from "@elizaos/core";
|
|
26
|
+
import { type EnforcementWindow } from "../lifeops/enforcement-windows.js";
|
|
27
|
+
import type { BlockRule } from "./chat-integration/block-rule-schema.js";
|
|
28
|
+
export type ProactiveBlockBridgeReason = "blocked" | "no_active_rules" | "outside_enforcement_window" | "no_matching_rule" | "block_failed" | "rule_lookup_failed" | "invalid_domain";
|
|
29
|
+
export interface ProactiveBlockBridgeOutcome {
|
|
30
|
+
blocked: boolean;
|
|
31
|
+
reason: ProactiveBlockBridgeReason;
|
|
32
|
+
ruleId: string | null;
|
|
33
|
+
domain: string;
|
|
34
|
+
alertText: string | null;
|
|
35
|
+
enforcementWindowKind: EnforcementWindow["kind"];
|
|
36
|
+
}
|
|
37
|
+
export interface ProactiveBlockBridgeDeps {
|
|
38
|
+
/** Override the engine call. Defaults to `startSelfControlBlock`. */
|
|
39
|
+
startBlock?: (request: {
|
|
40
|
+
websites: string[];
|
|
41
|
+
durationMinutes: number | null;
|
|
42
|
+
metadata: Record<string, unknown>;
|
|
43
|
+
}) => Promise<{
|
|
44
|
+
success: boolean;
|
|
45
|
+
}>;
|
|
46
|
+
/** Override the alert dispatcher. Defaults to `runtime.sendMessageToTarget` to the rule's profile room. */
|
|
47
|
+
sendAlert?: (alert: ProactiveBlockBridgeAlert) => Promise<void>;
|
|
48
|
+
/** Read active rules. Defaults to `BlockRuleReader.listActiveBlocks`. */
|
|
49
|
+
loadActiveRules?: (runtime: IAgentRuntime) => Promise<readonly BlockRule[]>;
|
|
50
|
+
/** Override "now" — used by the enforcement-window check. */
|
|
51
|
+
now?: () => Date;
|
|
52
|
+
/** Override the IANA timezone. Defaults to `resolveDefaultTimeZone()`. */
|
|
53
|
+
timezone?: string;
|
|
54
|
+
/** Override the enforcement windows. Defaults to morning + night. */
|
|
55
|
+
enforcementWindows?: readonly EnforcementWindow[];
|
|
56
|
+
}
|
|
57
|
+
export interface ProactiveBlockBridgeAlert {
|
|
58
|
+
text: string;
|
|
59
|
+
domain: string;
|
|
60
|
+
ruleId: string;
|
|
61
|
+
enforcementWindowKind: EnforcementWindow["kind"];
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* The single entry point. Idempotent: if the engine already has an
|
|
65
|
+
* active block covering `args.domain`, `startSelfControlBlock` will
|
|
66
|
+
* report "already running" (`success: false`) and the bridge returns
|
|
67
|
+
* `block_failed` without raising. The reconciler is the long-lived
|
|
68
|
+
* lifecycle owner; this bridge only ever asks the engine to start a
|
|
69
|
+
* new short manual block when the user is observed on a banned site.
|
|
70
|
+
*/
|
|
71
|
+
export declare function evaluateProactiveBlockOnBrowserFocus(runtime: IAgentRuntime, args: {
|
|
72
|
+
domain: string;
|
|
73
|
+
deviceId?: string | null;
|
|
74
|
+
}, deps?: ProactiveBlockBridgeDeps): Promise<ProactiveBlockBridgeOutcome>;
|
|
75
|
+
//# sourceMappingURL=proactive-block-bridge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proactive-block-bridge.d.ts","sourceRoot":"","sources":["../../src/website-blocker/proactive-block-bridge.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAQnD,OAAO,EACL,KAAK,iBAAiB,EAEvB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAGzE,MAAM,MAAM,0BAA0B,GAClC,SAAS,GACT,iBAAiB,GACjB,4BAA4B,GAC5B,kBAAkB,GAClB,cAAc,GACd,oBAAoB,GACpB,gBAAgB,CAAC;AAErB,MAAM,WAAW,2BAA2B;IAC1C,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,0BAA0B,CAAC;IACnC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,qBAAqB,EAAE,iBAAiB,CAAC,MAAM,CAAC,CAAC;CAClD;AAED,MAAM,WAAW,wBAAwB;IACvC,qEAAqE;IACrE,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE;QACrB,QAAQ,EAAE,MAAM,EAAE,CAAC;QACnB,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;QAC/B,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACnC,KAAK,OAAO,CAAC;QAAE,OAAO,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;IACpC,2GAA2G;IAC3G,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,yBAAyB,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAChE,yEAAyE;IACzE,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,aAAa,KAAK,OAAO,CAAC,SAAS,SAAS,EAAE,CAAC,CAAC;IAC5E,6DAA6D;IAC7D,GAAG,CAAC,EAAE,MAAM,IAAI,CAAC;IACjB,0EAA0E;IAC1E,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,qEAAqE;IACrE,kBAAkB,CAAC,EAAE,SAAS,iBAAiB,EAAE,CAAC;CACnD;AAED,MAAM,WAAW,yBAAyB;IACxC,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,qBAAqB,EAAE,iBAAiB,CAAC,MAAM,CAAC,CAAC;CAClD;AA0ED;;;;;;;GAOG;AACH,wBAAsB,oCAAoC,CACxD,OAAO,EAAE,aAAa,EACtB,IAAI,EAAE;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,EAClD,IAAI,GAAE,wBAA6B,GAClC,OAAO,CAAC,2BAA2B,CAAC,CAqGtC"}
|