@vellumai/assistant 0.4.43 → 0.4.45
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/.prettierignore +4 -0
- package/ARCHITECTURE.md +46 -44
- package/README.md +15 -16
- package/bun.lock +10 -35
- package/docs/architecture/integrations.md +102 -215
- package/docs/architecture/keychain-broker.md +1 -1
- package/docs/architecture/memory.md +2 -2
- package/docs/architecture/scheduling.md +1 -1
- package/docs/architecture/security.md +11 -11
- package/docs/error-handling.md +1 -1
- package/docs/trusted-contact-access.md +3 -3
- package/drizzle/meta/0000_snapshot.json +34 -100
- package/drizzle/meta/_journal.json +1 -1
- package/drizzle.config.ts +4 -4
- package/package.json +3 -2
- package/scripts/capture-x-graphql.ts +237 -141
- package/scripts/generate-bundled-tool-registry.ts +223 -0
- package/src/__tests__/access-request-decision.test.ts +0 -1
- package/src/__tests__/actor-token-service.test.ts +23 -24
- package/src/__tests__/agent-loop.test.ts +0 -131
- package/src/__tests__/always-loaded-tools-guard.test.ts +71 -0
- package/src/__tests__/amazon-cdp-integration.test.ts +11 -9
- package/src/__tests__/approval-primitive.test.ts +0 -1
- package/src/__tests__/approval-routes-http.test.ts +11 -3
- package/src/__tests__/asset-materialize-tool.test.ts +0 -1
- package/src/__tests__/asset-search-tool.test.ts +0 -1
- package/src/__tests__/assistant-attachment-directive.test.ts +1 -1
- package/src/__tests__/assistant-events-sse-hardening.test.ts +0 -1
- package/src/__tests__/assistant-feature-flag-guardrails.test.ts +0 -2
- package/src/__tests__/assistant-feature-flags-integration.test.ts +70 -18
- package/src/__tests__/assistant-id-boundary-guard.test.ts +6 -6
- package/src/__tests__/attachments-store.test.ts +0 -1
- package/src/__tests__/avatar-e2e.test.ts +74 -115
- package/src/__tests__/avatar-router.test.ts +25 -62
- package/src/__tests__/browser-manager.test.ts +24 -0
- package/src/__tests__/browser-skill-baseline-tool-payload.test.ts +4 -3
- package/src/__tests__/browser-skill-endstate.test.ts +8 -11
- package/src/__tests__/btw-routes.test.ts +326 -0
- package/src/__tests__/bundled-asset.test.ts +1 -1
- package/src/__tests__/bundled-skill-retrieval-guard.test.ts +23 -9
- package/src/__tests__/call-controller.test.ts +0 -1
- package/src/__tests__/call-conversation-messages.test.ts +0 -1
- package/src/__tests__/call-domain.test.ts +0 -1
- package/src/__tests__/call-pointer-messages.test.ts +0 -1
- package/src/__tests__/call-recovery.test.ts +0 -1
- package/src/__tests__/call-routes-http.test.ts +0 -1
- package/src/__tests__/call-store.test.ts +0 -1
- package/src/__tests__/canonical-guardian-store.test.ts +0 -1
- package/src/__tests__/channel-approval-routes.test.ts +1 -1
- package/src/__tests__/channel-approvals.test.ts +1 -1
- package/src/__tests__/channel-delivery-store.test.ts +0 -1
- package/src/__tests__/channel-guardian.test.ts +5 -7
- package/src/__tests__/channel-retry-sweep.test.ts +0 -1
- package/src/__tests__/checker.test.ts +32 -36
- package/src/__tests__/compaction.benchmark.test.ts +16 -14
- package/src/__tests__/computer-use-session-lifecycle.test.ts +10 -11
- package/src/__tests__/computer-use-session-working-dir.test.ts +2 -6
- package/src/__tests__/computer-use-skill-lifecycle-cleanup.test.ts +2 -5
- package/src/__tests__/computer-use-tools.test.ts +35 -31
- package/src/__tests__/config-schema.test.ts +11 -15
- package/src/__tests__/config-watcher.test.ts +0 -1
- package/src/__tests__/confirmation-request-guardian-bridge.test.ts +0 -1
- package/src/__tests__/conflict-store.test.ts +0 -1
- package/src/__tests__/connection-policy.test.ts +4 -7
- package/src/__tests__/contacts-tools.test.ts +0 -1
- package/src/__tests__/context-memory-e2e.test.ts +2 -4
- package/src/__tests__/context-overflow-reducer.test.ts +2 -4
- package/src/__tests__/context-window-manager.test.ts +147 -60
- package/src/__tests__/contradiction-checker.test.ts +0 -1
- package/src/__tests__/conversation-attention-store.test.ts +0 -1
- package/src/__tests__/conversation-attention-telegram.test.ts +1 -1
- package/src/__tests__/conversation-pairing.test.ts +2 -2
- package/src/__tests__/conversation-routes-guardian-reply.test.ts +31 -7
- package/src/__tests__/conversation-routes-slash-commands.test.ts +381 -0
- package/src/__tests__/conversation-store.test.ts +0 -1
- package/src/__tests__/conversation-unread-route.test.ts +1 -2
- package/src/__tests__/credential-security-invariants.test.ts +8 -8
- package/src/__tests__/cross-provider-web-search.test.ts +353 -0
- package/src/__tests__/daemon-assistant-events.test.ts +6 -7
- package/src/__tests__/db-schedule-syntax-migration.test.ts +15 -3
- package/src/__tests__/delete-managed-skill-tool.test.ts +5 -9
- package/src/__tests__/deterministic-verification-control-plane.test.ts +0 -1
- package/src/__tests__/diagnostics-export.test.ts +189 -0
- package/src/__tests__/dynamic-skill-workflow-prompt.test.ts +0 -1
- package/src/__tests__/emit-signal-routing-intent.test.ts +3 -3
- package/src/__tests__/entity-extractor.test.ts +0 -1
- package/src/__tests__/entity-search.test.ts +0 -1
- package/src/__tests__/ephemeral-permissions.test.ts +2 -4
- package/src/__tests__/error-handler-friendly-messages.test.ts +46 -0
- package/src/__tests__/file-read-tool.test.ts +86 -0
- package/src/__tests__/followup-tools.test.ts +0 -1
- package/src/__tests__/frontmatter.test.ts +77 -34
- package/src/__tests__/gateway-only-enforcement.test.ts +0 -1
- package/src/__tests__/gateway-only-guard.test.ts +1 -1
- package/src/__tests__/guardian-action-conversation-turn.test.ts +0 -1
- package/src/__tests__/guardian-action-followup-executor.test.ts +0 -1
- package/src/__tests__/guardian-action-followup-store.test.ts +0 -1
- package/src/__tests__/guardian-action-grant-mint-consume.test.ts +0 -1
- package/src/__tests__/guardian-action-late-reply.test.ts +0 -1
- package/src/__tests__/guardian-action-store.test.ts +0 -1
- package/src/__tests__/guardian-action-sweep.test.ts +0 -1
- package/src/__tests__/guardian-decision-primitive-canonical.test.ts +0 -1
- package/src/__tests__/guardian-dispatch.test.ts +1 -2
- package/src/__tests__/guardian-grant-minting.test.ts +1 -1
- package/src/__tests__/guardian-outbound-http.test.ts +0 -1
- package/src/__tests__/guardian-principal-id-roundtrip.test.ts +0 -1
- package/src/__tests__/guardian-routing-invariants.test.ts +1 -1
- package/src/__tests__/guardian-routing-state.test.ts +0 -1
- package/src/__tests__/guardian-verification-voice-binding.test.ts +0 -1
- package/src/__tests__/guardian-verify-setup-skill-regression.test.ts +3 -5
- package/src/__tests__/handlers-user-message-approval-consumption.test.ts +28 -426
- package/src/__tests__/host-bash-proxy.test.ts +335 -0
- package/src/__tests__/host-file-proxy.test.ts +374 -0
- package/src/__tests__/host-shell-tool.test.ts +147 -1
- package/src/__tests__/http-user-message-parity.test.ts +361 -0
- package/src/__tests__/inbound-invite-redemption.test.ts +0 -1
- package/src/__tests__/integration-status.test.ts +3 -8
- package/src/__tests__/intent-routing.test.ts +7 -46
- package/src/__tests__/invite-redemption-service.test.ts +0 -1
- package/src/__tests__/invite-routes-http.test.ts +0 -1
- package/src/__tests__/llm-usage-store.test.ts +0 -1
- package/src/__tests__/managed-avatar-client.test.ts +101 -55
- package/src/__tests__/managed-skill-lifecycle.test.ts +9 -18
- package/src/__tests__/managed-store.test.ts +94 -21
- package/src/__tests__/media-reuse-story.e2e.test.ts +0 -1
- package/src/__tests__/memory-context-benchmark.benchmark.test.ts +2 -4
- package/src/__tests__/memory-lifecycle-e2e.test.ts +0 -1
- package/src/__tests__/memory-recall-quality.test.ts +0 -1
- package/src/__tests__/memory-regressions.experimental.test.ts +0 -1
- package/src/__tests__/memory-regressions.test.ts +0 -1
- package/src/__tests__/memory-retrieval.benchmark.test.ts +0 -1
- package/src/__tests__/memory-upsert-concurrency.test.ts +0 -1
- package/src/__tests__/messaging-send-tool.test.ts +35 -0
- package/src/__tests__/messaging-skill-split.test.ts +138 -0
- package/src/__tests__/migration-cross-version-compatibility.test.ts +0 -1
- package/src/__tests__/migration-export-http.test.ts +2 -3
- package/src/__tests__/migration-import-commit-http.test.ts +1 -2
- package/src/__tests__/migration-import-preflight-http.test.ts +1 -2
- package/src/__tests__/migration-validate-http.test.ts +1 -2
- package/src/__tests__/native-web-search.test.ts +475 -0
- package/src/__tests__/navigate-settings-tab.test.ts +84 -0
- package/src/__tests__/non-member-access-request.test.ts +0 -1
- package/src/__tests__/notification-broadcaster.test.ts +15 -15
- package/src/__tests__/notification-decision-strategy.test.ts +6 -6
- package/src/__tests__/notification-deep-link.test.ts +7 -7
- package/src/__tests__/notification-guardian-path.test.ts +2 -3
- package/src/__tests__/notification-telegram-adapter.test.ts +1 -1
- package/src/__tests__/notification-thread-candidates.test.ts +4 -4
- package/src/__tests__/onboarding-starter-tasks.test.ts +0 -1
- package/src/__tests__/onboarding-template-contract.test.ts +0 -10
- package/src/__tests__/playbook-execution.test.ts +0 -1
- package/src/__tests__/playbook-tools.test.ts +0 -1
- package/src/__tests__/profile-compiler.test.ts +0 -1
- package/src/__tests__/provider-fail-open-selection.test.ts +12 -2
- package/src/__tests__/provider-managed-proxy-integration.test.ts +25 -0
- package/src/__tests__/qdrant-collection-migration.test.ts +223 -0
- package/src/__tests__/recording-handler.test.ts +30 -94
- package/src/__tests__/registry.test.ts +28 -35
- package/src/__tests__/relay-server.test.ts +0 -1
- package/src/__tests__/ride-shotgun-handler.test.ts +4 -20
- package/src/__tests__/runtime-attachment-metadata.test.ts +0 -1
- package/src/__tests__/runtime-events-sse-parity.test.ts +3 -4
- package/src/__tests__/runtime-events-sse.test.ts +0 -1
- package/src/__tests__/sandbox-diagnostics.test.ts +0 -1
- package/src/__tests__/scaffold-managed-skill-tool.test.ts +30 -28
- package/src/__tests__/schedule-store.test.ts +441 -1
- package/src/__tests__/schedule-tools.test.ts +468 -7
- package/src/__tests__/scheduler-recurrence.test.ts +196 -23
- package/src/__tests__/scoped-approval-grants.test.ts +0 -1
- package/src/__tests__/scoped-grant-security-matrix.test.ts +0 -1
- package/src/__tests__/secret-prompt-log-hygiene.test.ts +6 -3
- package/src/__tests__/secret-response-routing.test.ts +4 -1
- package/src/__tests__/send-endpoint-busy.test.ts +14 -5
- package/src/__tests__/send-notification-tool.test.ts +0 -7
- package/src/__tests__/sequence-store.test.ts +0 -1
- package/src/__tests__/server-history-render.test.ts +1 -2
- package/src/__tests__/session-abort-tool-results.test.ts +0 -1
- package/src/__tests__/session-agent-loop.test.ts +46 -6
- package/src/__tests__/session-confirmation-signals.test.ts +7 -46
- package/src/__tests__/session-conflict-gate.test.ts +2 -6
- package/src/__tests__/session-error.test.ts +5 -14
- package/src/__tests__/session-init.benchmark.test.ts +3 -5
- package/src/__tests__/session-load-history-repair.test.ts +0 -1
- package/src/__tests__/session-media-retry.test.ts +12 -74
- package/src/__tests__/session-pre-run-repair.test.ts +0 -1
- package/src/__tests__/session-profile-injection.test.ts +2 -6
- package/src/__tests__/session-provider-retry-repair.test.ts +2 -6
- package/src/__tests__/session-queue.test.ts +94 -139
- package/src/__tests__/session-skill-tools.test.ts +115 -115
- package/src/__tests__/session-slash-known.test.ts +0 -1
- package/src/__tests__/session-slash-queue.test.ts +0 -1
- package/src/__tests__/session-slash-unknown.test.ts +0 -1
- package/src/__tests__/session-surfaces-task-progress.test.ts +34 -0
- package/src/__tests__/session-usage.test.ts +0 -1
- package/src/__tests__/session-workspace-cache-state.test.ts +2 -6
- package/src/__tests__/session-workspace-injection.test.ts +2 -6
- package/src/__tests__/session-workspace-tool-tracking.test.ts +2 -6
- package/src/__tests__/skill-feature-flags-integration.test.ts +180 -184
- package/src/__tests__/skill-feature-flags.test.ts +125 -18
- package/src/__tests__/skill-load-feature-flag.test.ts +1 -2
- package/src/__tests__/skill-load-tool.test.ts +194 -2
- package/src/__tests__/skill-projection-feature-flag.test.ts +27 -16
- package/src/__tests__/skill-projection.benchmark.test.ts +15 -14
- package/src/__tests__/skills.test.ts +14 -53
- package/src/__tests__/slack-channel-config.test.ts +0 -1
- package/src/__tests__/slack-inbound-verification.test.ts +0 -1
- package/src/__tests__/slack-skill.test.ts +1 -1
- package/src/__tests__/starter-task-flow.test.ts +9 -19
- package/src/__tests__/subagent-tools.test.ts +2 -2
- package/src/__tests__/system-prompt.test.ts +7 -7
- package/src/__tests__/task-compiler.test.ts +0 -1
- package/src/__tests__/task-management-tools.test.ts +0 -1
- package/src/__tests__/task-memory-cleanup.test.ts +0 -1
- package/src/__tests__/task-runner.test.ts +0 -1
- package/src/__tests__/task-scheduler.test.ts +0 -1
- package/src/__tests__/terminal-tools.test.ts +0 -1
- package/src/__tests__/test-support/computer-use-skill-harness.ts +2 -4
- package/src/__tests__/thread-seed-composer.test.ts +5 -5
- package/src/__tests__/tool-approval-handler.test.ts +0 -1
- package/src/__tests__/tool-execution-abort-cleanup.test.ts +0 -1
- package/src/__tests__/tool-execution-pipeline.benchmark.test.ts +0 -1
- package/src/__tests__/tool-executor.test.ts +8 -86
- package/src/__tests__/tool-grant-request-escalation.test.ts +0 -1
- package/src/__tests__/tool-notification-listener.test.ts +1 -1
- package/src/__tests__/tool-preview-lifecycle.test.ts +416 -0
- package/src/__tests__/trust-store.test.ts +84 -8
- package/src/__tests__/trusted-contact-approval-notifier.test.ts +0 -1
- package/src/__tests__/trusted-contact-inline-approval-integration.test.ts +0 -1
- package/src/__tests__/trusted-contact-lifecycle-notifications.test.ts +0 -1
- package/src/__tests__/trusted-contact-multichannel.test.ts +0 -1
- package/src/__tests__/trusted-contact-verification.test.ts +0 -1
- package/src/__tests__/twilio-provider.test.ts +0 -1
- package/src/__tests__/twilio-routes.test.ts +0 -1
- package/src/__tests__/{request-file-tool.test.ts → ui-file-upload-surface.test.ts} +11 -72
- package/src/__tests__/update-bulletin.test.ts +0 -1
- package/src/__tests__/usage-cache-backfill-migration.test.ts +0 -1
- package/src/__tests__/usage-routes.test.ts +0 -1
- package/src/__tests__/verification-control-plane-policy.test.ts +4 -4
- package/src/__tests__/voice-invite-redemption.test.ts +0 -1
- package/src/__tests__/voice-scoped-grant-consumer.test.ts +0 -1
- package/src/__tests__/voice-session-bridge.test.ts +9 -1
- package/src/__tests__/web-fetch.test.ts +57 -0
- package/src/__tests__/workspace-git-service.test.ts +5 -14
- package/src/__tests__/workspace-policy.test.ts +0 -1
- package/src/agent/loop.ts +22 -34
- package/src/bundler/bundle-signer.ts +4 -4
- package/src/calls/call-controller.ts +1 -1
- package/src/calls/relay-server.ts +1 -1
- package/src/calls/twilio-rest.ts +1 -1
- package/src/calls/voice-session-bridge.ts +3 -1
- package/src/cli/__tests__/notifications.test.ts +3 -4
- package/src/cli/commands/map.ts +2 -6
- package/src/cli/commands/mcp.ts +73 -15
- package/src/cli/commands/notifications.ts +4 -4
- package/src/cli/commands/sessions.ts +9 -1
- package/src/cli/commands/skills.ts +6 -10
- package/src/cli/http-client.ts +2 -3
- package/src/cli/main-screen.tsx +10 -10
- package/src/cli/program.ts +0 -4
- package/src/cli/reference.ts +0 -2
- package/src/cli.ts +15 -9
- package/src/config/__tests__/bundled-tool-registry-guard.test.ts +120 -0
- package/src/config/bundled-skills/_shared/CLI_RETRIEVAL_PATTERN.md +11 -0
- package/src/config/bundled-skills/app-builder/SKILL.md +6 -7
- package/src/config/bundled-skills/app-builder/TOOLS.json +0 -4
- package/src/config/bundled-skills/browser/SKILL.md +6 -1
- package/src/config/bundled-skills/chatgpt-import/SKILL.md +5 -1
- package/src/config/bundled-skills/claude-code/SKILL.md +5 -1
- package/src/config/bundled-skills/computer-use/SKILL.md +6 -1
- package/src/config/bundled-skills/computer-use/TOOLS.json +6 -69
- package/src/config/bundled-skills/computer-use/tools/computer-use-click.ts +10 -1
- package/src/config/bundled-skills/contacts/SKILL.md +10 -1
- package/src/config/bundled-skills/contacts/TOOLS.json +35 -0
- package/src/config/bundled-skills/{messaging → contacts}/tools/google-contacts.ts +9 -2
- package/src/config/bundled-skills/document/SKILL.md +4 -1
- package/src/config/bundled-skills/doordash/SKILL.md +8 -2
- package/src/config/bundled-skills/doordash/__tests__/doordash-session.test.ts +1 -82
- package/src/config/bundled-skills/doordash/doordash-cli.ts +17 -28
- package/src/config/bundled-skills/doordash/lib/session.ts +21 -17
- package/src/config/bundled-skills/doordash/lib/shared/platform.ts +4 -1
- package/src/config/bundled-skills/followups/SKILL.md +4 -1
- package/src/config/bundled-skills/gmail/SKILL.md +180 -0
- package/src/config/bundled-skills/gmail/TOOLS.json +506 -0
- package/src/config/bundled-skills/gmail/tools/gmail-archive.ts +149 -0
- package/src/config/bundled-skills/gmail/tools/gmail-attachments.ts +110 -0
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-draft.ts +1 -1
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-filters.ts +1 -1
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-follow-up.ts +1 -1
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-forward.ts +1 -1
- package/src/config/bundled-skills/gmail/tools/gmail-label.ts +50 -0
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-outreach-scan.ts +8 -90
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-send-draft.ts +1 -1
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-sender-digest.ts +2 -2
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-trash.ts +1 -1
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-unsubscribe.ts +1 -1
- package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-vacation.ts +1 -1
- package/src/config/bundled-skills/gmail/tools/shared.ts +47 -0
- package/src/config/bundled-skills/google-calendar/SKILL.md +5 -1
- package/src/config/bundled-skills/image-studio/SKILL.md +5 -1
- package/src/config/bundled-skills/knowledge-graph/SKILL.md +4 -1
- package/src/config/bundled-skills/media-processing/SKILL.md +7 -13
- package/src/config/bundled-skills/media-processing/TOOLS.json +0 -22
- package/src/config/bundled-skills/media-processing/tools/generate-clip.ts +12 -1
- package/src/config/bundled-skills/messaging/SKILL.md +23 -139
- package/src/config/bundled-skills/messaging/TOOLS.json +33 -1215
- package/src/config/bundled-skills/messaging/tools/gmail-mime-helpers.ts +42 -0
- package/src/config/bundled-skills/messaging/tools/messaging-send.ts +165 -2
- package/src/config/bundled-skills/messaging/tools/messaging-sender-digest.ts +1 -13
- package/src/config/bundled-skills/messaging/tools/shared.ts +81 -34
- package/src/config/bundled-skills/notifications/SKILL.md +5 -1
- package/src/config/bundled-skills/orchestration/SKILL.md +30 -0
- package/src/config/bundled-skills/orchestration/TOOLS.json +35 -0
- package/src/config/bundled-skills/{reminder/tools/reminder-cancel.ts → orchestration/tools/swarm-delegate.ts} +3 -3
- package/src/config/bundled-skills/phone-calls/SKILL.md +9 -1
- package/src/config/bundled-skills/playbooks/SKILL.md +4 -1
- package/src/config/bundled-skills/schedule/SKILL.md +70 -9
- package/src/config/bundled-skills/schedule/TOOLS.json +38 -6
- package/src/config/bundled-skills/screen-watch/SKILL.md +28 -0
- package/src/config/bundled-skills/screen-watch/TOOLS.json +35 -0
- package/src/config/bundled-skills/{reminder/tools/reminder-create.ts → screen-watch/tools/start-screen-watch.ts} +3 -3
- package/src/config/bundled-skills/sequences/SKILL.md +47 -0
- package/src/config/bundled-skills/sequences/TOOLS.json +340 -0
- package/src/config/bundled-skills/sequences/tools/sequence-update.ts +128 -0
- package/src/config/bundled-skills/sequences/tools/shared.ts +9 -0
- package/src/config/bundled-skills/settings/SKILL.md +12 -0
- package/src/config/bundled-skills/settings/TOOLS.json +112 -0
- package/src/config/bundled-skills/settings/tools/navigate-settings-tab.ts +43 -0
- package/src/config/bundled-skills/settings/tools/open-system-settings.ts +52 -0
- package/src/config/bundled-skills/{computer-use/tools/computer-use-right-click.ts → settings/tools/set-avatar.ts} +2 -6
- package/src/{tools/system/voice-config.ts → config/bundled-skills/settings/tools/voice-config-update.ts} +59 -96
- package/src/config/bundled-skills/skill-management/SKILL.md +18 -0
- package/src/config/bundled-skills/skill-management/TOOLS.json +90 -0
- package/src/config/bundled-skills/{computer-use/tools/computer-use-double-click.ts → skill-management/tools/delete-managed.ts} +2 -6
- package/src/config/bundled-skills/skill-management/tools/scaffold-managed.ts +12 -0
- package/src/config/bundled-skills/slack/SKILL.md +5 -1
- package/src/config/bundled-skills/subagent/SKILL.md +4 -1
- package/src/config/bundled-skills/tasks/SKILL.md +5 -2
- package/src/config/bundled-skills/transcribe/SKILL.md +4 -1
- package/src/config/bundled-skills/watcher/SKILL.md +4 -1
- package/src/config/bundled-tool-registry.ts +118 -107
- package/src/config/env.ts +5 -2
- package/src/config/feature-flag-registry.json +33 -9
- package/src/config/loader.ts +10 -2
- package/src/config/schema.ts +19 -16
- package/src/config/schemas/inference.ts +12 -22
- package/src/config/schemas/memory-storage.ts +19 -1
- package/src/config/schemas/platform.ts +0 -16
- package/src/config/skill-state.ts +11 -8
- package/src/config/skills.ts +83 -32
- package/src/context/token-estimator.ts +11 -0
- package/src/context/window-manager.ts +180 -151
- package/src/daemon/computer-use-session.ts +11 -43
- package/src/daemon/daemon-control.ts +4 -1
- package/src/daemon/handlers/config-channels.ts +5 -9
- package/src/daemon/handlers/config-ingress.ts +0 -4
- package/src/daemon/handlers/config-model.ts +7 -13
- package/src/daemon/handlers/config-telegram.ts +4 -8
- package/src/daemon/handlers/config-voice.ts +2 -5
- package/src/daemon/handlers/dictation.ts +2 -12
- package/src/daemon/handlers/identity.ts +0 -105
- package/src/daemon/handlers/recording.ts +3 -23
- package/src/daemon/handlers/session-history.ts +42 -10
- package/src/daemon/handlers/sessions.ts +53 -72
- package/src/daemon/handlers/shared.ts +7 -28
- package/src/daemon/handlers/skills.ts +31 -27
- package/src/daemon/host-bash-proxy.ts +148 -0
- package/src/daemon/host-file-proxy.ts +135 -0
- package/src/daemon/lifecycle.ts +53 -41
- package/src/daemon/mcp-reload-service.ts +123 -0
- package/src/daemon/message-protocol.ts +6 -0
- package/src/daemon/message-types/apps.ts +0 -25
- package/src/daemon/message-types/browser.ts +1 -1
- package/src/daemon/message-types/computer-use.ts +1 -4
- package/src/daemon/message-types/guardian-actions.ts +1 -1
- package/src/daemon/message-types/host-bash.ts +18 -0
- package/src/daemon/message-types/host-file.ts +44 -0
- package/src/daemon/message-types/integrations.ts +1 -73
- package/src/daemon/message-types/messages.ts +15 -0
- package/src/daemon/message-types/schedules.ts +11 -27
- package/src/daemon/message-types/sessions.ts +8 -2
- package/src/daemon/message-types/settings.ts +1 -1
- package/src/daemon/message-types/shared.ts +1 -1
- package/src/daemon/message-types/surfaces.ts +2 -0
- package/src/daemon/ride-shotgun-handler.ts +35 -43
- package/src/daemon/seed-files.ts +3 -27
- package/src/daemon/server.ts +45 -28
- package/src/daemon/session-agent-loop-handlers.ts +72 -9
- package/src/daemon/session-agent-loop.ts +97 -66
- package/src/daemon/session-attachments.ts +1 -1
- package/src/daemon/session-error.ts +17 -16
- package/src/daemon/session-lifecycle.ts +20 -1
- package/src/daemon/session-media-retry.ts +1 -15
- package/src/daemon/session-messaging.ts +14 -6
- package/src/daemon/session-process.ts +36 -7
- package/src/daemon/session-queue-manager.ts +62 -103
- package/src/daemon/session-runtime-assembly.ts +27 -7
- package/src/daemon/session-skill-tools.ts +12 -11
- package/src/daemon/session-slash.ts +7 -0
- package/src/daemon/session-surfaces.ts +192 -118
- package/src/daemon/session-tool-setup.ts +146 -6
- package/src/daemon/session.ts +75 -37
- package/src/errors.ts +0 -2
- package/src/export/formatter.ts +6 -0
- package/src/mcp/mcp-oauth-provider.ts +1 -3
- package/src/media/avatar-router.ts +20 -28
- package/src/media/avatar-types.ts +7 -14
- package/src/media/managed-avatar-client.ts +70 -34
- package/src/memory/app-store.ts +0 -18
- package/src/memory/conversation-title-service.ts +1 -2
- package/src/memory/db-init.ts +16 -0
- package/src/memory/embedding-backend.ts +129 -27
- package/src/memory/embedding-gemini.test.ts +256 -0
- package/src/memory/embedding-gemini.ts +47 -13
- package/src/memory/embedding-local.ts +14 -2
- package/src/memory/embedding-ollama.ts +15 -2
- package/src/memory/embedding-openai.ts +15 -2
- package/src/memory/embedding-types.test.ts +116 -0
- package/src/memory/embedding-types.ts +61 -0
- package/src/memory/fingerprint.ts +1 -1
- package/src/memory/indexer.ts +25 -1
- package/src/memory/job-handlers/embedding.test.ts +258 -0
- package/src/memory/job-handlers/embedding.ts +81 -1
- package/src/memory/job-handlers/index-maintenance.ts +35 -1
- package/src/memory/job-handlers/media-processing.ts +11 -1
- package/src/memory/job-utils.ts +21 -6
- package/src/memory/jobs-store.ts +5 -1
- package/src/memory/jobs-worker.ts +8 -0
- package/src/memory/message-content.ts +66 -0
- package/src/memory/migrations/100-core-tables.ts +1 -31
- package/src/memory/migrations/104-core-indexes.ts +0 -11
- package/src/memory/migrations/145-drop-accounts-table.ts +19 -0
- package/src/memory/migrations/146-schedule-oneshot-routing.ts +94 -0
- package/src/memory/migrations/147-migrate-reminders-to-schedules.ts +129 -0
- package/src/memory/migrations/148-drop-reminders-table.ts +18 -0
- package/src/memory/migrations/index.ts +4 -0
- package/src/memory/migrations/registry.ts +19 -0
- package/src/memory/qdrant-client.ts +158 -43
- package/src/memory/retriever.test.ts +0 -1
- package/src/memory/retriever.ts +12 -2
- package/src/memory/schema/infrastructure.ts +5 -37
- package/src/memory/search/formatting.ts +34 -9
- package/src/memory/search/semantic.ts +57 -2
- package/src/memory/search/types.ts +2 -1
- package/src/notifications/AGENTS.md +2 -2
- package/src/notifications/README.md +59 -58
- package/src/notifications/adapters/macos.ts +1 -1
- package/src/notifications/broadcaster.ts +5 -5
- package/src/notifications/copy-composer.ts +1 -1
- package/src/notifications/decision-engine.ts +2 -2
- package/src/notifications/destination-resolver.ts +2 -2
- package/src/notifications/emit-signal.ts +8 -8
- package/src/notifications/signal.ts +1 -1
- package/src/notifications/thread-seed-composer.ts +1 -1
- package/src/oauth/connect-orchestrator.ts +1 -1
- package/src/oauth/token-persistence.ts +1 -1
- package/src/permissions/checker.ts +12 -1
- package/src/permissions/defaults.ts +13 -17
- package/src/permissions/trust-store.ts +37 -0
- package/src/permissions/workspace-policy.ts +0 -1
- package/src/prompts/__tests__/build-cli-reference-section.test.ts +11 -0
- package/src/prompts/computer-use-prompt.ts +1 -1
- package/src/prompts/system-prompt.ts +33 -35
- package/src/prompts/templates/BOOTSTRAP.md +0 -3
- package/src/prompts/templates/SOUL.md +1 -2
- package/src/prompts/templates/UPDATES.md +16 -7
- package/src/providers/anthropic/client.ts +87 -33
- package/src/providers/gemini/client.ts +6 -0
- package/src/providers/managed-proxy/constants.ts +5 -0
- package/src/providers/openai/client.ts +15 -0
- package/src/providers/registry.ts +4 -6
- package/src/providers/types.ts +24 -2
- package/src/runtime/AGENTS.md +18 -0
- package/src/runtime/assistant-event-hub.ts +2 -3
- package/src/runtime/assistant-event.ts +4 -4
- package/src/runtime/auth/__tests__/context.test.ts +5 -5
- package/src/runtime/auth/__tests__/credential-service.test.ts +0 -1
- package/src/runtime/auth/__tests__/guard-tests.test.ts +3 -2
- package/src/runtime/auth/__tests__/{ipc-auth-context.test.ts → local-auth-context.test.ts} +21 -21
- package/src/runtime/auth/__tests__/route-policy.test.ts +2 -2
- package/src/runtime/auth/__tests__/scopes.test.ts +9 -8
- package/src/runtime/auth/__tests__/subject.test.ts +8 -8
- package/src/runtime/auth/__tests__/token-service.test.ts +0 -1
- package/src/runtime/auth/route-policy.ts +8 -8
- package/src/runtime/auth/scopes.ts +2 -1
- package/src/runtime/auth/subject.ts +4 -4
- package/src/runtime/auth/token-service.ts +1 -24
- package/src/runtime/auth/types.ts +3 -3
- package/src/runtime/guardian-action-followup-executor.ts +1 -1
- package/src/runtime/guardian-action-grant-minter.ts +1 -1
- package/src/runtime/guardian-action-service.ts +3 -3
- package/src/runtime/http-server.ts +15 -2
- package/src/runtime/http-types.ts +10 -0
- package/src/runtime/invite-service.ts +3 -3
- package/src/runtime/local-actor-identity.ts +17 -22
- package/src/runtime/middleware/error-handler.ts +14 -1
- package/src/runtime/pending-interactions.ts +21 -9
- package/src/runtime/routes/app-management-routes.ts +63 -67
- package/src/runtime/routes/approval-routes.ts +1 -3
- package/src/runtime/routes/brain-graph/brain-graph.html +1845 -0
- package/src/runtime/routes/brain-graph-routes.ts +4 -42
- package/src/runtime/routes/btw-routes.ts +155 -0
- package/src/runtime/routes/computer-use-routes.ts +77 -31
- package/src/runtime/routes/conversation-routes.ts +234 -47
- package/src/runtime/routes/diagnostics-routes.ts +154 -43
- package/src/runtime/routes/documents-routes.ts +2 -2
- package/src/runtime/routes/global-search-routes.ts +1 -1
- package/src/runtime/routes/host-bash-routes.ts +83 -0
- package/src/runtime/routes/host-file-routes.ts +79 -0
- package/src/runtime/routes/integrations/slack/share.ts +1 -1
- package/src/runtime/routes/log-export-routes.ts +120 -0
- package/src/runtime/routes/mcp-routes.ts +20 -0
- package/src/runtime/routes/migration-routes.ts +3 -3
- package/src/runtime/routes/pairing-routes.ts +1 -1
- package/src/runtime/routes/recording-routes.ts +6 -4
- package/src/runtime/routes/schedule-routes.ts +31 -5
- package/src/runtime/routes/session-management-routes.ts +2 -6
- package/src/runtime/routes/session-query-routes.ts +18 -15
- package/src/runtime/routes/settings-routes.ts +7 -351
- package/src/runtime/routes/skills-routes.ts +7 -6
- package/src/runtime/routes/subagents-routes.ts +4 -10
- package/src/runtime/routes/surface-action-routes.ts +3 -14
- package/src/runtime/routes/surface-content-routes.ts +22 -5
- package/src/runtime/routes/work-items-routes.ts +21 -25
- package/src/runtime/routes/workspace-routes.test.ts +3 -3
- package/src/runtime/routes/workspace-utils.ts +1 -1
- package/src/runtime/telegram-streaming-delivery.ts +3 -0
- package/src/runtime/verification-outbound-actions.ts +2 -2
- package/src/schedule/integration-status.ts +0 -6
- package/src/schedule/schedule-store.ts +234 -43
- package/src/schedule/scheduler.ts +73 -74
- package/src/security/oauth2.ts +1 -1
- package/src/sequence/store.ts +12 -2
- package/src/skills/frontmatter.ts +19 -77
- package/src/skills/managed-store.ts +11 -2
- package/src/subagent/manager.ts +5 -3
- package/src/tasks/ephemeral-permissions.ts +3 -5
- package/src/tools/AGENTS.md +37 -0
- package/src/tools/apps/executors.ts +0 -6
- package/src/tools/browser/browser-manager.ts +17 -11
- package/src/tools/browser/jit-auth.ts +4 -1
- package/src/tools/claude-code/claude-code.ts +1 -1
- package/src/tools/computer-use/definitions.ts +48 -60
- package/src/tools/document/document-tool.ts +6 -6
- package/src/tools/document/editor-template.ts +10 -8
- package/src/tools/filesystem/edit.ts +2 -1
- package/src/tools/filesystem/read.ts +20 -2
- package/src/tools/filesystem/write.ts +2 -1
- package/src/tools/host-filesystem/edit.ts +17 -1
- package/src/tools/host-filesystem/read.ts +16 -1
- package/src/tools/host-filesystem/write.ts +15 -1
- package/src/tools/host-terminal/host-shell.ts +24 -0
- package/src/tools/memory/definitions.ts +45 -81
- package/src/tools/memory/handlers.test.ts +0 -1
- package/src/tools/memory/handlers.ts +1 -1
- package/src/tools/memory/register.ts +26 -60
- package/src/tools/network/script-proxy/session-manager.ts +6 -8
- package/src/tools/network/web-fetch.ts +7 -1
- package/src/tools/network/web-search.ts +2 -1
- package/src/tools/registry.ts +23 -0
- package/src/tools/schedule/create.ts +113 -5
- package/src/tools/schedule/list.ts +57 -15
- package/src/tools/schedule/update.ts +73 -3
- package/src/tools/shared/filesystem/image-read.ts +192 -0
- package/src/tools/side-effects.ts +1 -7
- package/src/tools/skills/delete-managed.ts +27 -64
- package/src/tools/skills/execute.ts +54 -0
- package/src/tools/skills/load.ts +127 -5
- package/src/tools/skills/scaffold-managed.ts +93 -172
- package/src/tools/subagent/message.ts +0 -7
- package/src/tools/subagent/spawn.ts +1 -1
- package/src/tools/swarm/delegate.ts +0 -3
- package/src/tools/system/avatar-generator.ts +13 -19
- package/src/tools/system/request-permission.ts +2 -1
- package/src/tools/terminal/safe-env.ts +1 -0
- package/src/tools/tool-manifest.ts +41 -47
- package/src/tools/types.ts +6 -2
- package/src/tools/ui-surface/definitions.ts +0 -55
- package/src/util/errors.ts +12 -10
- package/src/workspace/git-service.ts +0 -2
- package/src/__tests__/account-registry.test.ts +0 -258
- package/src/__tests__/email-classifier.test.ts +0 -25
- package/src/__tests__/gmail-integration.test.ts +0 -97
- package/src/__tests__/handle-user-message-secret-resume.test.ts +0 -172
- package/src/__tests__/home-base-bootstrap.test.ts +0 -84
- package/src/__tests__/managed-twitter-guardrails.test.ts +0 -353
- package/src/__tests__/prebuilt-home-base-seed.test.ts +0 -79
- package/src/__tests__/recording-intent-fallback.test.ts +0 -199
- package/src/__tests__/recording-intent.test.ts +0 -985
- package/src/__tests__/recording-state-machine.test.ts +0 -1574
- package/src/__tests__/reminder-store.test.ts +0 -350
- package/src/__tests__/reminder.test.ts +0 -337
- package/src/__tests__/scan-result-store.test.ts +0 -121
- package/src/__tests__/twitter-platform-proxy-client.test.ts +0 -450
- package/src/__tests__/view-image-tool.test.ts +0 -241
- package/src/cli/commands/amazon/cart.ts +0 -513
- package/src/cli/commands/amazon/checkout.ts +0 -394
- package/src/cli/commands/amazon/client.ts +0 -513
- package/src/cli/commands/amazon/index.ts +0 -920
- package/src/cli/commands/amazon/product-details.ts +0 -145
- package/src/cli/commands/amazon/request-extractor.ts +0 -187
- package/src/cli/commands/amazon/search.ts +0 -76
- package/src/cli/commands/amazon/session.ts +0 -116
- package/src/cli/commands/twitter/__tests__/cli-error-shaping.test.ts +0 -265
- package/src/cli/commands/twitter/__tests__/cli-read-routing.test.ts +0 -483
- package/src/cli/commands/twitter/__tests__/cli-routing.test.ts +0 -412
- package/src/cli/commands/twitter/__tests__/oauth-client.test.ts +0 -197
- package/src/cli/commands/twitter/client.ts +0 -989
- package/src/cli/commands/twitter/index.ts +0 -1160
- package/src/cli/commands/twitter/oauth-client.ts +0 -94
- package/src/cli/commands/twitter/router.ts +0 -396
- package/src/cli/commands/twitter/session.ts +0 -121
- package/src/config/bundled-skills/agentmail/SKILL.md +0 -132
- package/src/config/bundled-skills/agentmail/icon.svg +0 -21
- package/src/config/bundled-skills/amazon/SKILL.md +0 -137
- package/src/config/bundled-skills/amazon/icon.svg +0 -13
- package/src/config/bundled-skills/api-mapping/SKILL.md +0 -78
- package/src/config/bundled-skills/api-mapping/icon.svg +0 -18
- package/src/config/bundled-skills/cli-discover/SKILL.md +0 -68
- package/src/config/bundled-skills/deploy-fullstack-vercel/SKILL.md +0 -179
- package/src/config/bundled-skills/document-writer/SKILL.md +0 -195
- package/src/config/bundled-skills/elevenlabs-voice/SKILL.md +0 -140
- package/src/config/bundled-skills/email-setup/SKILL.md +0 -68
- package/src/config/bundled-skills/frontend-design/SKILL.md +0 -44
- package/src/config/bundled-skills/frontend-design/icon.svg +0 -16
- package/src/config/bundled-skills/google-oauth-setup/SKILL.md +0 -452
- package/src/config/bundled-skills/guardian-verify-setup/SKILL.md +0 -203
- package/src/config/bundled-skills/influencer/SKILL.md +0 -144
- package/src/config/bundled-skills/influencer/scripts/client.ts +0 -1269
- package/src/config/bundled-skills/influencer/scripts/influencer.ts +0 -267
- package/src/config/bundled-skills/macos-automation/SKILL.md +0 -65
- package/src/config/bundled-skills/macos-automation/icon.svg +0 -12
- package/src/config/bundled-skills/mcp-setup/SKILL.md +0 -75
- package/src/config/bundled-skills/media-processing/tools/media-diagnostics.ts +0 -184
- package/src/config/bundled-skills/messaging/tools/gmail-archive-by-query.ts +0 -80
- package/src/config/bundled-skills/messaging/tools/gmail-archive.ts +0 -29
- package/src/config/bundled-skills/messaging/tools/gmail-batch-archive.ts +0 -56
- package/src/config/bundled-skills/messaging/tools/gmail-batch-label.ts +0 -34
- package/src/config/bundled-skills/messaging/tools/gmail-download-attachment.ts +0 -47
- package/src/config/bundled-skills/messaging/tools/gmail-label.ts +0 -31
- package/src/config/bundled-skills/messaging/tools/gmail-list-attachments.ts +0 -67
- package/src/config/bundled-skills/messaging/tools/gmail-send-with-attachments.ts +0 -97
- package/src/config/bundled-skills/messaging/tools/gmail-summarize-thread.ts +0 -87
- package/src/config/bundled-skills/messaging/tools/gmail-triage.ts +0 -135
- package/src/config/bundled-skills/messaging/tools/messaging-analyze-activity.ts +0 -24
- package/src/config/bundled-skills/messaging/tools/messaging-reply.ts +0 -201
- package/src/config/bundled-skills/messaging/tools/send-notification.ts +0 -1
- package/src/config/bundled-skills/messaging/tools/sequence-cancel.ts +0 -27
- package/src/config/bundled-skills/messaging/tools/sequence-pause.ts +0 -48
- package/src/config/bundled-skills/messaging/tools/sequence-resume.ts +0 -27
- package/src/config/bundled-skills/messaging/tools/sequence-update.ts +0 -56
- package/src/config/bundled-skills/notion/SKILL.md +0 -240
- package/src/config/bundled-skills/notion-oauth-setup/SKILL.md +0 -126
- package/src/config/bundled-skills/oauth-setup/SKILL.md +0 -143
- package/src/config/bundled-skills/public-ingress/SKILL.md +0 -258
- package/src/config/bundled-skills/reminder/SKILL.md +0 -79
- package/src/config/bundled-skills/reminder/TOOLS.json +0 -89
- package/src/config/bundled-skills/reminder/tools/reminder-list.ts +0 -12
- package/src/config/bundled-skills/restaurant-reservation/SKILL.md +0 -141
- package/src/config/bundled-skills/screen-recording/SKILL.md +0 -148
- package/src/config/bundled-skills/self-upgrade/SKILL.md +0 -69
- package/src/config/bundled-skills/skills-catalog/SKILL.md +0 -78
- package/src/config/bundled-skills/slack-app-setup/SKILL.md +0 -178
- package/src/config/bundled-skills/slack-digest-setup/SKILL.md +0 -163
- package/src/config/bundled-skills/slack-oauth-setup/SKILL.md +0 -157
- package/src/config/bundled-skills/start-the-day/SKILL.md +0 -70
- package/src/config/bundled-skills/start-the-day/icon.svg +0 -13
- package/src/config/bundled-skills/telegram-setup/SKILL.md +0 -105
- package/src/config/bundled-skills/time-based-actions/SKILL.md +0 -142
- package/src/config/bundled-skills/twilio-setup/SKILL.md +0 -232
- package/src/config/bundled-skills/twitter/SKILL.md +0 -319
- package/src/config/bundled-skills/twitter/icon.svg +0 -14
- package/src/config/bundled-skills/typescript-eval/SKILL.md +0 -60
- package/src/config/bundled-skills/vercel-token-setup/SKILL.md +0 -214
- package/src/config/bundled-skills/voice-setup/SKILL.md +0 -131
- package/src/config/bundled-skills/voice-setup/icon.svg +0 -20
- package/src/daemon/handlers/pairing.ts +0 -119
- package/src/daemon/handlers/session-user-message.ts +0 -961
- package/src/daemon/recording-executor.ts +0 -180
- package/src/daemon/recording-intent-fallback.ts +0 -162
- package/src/daemon/recording-intent.ts +0 -493
- package/src/home-base/app-link-store.ts +0 -78
- package/src/home-base/bootstrap.ts +0 -74
- package/src/home-base/prebuilt/brain-graph.html +0 -1483
- package/src/home-base/prebuilt/index.html +0 -702
- package/src/home-base/prebuilt/seed-metadata.json +0 -21
- package/src/home-base/prebuilt/seed.ts +0 -122
- package/src/home-base/prebuilt-home-base-updater.ts +0 -36
- package/src/memory/account-store.ts +0 -117
- package/src/messaging/activity-analyzer.ts +0 -76
- package/src/messaging/email-classifier.ts +0 -208
- package/src/messaging/index.ts +0 -2
- package/src/messaging/outreach-classifier.ts +0 -185
- package/src/messaging/thread-summarizer.ts +0 -346
- package/src/messaging/types.ts +0 -17
- package/src/tools/browser/x-auto-navigate.ts +0 -254
- package/src/tools/credentials/account-registry.ts +0 -144
- package/src/tools/filesystem/view-image.ts +0 -244
- package/src/tools/reminder/reminder-store.ts +0 -194
- package/src/tools/reminder/reminder.ts +0 -158
- package/src/tools/system/navigate-settings.ts +0 -74
- package/src/tools/system/open-system-settings.ts +0 -85
- package/src/tools/system/version.ts +0 -54
- package/src/twitter/platform-proxy-client.ts +0 -405
- package/src/util/cookie-session.ts +0 -98
- /package/src/config/bundled-skills/{messaging → gmail}/tools/scan-result-store.ts +0 -0
- /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-analytics.ts +0 -0
- /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-create.ts +0 -0
- /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-delete.ts +0 -0
- /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-enroll.ts +0 -0
- /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-enrollment-list.ts +0 -0
- /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-get.ts +0 -0
- /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-import.ts +0 -0
- /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-list.ts +0 -0
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: notion-oauth-setup
|
|
3
|
-
description: Create a Notion integration and OAuth credentials for Notion integration using browser automation
|
|
4
|
-
compatibility: "Designed for Vellum personal assistants"
|
|
5
|
-
metadata: {"emoji":"🔑","vellum":{"display-name":"Notion OAuth Setup","user-invocable":true,"includes":["browser","public-ingress"]}}
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
You are helping your user create a Notion integration (OAuth app) so Vellum can connect to their Notion workspace. Walk through each step below using `browser_navigate`, `browser_snapshot`, `browser_screenshot`, `browser_click`, `browser_type`, and `browser_extract` tools.
|
|
9
|
-
|
|
10
|
-
**Tone:** Be friendly and reassuring throughout. Narrate what you're doing in plain language so the user always knows what's happening. After each step, briefly confirm what was accomplished before moving on.
|
|
11
|
-
|
|
12
|
-
## Prerequisites
|
|
13
|
-
|
|
14
|
-
Before starting, check that `ingress.publicBaseUrl` is configured (Settings > Public Ingress, or `INGRESS_PUBLIC_BASE_URL` env var). If it is not set, load and execute the **public-ingress** skill first (`skill_load` with `skill: "public-ingress"`) to set up an ngrok tunnel and persist the public URL. The OAuth redirect URI depends on this value.
|
|
15
|
-
|
|
16
|
-
## Before You Start
|
|
17
|
-
|
|
18
|
-
Tell the user:
|
|
19
|
-
- "I'll walk you through creating a Notion integration so Vellum can read and write pages and databases in your workspace. The whole process takes a few minutes."
|
|
20
|
-
- "I'll be automating the Notion integrations page in the browser — you'll be able to see everything I'm doing."
|
|
21
|
-
- "I'll ask for your approval before each major step, so nothing happens without your say-so."
|
|
22
|
-
- "No sensitive credentials will be shown in the conversation."
|
|
23
|
-
|
|
24
|
-
## Step 1: Navigate to Notion Integrations
|
|
25
|
-
|
|
26
|
-
Tell the user: "First, let me open the Notion integrations page."
|
|
27
|
-
|
|
28
|
-
Use `browser_navigate` to go to `https://www.notion.so/my-integrations`.
|
|
29
|
-
|
|
30
|
-
Take a `browser_screenshot` to show the user what loaded, then take a `browser_snapshot` to check the page state:
|
|
31
|
-
- **If a sign-in page appears:** Tell the user "Please sign in to your Notion account in the browser window. Let me know when you're done." Wait for their confirmation, then take another snapshot.
|
|
32
|
-
- **If the integrations dashboard loads:** Tell the user "Notion integrations page is loaded. Let's create your integration!" and continue to Step 2.
|
|
33
|
-
|
|
34
|
-
## Step 2: Create a New Integration
|
|
35
|
-
|
|
36
|
-
**Ask for approval before proceeding.** Use `ui_show` with `surface_type: "confirmation"` and this message:
|
|
37
|
-
|
|
38
|
-
> **Create a Notion Integration**
|
|
39
|
-
>
|
|
40
|
-
> I'm about to create a new Notion integration called "Vellum Assistant". This integration will only have the capabilities you approve — it won't access any pages or databases until you explicitly share them with it or authorize it via OAuth.
|
|
41
|
-
|
|
42
|
-
Wait for the user to approve. If they decline, explain that the integration is required for OAuth and offer to try again or cancel.
|
|
43
|
-
|
|
44
|
-
Once approved:
|
|
45
|
-
1. Click "New integration" (or the "+" button)
|
|
46
|
-
2. Select "Public" as the integration type (required for OAuth)
|
|
47
|
-
3. Enter integration name: "Vellum Assistant"
|
|
48
|
-
4. Select the user's workspace
|
|
49
|
-
5. Click "Submit" or "Create"
|
|
50
|
-
|
|
51
|
-
Take a `browser_screenshot` to show the result.
|
|
52
|
-
|
|
53
|
-
Tell the user: "Integration created! Now let's configure the OAuth settings."
|
|
54
|
-
|
|
55
|
-
## Step 3: Configure OAuth Settings
|
|
56
|
-
|
|
57
|
-
Navigate to the integration's "Distribution" or "OAuth Domain & URIs" tab.
|
|
58
|
-
|
|
59
|
-
**Ask for approval before proceeding.** Use `ui_show` with `surface_type: "confirmation"` and this message:
|
|
60
|
-
|
|
61
|
-
> **Configure OAuth Redirect URI**
|
|
62
|
-
>
|
|
63
|
-
> I'm about to add the OAuth redirect URI to your Notion integration. This allows Notion to send the authorization code back to Vellum after you approve the connection.
|
|
64
|
-
|
|
65
|
-
Wait for the user to approve.
|
|
66
|
-
|
|
67
|
-
Once approved:
|
|
68
|
-
1. Find the "Redirect URIs" field
|
|
69
|
-
2. Enter `${ingress.publicBaseUrl}/webhooks/oauth/callback` (e.g. `https://abc123.ngrok-free.app/webhooks/oauth/callback`). Read the `ingress.publicBaseUrl` value from the assistant's workspace config (Settings > Public Ingress) or the `INGRESS_PUBLIC_BASE_URL` environment variable.
|
|
70
|
-
3. Save the settings
|
|
71
|
-
|
|
72
|
-
Take a `browser_snapshot` to confirm.
|
|
73
|
-
|
|
74
|
-
Tell the user: "Redirect URI configured. Now let's get your OAuth credentials."
|
|
75
|
-
|
|
76
|
-
## Step 4: Extract Client ID and Client Secret
|
|
77
|
-
|
|
78
|
-
Stay on the integration settings page and navigate to the "Secrets" or "OAuth Clients" section.
|
|
79
|
-
|
|
80
|
-
Use `browser_extract` to read:
|
|
81
|
-
1. **OAuth client_id** — this is the integration's OAuth client ID
|
|
82
|
-
2. **OAuth client_secret** — click "Show" or "Reveal" first, then extract the value
|
|
83
|
-
|
|
84
|
-
**Important:** Notion requires a client secret for the token exchange (sent via HTTP Basic Auth). Both values are needed.
|
|
85
|
-
|
|
86
|
-
Tell the user: "Credentials extracted! Now let's connect your Notion workspace."
|
|
87
|
-
|
|
88
|
-
## Step 5: Connect Notion
|
|
89
|
-
|
|
90
|
-
Tell the user: "Opening Notion authorization so you can grant Vellum access to your workspace. You'll see a Notion consent page — just click 'Allow access'."
|
|
91
|
-
|
|
92
|
-
Use the `credential_store` tool to connect Notion via OAuth2:
|
|
93
|
-
|
|
94
|
-
```
|
|
95
|
-
action: "oauth2_connect"
|
|
96
|
-
service: "integration:notion"
|
|
97
|
-
client_id: "<the extracted OAuth client_id>"
|
|
98
|
-
client_secret: "<the extracted OAuth client_secret>"
|
|
99
|
-
auth_url: "https://api.notion.com/v1/oauth/authorize"
|
|
100
|
-
token_url: "https://api.notion.com/v1/oauth/token"
|
|
101
|
-
scopes: []
|
|
102
|
-
extra_params: {"owner": "user"}
|
|
103
|
-
token_endpoint_auth_method: "client_secret_basic"
|
|
104
|
-
```
|
|
105
|
-
|
|
106
|
-
This will open the Notion authorization page in the user's browser. Wait for the flow to complete.
|
|
107
|
-
|
|
108
|
-
## Step 6: Celebrate!
|
|
109
|
-
|
|
110
|
-
Once connected, tell the user:
|
|
111
|
-
|
|
112
|
-
"**Notion is connected!** You're all set. You can now read and write pages and databases in your Notion workspace through Vellum. Try asking me to list your databases or read a specific page!"
|
|
113
|
-
|
|
114
|
-
Summarize what was accomplished:
|
|
115
|
-
- Created a Notion public integration called "Vellum Assistant"
|
|
116
|
-
- Configured the OAuth redirect URI
|
|
117
|
-
- Connected your Notion workspace with read and write access
|
|
118
|
-
|
|
119
|
-
## Error Handling
|
|
120
|
-
|
|
121
|
-
- **Page load failures:** Retry navigation once. If it still fails, tell the user and ask them to check their internet connection.
|
|
122
|
-
- **"Public" integration type not available:** The user may need to enable public integrations in their workspace settings. Guide them to Workspace Settings > Integrations.
|
|
123
|
-
- **Element not found for click/type:** Take a fresh `browser_snapshot` to re-assess the page layout. Notion's UI may have changed; adapt your selectors.
|
|
124
|
-
- **User declines an approval gate:** Don't push back. Explain briefly why the step matters, offer to try again, or cancel gracefully.
|
|
125
|
-
- **OAuth flow timeout or failure:** Tell the user what happened and offer to retry. The integration is already created, so they only need to re-run the connect step.
|
|
126
|
-
- **Any unexpected state:** Take a `browser_screenshot` and `browser_snapshot`, describe what you see, and ask the user for guidance.
|
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: oauth-setup
|
|
3
|
-
description: Connect any OAuth service — create app credentials and authorize via browser automation
|
|
4
|
-
compatibility: "Designed for Vellum personal assistants"
|
|
5
|
-
metadata: {"emoji":"🔑","vellum":{"display-name":"OAuth Setup","user-invocable":true,"includes":["browser"]}}
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
You are helping the user connect an OAuth-based service to Vellum. This is a generic setup flow that works for any provider with a well-known OAuth config.
|
|
9
|
-
|
|
10
|
-
**Tone:** Be friendly and reassuring throughout. Narrate what you're doing in plain language so the user always knows what's happening. After each step, briefly confirm what was accomplished before moving on.
|
|
11
|
-
|
|
12
|
-
## Input
|
|
13
|
-
|
|
14
|
-
You will be given a `service` name (e.g., "discord", "linear", "spotify"). If not provided, ask the user which service they want to connect.
|
|
15
|
-
|
|
16
|
-
## Step 1: Read the service config
|
|
17
|
-
|
|
18
|
-
Use `credential_store` with `action: "describe"` and `service: "<name>"` to get the well-known OAuth config. This returns:
|
|
19
|
-
- `scopes` — permissions to request
|
|
20
|
-
- `redirectUri` — the callback URL to register
|
|
21
|
-
- `callbackTransport` — loopback or gateway
|
|
22
|
-
- `requiresClientSecret` — whether a client secret is needed
|
|
23
|
-
- `authUrl` / `tokenUrl` — OAuth endpoints
|
|
24
|
-
|
|
25
|
-
It may also include a `setup` object with rich metadata:
|
|
26
|
-
- `setup.displayName` — the provider's name
|
|
27
|
-
- `setup.dashboardUrl` — where to create the app
|
|
28
|
-
- `setup.appType` — what kind of app to create
|
|
29
|
-
- `setup.requiresClientSecret` — whether a client secret is needed
|
|
30
|
-
- `setup.notes` — provider-specific guidance
|
|
31
|
-
|
|
32
|
-
If no config is found, tell the user this service doesn't have a pre-configured setup and offer to help them configure it manually via `oauth2_connect`.
|
|
33
|
-
|
|
34
|
-
## Step 2: Choose the flow based on setup metadata
|
|
35
|
-
|
|
36
|
-
### If `setup` metadata is present (rich flow)
|
|
37
|
-
|
|
38
|
-
Continue to Step 3 (Rich Flow).
|
|
39
|
-
|
|
40
|
-
### If `setup` metadata is absent (manual flow)
|
|
41
|
-
|
|
42
|
-
The provider has OAuth config (endpoints, scopes) but no setup automation metadata. Guide the user through a manual app creation:
|
|
43
|
-
|
|
44
|
-
1. Tell the user: "I have the OAuth endpoints and scopes for this service, but I don't have developer dashboard automation for it. You'll need to create an OAuth app manually."
|
|
45
|
-
2. Provide the details they need:
|
|
46
|
-
- **Scopes to request:** list the `scopes` from the config
|
|
47
|
-
- **Redirect URI:** show the `redirectUri` value
|
|
48
|
-
- **Whether a client secret is required:** use the top-level `requiresClientSecret` field
|
|
49
|
-
3. Ask the user to:
|
|
50
|
-
- Go to the provider's developer dashboard
|
|
51
|
-
- Create an OAuth app (name it "Vellum Assistant")
|
|
52
|
-
- Set the redirect URI
|
|
53
|
-
- Configure the required scopes
|
|
54
|
-
- Copy the Client ID (and Client Secret if required)
|
|
55
|
-
4. Once they provide the credentials, skip to **Step 8: Connect**.
|
|
56
|
-
|
|
57
|
-
---
|
|
58
|
-
|
|
59
|
-
## Rich Flow (when `setup` is present)
|
|
60
|
-
|
|
61
|
-
### Step 3: Tell the user what's happening
|
|
62
|
-
|
|
63
|
-
Tell the user:
|
|
64
|
-
- "I'll walk you through creating a {setup.appType} so Vellum can connect to {setup.displayName}. The whole process takes a few minutes."
|
|
65
|
-
- "I'll be automating the {setup.displayName} developer dashboard in the browser — you'll be able to see everything I'm doing."
|
|
66
|
-
- "I'll ask for your approval before each major step, so nothing happens without your say-so."
|
|
67
|
-
|
|
68
|
-
### Step 4: Navigate to the developer dashboard
|
|
69
|
-
|
|
70
|
-
Use `browser_navigate` to go to `setup.dashboardUrl`.
|
|
71
|
-
|
|
72
|
-
Take a `browser_screenshot` and `browser_snapshot`:
|
|
73
|
-
- **If a sign-in page appears:** Tell the user to sign in and wait for confirmation.
|
|
74
|
-
- **If the dashboard loads:** Continue to Step 5.
|
|
75
|
-
|
|
76
|
-
### Step 5: Create an app
|
|
77
|
-
|
|
78
|
-
**Ask for approval before proceeding.** Use `ui_show` with `surface_type: "confirmation"` explaining what you're about to create.
|
|
79
|
-
|
|
80
|
-
Once approved:
|
|
81
|
-
1. Find and click the "Create App" / "New Application" / "New Integration" button (adapt to the provider's UI)
|
|
82
|
-
2. Name it "Vellum Assistant"
|
|
83
|
-
3. Follow any guidance from `setup.notes`
|
|
84
|
-
4. Complete the creation flow
|
|
85
|
-
|
|
86
|
-
Take a `browser_screenshot` to confirm.
|
|
87
|
-
|
|
88
|
-
### Step 6: Configure scopes/permissions
|
|
89
|
-
|
|
90
|
-
**Ask for approval before proceeding.** List the `scopes` from the config and explain what each grants.
|
|
91
|
-
|
|
92
|
-
Once approved, navigate to the OAuth/permissions section and add each scope. Follow `setup.notes` for any provider-specific guidance (e.g., "User Token Scopes" vs "Bot Token Scopes").
|
|
93
|
-
|
|
94
|
-
Take a `browser_screenshot` after adding all scopes.
|
|
95
|
-
|
|
96
|
-
### Step 7: Set redirect URL
|
|
97
|
-
|
|
98
|
-
Check the `redirectUri` from the config:
|
|
99
|
-
- If it mentions "not currently configured", `GATEWAY_BASE_URL`, or `INGRESS_PUBLIC_BASE_URL` — the user needs a public gateway URL configured. Check if one is set; if not, load the `public-ingress` skill first.
|
|
100
|
-
- If it says "automatic" — skip this step entirely (no redirect URI needed).
|
|
101
|
-
- Otherwise, enter the `redirectUri` exactly as provided.
|
|
102
|
-
|
|
103
|
-
Take a `browser_snapshot` to confirm.
|
|
104
|
-
|
|
105
|
-
### Step 7b: Extract credentials
|
|
106
|
-
|
|
107
|
-
Navigate to the app's credentials/settings section.
|
|
108
|
-
|
|
109
|
-
Use `browser_extract` to read:
|
|
110
|
-
1. **Client ID** (or equivalent)
|
|
111
|
-
2. **Client Secret** (if `requiresClientSecret` is true) — click "Show"/"Reveal" first if needed
|
|
112
|
-
|
|
113
|
-
---
|
|
114
|
-
|
|
115
|
-
## Step 8: Connect
|
|
116
|
-
|
|
117
|
-
Tell the user you're opening the authorization page.
|
|
118
|
-
|
|
119
|
-
Use `credential_store` with:
|
|
120
|
-
```
|
|
121
|
-
action: "oauth2_connect"
|
|
122
|
-
service: "<service name>"
|
|
123
|
-
client_id: "<extracted client ID>"
|
|
124
|
-
client_secret: "<extracted client secret>" (if required)
|
|
125
|
-
```
|
|
126
|
-
|
|
127
|
-
Everything else (endpoints, scopes, params) is auto-filled from the well-known config. Wait for the flow to complete.
|
|
128
|
-
|
|
129
|
-
## Step 9: Celebrate!
|
|
130
|
-
|
|
131
|
-
Once connected, tell the user:
|
|
132
|
-
- If `setup` is present: "**{setup.displayName} is connected!** You're all set."
|
|
133
|
-
- If `setup` is absent: "**{service} is connected!** You're all set."
|
|
134
|
-
|
|
135
|
-
Summarize what was accomplished.
|
|
136
|
-
|
|
137
|
-
## Error Handling
|
|
138
|
-
|
|
139
|
-
- **Page load failures:** Retry once. If it still fails, ask the user to check their connection.
|
|
140
|
-
- **Element not found:** Take a fresh `browser_snapshot`. The provider's UI may have changed — adapt dynamically.
|
|
141
|
-
- **User declines an approval gate:** Don't push back. Explain why it matters, offer to retry or cancel.
|
|
142
|
-
- **OAuth flow timeout or failure:** Offer to retry. The app is already created, so only the connect step needs to be re-run.
|
|
143
|
-
- **Any unexpected state:** Take a `browser_screenshot` and `browser_snapshot`, describe what you see, and ask for guidance.
|
|
@@ -1,258 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: public-ingress
|
|
3
|
-
description: Set up and manage ngrok-based public ingress for webhooks and OAuth callbacks via ingress.publicBaseUrl
|
|
4
|
-
compatibility: "Designed for Vellum personal assistants"
|
|
5
|
-
metadata: {"emoji":"🌍","vellum":{"display-name":"Public Ingress","user-invocable":true}}
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
You are setting up and managing a public ingress tunnel so that external services (Telegram webhooks, OAuth callbacks, etc.) can reach the local Vellum gateway. This skill uses ngrok to create a secure tunnel and persists the public URL as `ingress.publicBaseUrl`.
|
|
9
|
-
|
|
10
|
-
## Overview
|
|
11
|
-
|
|
12
|
-
The Vellum gateway listens locally and needs a publicly reachable URL for:
|
|
13
|
-
|
|
14
|
-
- Telegram webhook delivery
|
|
15
|
-
- Google/Slack OAuth redirect callbacks
|
|
16
|
-
- Any other inbound webhook traffic
|
|
17
|
-
|
|
18
|
-
This skill installs ngrok, configures authentication, starts a tunnel, discovers the public URL, and saves it to the assistant's ingress config.
|
|
19
|
-
|
|
20
|
-
## Step 1: Check Current Ingress Status
|
|
21
|
-
|
|
22
|
-
First, check whether ingress is already configured:
|
|
23
|
-
|
|
24
|
-
```bash
|
|
25
|
-
assistant config get ingress.publicBaseUrl
|
|
26
|
-
assistant config get ingress.enabled
|
|
27
|
-
```
|
|
28
|
-
|
|
29
|
-
Note: The local gateway target is `$INTERNAL_GATEWAY_BASE_URL` (e.g. `http://127.0.0.1:7830`).
|
|
30
|
-
|
|
31
|
-
The commands return:
|
|
32
|
-
|
|
33
|
-
- `ingress.publicBaseUrl` — currently configured public ingress URL (if any)
|
|
34
|
-
- `ingress.enabled` — whether ingress is enabled
|
|
35
|
-
|
|
36
|
-
If `publicBaseUrl` is already set and the tunnel is running (check via `curl -s http://127.0.0.1:4040/api/tunnels`), tell the user the current status and ask if they want to reconfigure or if this is sufficient.
|
|
37
|
-
|
|
38
|
-
## Step 2: Install ngrok
|
|
39
|
-
|
|
40
|
-
Check if ngrok is installed:
|
|
41
|
-
|
|
42
|
-
```bash
|
|
43
|
-
ngrok version
|
|
44
|
-
```
|
|
45
|
-
|
|
46
|
-
If not installed, install it:
|
|
47
|
-
|
|
48
|
-
**macOS (Homebrew):**
|
|
49
|
-
|
|
50
|
-
```bash
|
|
51
|
-
brew install ngrok/ngrok/ngrok
|
|
52
|
-
```
|
|
53
|
-
|
|
54
|
-
**Linux (snap):**
|
|
55
|
-
|
|
56
|
-
```bash
|
|
57
|
-
sudo snap install ngrok
|
|
58
|
-
```
|
|
59
|
-
|
|
60
|
-
**Linux (apt — alternative):**
|
|
61
|
-
|
|
62
|
-
```bash
|
|
63
|
-
curl -sSL https://ngrok-agent.s3.amazonaws.com/ngrok.asc | sudo tee /etc/apt/trusted.gpg.d/ngrok.asc >/dev/null
|
|
64
|
-
echo "deb https://ngrok-agent.s3.amazonaws.com buster main" | sudo tee /etc/apt/sources.list.d/ngrok.list
|
|
65
|
-
sudo apt update && sudo apt install ngrok
|
|
66
|
-
```
|
|
67
|
-
|
|
68
|
-
After installation, verify with `ngrok version`.
|
|
69
|
-
|
|
70
|
-
## Step 3: Authenticate ngrok
|
|
71
|
-
|
|
72
|
-
Check if ngrok already has an auth token configured:
|
|
73
|
-
|
|
74
|
-
```bash
|
|
75
|
-
ngrok config check
|
|
76
|
-
```
|
|
77
|
-
|
|
78
|
-
If not authenticated:
|
|
79
|
-
|
|
80
|
-
1. Tell the user: "You need an ngrok account to create tunnels. If you don't have one, sign up at https://dashboard.ngrok.com/signup — it's free."
|
|
81
|
-
2. Once they have an account, use `credential_store` to securely collect their auth token. **Never ask the user to paste the token directly in chat.**
|
|
82
|
-
|
|
83
|
-
Use `credential_store` with:
|
|
84
|
-
- action: `prompt`
|
|
85
|
-
- service: `ngrok`
|
|
86
|
-
- field: `authtoken`
|
|
87
|
-
- label: `ngrok Auth Token`
|
|
88
|
-
- description: `Get your auth token from https://dashboard.ngrok.com/get-started/your-authtoken`
|
|
89
|
-
- usage_description: `ngrok authentication token for creating public tunnels`
|
|
90
|
-
|
|
91
|
-
3. Once the credential is stored, retrieve it via `credential_store` and apply it to ngrok:
|
|
92
|
-
|
|
93
|
-
```bash
|
|
94
|
-
credential_store action=get service=ngrok field=authtoken
|
|
95
|
-
ngrok config add-authtoken "<authtoken_from_credential_store>"
|
|
96
|
-
```
|
|
97
|
-
|
|
98
|
-
If no value is returned, re-run `credential_store` with `action: "prompt"` and try again.
|
|
99
|
-
|
|
100
|
-
Verify authentication succeeded by checking `ngrok config check` again.
|
|
101
|
-
|
|
102
|
-
## Step 4: Start the Tunnel
|
|
103
|
-
|
|
104
|
-
Before starting, check for an existing ngrok process to avoid duplicates:
|
|
105
|
-
|
|
106
|
-
```bash
|
|
107
|
-
curl -s http://127.0.0.1:4040/api/tunnels 2>/dev/null
|
|
108
|
-
```
|
|
109
|
-
|
|
110
|
-
If a tunnel is already running, check whether it points to the correct local target. If so, skip to Step 5. If it points elsewhere, stop it first:
|
|
111
|
-
|
|
112
|
-
```bash
|
|
113
|
-
pkill -f ngrok || true
|
|
114
|
-
sleep 1
|
|
115
|
-
```
|
|
116
|
-
|
|
117
|
-
Start ngrok in the background, tunneling to the local gateway target:
|
|
118
|
-
|
|
119
|
-
```bash
|
|
120
|
-
nohup ngrok http "$INTERNAL_GATEWAY_BASE_URL" --log=stdout > /tmp/ngrok.log 2>&1 &
|
|
121
|
-
echo $! > /tmp/ngrok.pid
|
|
122
|
-
```
|
|
123
|
-
|
|
124
|
-
Wait a few seconds for the tunnel to establish:
|
|
125
|
-
|
|
126
|
-
```bash
|
|
127
|
-
sleep 3
|
|
128
|
-
```
|
|
129
|
-
|
|
130
|
-
## Step 4b: Verify Port Alignment
|
|
131
|
-
|
|
132
|
-
Before discovering the public URL, verify that ngrok is forwarding to the same port the gateway is actually listening on. A mismatch here causes silent failures — webhooks appear to be delivered but never reach the gateway.
|
|
133
|
-
|
|
134
|
-
Query the ngrok tunnel's target port and the gateway's configured port, then compare them:
|
|
135
|
-
|
|
136
|
-
```bash
|
|
137
|
-
curl -s http://127.0.0.1:4040/api/tunnels | python3 -c "
|
|
138
|
-
import sys, json, re
|
|
139
|
-
|
|
140
|
-
data = json.load(sys.stdin)
|
|
141
|
-
tunnels = data.get('tunnels', [])
|
|
142
|
-
if not tunnels:
|
|
143
|
-
print('ERROR: no active ngrok tunnel found')
|
|
144
|
-
sys.exit(1)
|
|
145
|
-
|
|
146
|
-
addr = tunnels[0].get('config', {}).get('addr', '')
|
|
147
|
-
match = re.search(r':(\d+)$', addr)
|
|
148
|
-
if not match:
|
|
149
|
-
print(f'ERROR: could not extract port from ngrok tunnel addr: {addr}')
|
|
150
|
-
sys.exit(1)
|
|
151
|
-
|
|
152
|
-
print(match.group(1))
|
|
153
|
-
"
|
|
154
|
-
```
|
|
155
|
-
|
|
156
|
-
```bash
|
|
157
|
-
echo "$INTERNAL_GATEWAY_BASE_URL" | grep -oE '[0-9]+$'
|
|
158
|
-
```
|
|
159
|
-
|
|
160
|
-
Compare the two port numbers. If they differ, warn the user:
|
|
161
|
-
|
|
162
|
-
> **Port mismatch detected:** ngrok is forwarding to port **X** but the gateway is listening on port **Y** (from `$INTERNAL_GATEWAY_BASE_URL`). Webhooks will not reach the gateway. Stop ngrok (`pkill -f ngrok`), then re-run this skill to start ngrok on the correct port.
|
|
163
|
-
|
|
164
|
-
If the ports match, proceed silently to Step 5.
|
|
165
|
-
|
|
166
|
-
## Step 5: Discover the Public URL
|
|
167
|
-
|
|
168
|
-
Query the ngrok local API for the tunnel's public URL:
|
|
169
|
-
|
|
170
|
-
```bash
|
|
171
|
-
curl -s http://127.0.0.1:4040/api/tunnels | python3 -c "
|
|
172
|
-
import sys, json
|
|
173
|
-
data = json.load(sys.stdin)
|
|
174
|
-
tunnels = data.get('tunnels', [])
|
|
175
|
-
for t in tunnels:
|
|
176
|
-
url = t.get('public_url', '')
|
|
177
|
-
if url.startswith('https://'):
|
|
178
|
-
print(url)
|
|
179
|
-
sys.exit(0)
|
|
180
|
-
for t in tunnels:
|
|
181
|
-
url = t.get('public_url', '')
|
|
182
|
-
if url:
|
|
183
|
-
print(url)
|
|
184
|
-
sys.exit(0)
|
|
185
|
-
print('ERROR: no tunnel found')
|
|
186
|
-
sys.exit(1)
|
|
187
|
-
"
|
|
188
|
-
```
|
|
189
|
-
|
|
190
|
-
If no tunnel is found, check `/tmp/ngrok.log` for errors and report them to the user.
|
|
191
|
-
|
|
192
|
-
## Step 6: Persist the Ingress Setting
|
|
193
|
-
|
|
194
|
-
Save the discovered public URL and enable ingress:
|
|
195
|
-
|
|
196
|
-
```bash
|
|
197
|
-
assistant config set ingress.publicBaseUrl "<public-url>"
|
|
198
|
-
assistant config set ingress.enabled true
|
|
199
|
-
```
|
|
200
|
-
|
|
201
|
-
Verify it was saved:
|
|
202
|
-
|
|
203
|
-
```bash
|
|
204
|
-
assistant config get ingress.publicBaseUrl
|
|
205
|
-
assistant config get ingress.enabled
|
|
206
|
-
```
|
|
207
|
-
|
|
208
|
-
## Step 7: Report Completion
|
|
209
|
-
|
|
210
|
-
Summarize the setup:
|
|
211
|
-
|
|
212
|
-
- **Public URL:** `<the-url>` (this is your `ingress.publicBaseUrl`)
|
|
213
|
-
- **Local gateway target:** `$INTERNAL_GATEWAY_BASE_URL`
|
|
214
|
-
- **ngrok dashboard:** http://127.0.0.1:4040
|
|
215
|
-
|
|
216
|
-
Provide useful follow-up commands:
|
|
217
|
-
|
|
218
|
-
- **Check tunnel status:** `curl -s http://127.0.0.1:4040/api/tunnels | python3 -c "import sys,json; [print(t['public_url']) for t in json.load(sys.stdin)['tunnels']]"`
|
|
219
|
-
- **View ngrok logs:** `cat /tmp/ngrok.log`
|
|
220
|
-
- **Restart tunnel:** `pkill -f ngrok; sleep 1; nohup ngrok http "$INTERNAL_GATEWAY_BASE_URL" --log=stdout > /tmp/ngrok.log 2>&1 &`
|
|
221
|
-
- **Stop tunnel:** `pkill -f ngrok`
|
|
222
|
-
- **Rotate URL:** Stop and restart ngrok (free tier assigns a new URL each time; update `ingress.publicBaseUrl` afterward)
|
|
223
|
-
|
|
224
|
-
**Important:** On ngrok's free tier, the public URL changes every time the tunnel restarts. After restarting, re-run this skill or manually update `ingress.publicBaseUrl` and any registered webhooks (e.g., Telegram).
|
|
225
|
-
|
|
226
|
-
## Troubleshooting
|
|
227
|
-
|
|
228
|
-
### ngrok not installed
|
|
229
|
-
|
|
230
|
-
Run the install commands in Step 2. On macOS, make sure Homebrew is installed first (`brew --version`).
|
|
231
|
-
|
|
232
|
-
### Auth token invalid or expired
|
|
233
|
-
|
|
234
|
-
Sign in to https://dashboard.ngrok.com, copy a fresh token from the "Your Authtoken" page, and re-run Step 3.
|
|
235
|
-
|
|
236
|
-
### ngrok API (port 4040) not responding
|
|
237
|
-
|
|
238
|
-
The ngrok process may not be running. Check with `ps aux | grep ngrok`. If not running, start it per Step 4. If running but 4040 is unresponsive, check `/tmp/ngrok.log` for errors.
|
|
239
|
-
|
|
240
|
-
### Gateway not reachable on local target
|
|
241
|
-
|
|
242
|
-
Re-check the local gateway target with `echo "$INTERNAL_GATEWAY_BASE_URL"`. Run `curl -s "$INTERNAL_GATEWAY_BASE_URL/healthz"` to verify it is reachable. If the gateway is not running, start the assistant first.
|
|
243
|
-
|
|
244
|
-
### "Too many connections" or tunnel limit errors
|
|
245
|
-
|
|
246
|
-
ngrok's free tier allows one tunnel at a time. Stop any other ngrok tunnels before starting a new one.
|
|
247
|
-
|
|
248
|
-
### ngrok port doesn't match gateway port
|
|
249
|
-
|
|
250
|
-
**Symptom:** Webhooks return connection refused or timeouts even though both ngrok and the gateway appear to be running.
|
|
251
|
-
|
|
252
|
-
**Cause:** ngrok is forwarding to a different port than the gateway is listening on. This can happen if the gateway port was changed after ngrok was started, or if ngrok was started manually with a hardcoded port.
|
|
253
|
-
|
|
254
|
-
**Fix:** Stop ngrok (`pkill -f ngrok`), verify the gateway URL with `echo "$INTERNAL_GATEWAY_BASE_URL"`, then re-run this skill to start ngrok on the correct port.
|
|
255
|
-
|
|
256
|
-
### ngrok automatically restarts with wrong port
|
|
257
|
-
|
|
258
|
-
If after killing the ngrok process, it automatically re-spawns and is still attached to the incorrect port, check to see if there is a launch agent process configured to auto-restart it. This might exist at `~/Library/LaunchAgents/com.ngrok.tunnel.plist`. If so, it needs to be either removed or updated.
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: reminder
|
|
3
|
-
description: One-time time-based reminders that fire at a specific future time
|
|
4
|
-
compatibility: "Designed for Vellum personal assistants"
|
|
5
|
-
metadata: {"emoji":"🔔","vellum":{"display-name":"Reminder"}}
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
Create, list, and cancel one-time reminders. Reminders fire at a specific future time and either notify the user or execute a message through the assistant.
|
|
9
|
-
|
|
10
|
-
## Modes
|
|
11
|
-
|
|
12
|
-
- **notify** (default) — shows a notification to the user when the reminder fires
|
|
13
|
-
- **execute** — sends the reminder message to a background assistant conversation for autonomous handling
|
|
14
|
-
|
|
15
|
-
## Routing
|
|
16
|
-
|
|
17
|
-
Control how the reminder is delivered at trigger time with `routing_intent`:
|
|
18
|
-
|
|
19
|
-
- **single_channel** — deliver to one best channel
|
|
20
|
-
- **multi_channel** — deliver to a subset of channels
|
|
21
|
-
- **all_channels** (default) — deliver to every available channel
|
|
22
|
-
|
|
23
|
-
Optionally pass `routing_hints` (a JSON object) to influence routing decisions (e.g. preferred channels, exclusions). When omitted, defaults to `{}`.
|
|
24
|
-
|
|
25
|
-
### Routing Defaults
|
|
26
|
-
|
|
27
|
-
Use the following heuristics to pick `routing_intent`:
|
|
28
|
-
|
|
29
|
-
- **Default to `all_channels`** for most reminders. Users setting reminders usually want to be notified wherever they are, and redundant notifications are less harmful than missed ones.
|
|
30
|
-
- **Use `single_channel`** only when the user explicitly specifies a single channel (e.g. "remind me on Telegram") or the reminder is low-stakes and noise reduction matters.
|
|
31
|
-
- **Check `user_message_channel`** from the turn context. If the user is currently active on a specific channel (e.g. `vellum`), always include that channel. Pass it as a routing hint:
|
|
32
|
-
```
|
|
33
|
-
routing_hints: { preferred_channels: ["vellum"] }
|
|
34
|
-
routing_intent: "all_channels"
|
|
35
|
-
```
|
|
36
|
-
- **Never use `single_channel` as a passive default.** If you haven't thought about which channel to use, use `all_channels`.
|
|
37
|
-
|
|
38
|
-
### Examples
|
|
39
|
-
|
|
40
|
-
| Scenario | routing_intent | routing_hints |
|
|
41
|
-
|---|---|---|
|
|
42
|
-
| User sets reminder from desktop app | `all_channels` | `{ preferred_channels: ["vellum"] }` |
|
|
43
|
-
| User says "remind me on Telegram" | `single_channel` | `{ preferred_channels: ["telegram"] }` |
|
|
44
|
-
| User sets reminder from Telegram | `all_channels` | `{ preferred_channels: ["telegram"] }` |
|
|
45
|
-
| No channel preference expressed | `all_channels` | `{}` |
|
|
46
|
-
|
|
47
|
-
## Usage Notes
|
|
48
|
-
|
|
49
|
-
- Use reminders ONLY for time-triggered notifications (e.g. "remind me at 3pm", "remind me in 2 hours").
|
|
50
|
-
- For recurring automation, use schedules instead.
|
|
51
|
-
- For task tracking ("add to my tasks", "add to my queue"), use task_list_add instead.
|
|
52
|
-
- `fire_at` must be a strict ISO 8601 timestamp with timezone offset or Z (e.g. `2025-03-15T09:00:00-05:00` or `2025-03-15T09:00:00Z`). Ambiguous timestamps without timezone info will be rejected.
|
|
53
|
-
- `label` is a short human-readable summary shown in the notification.
|
|
54
|
-
|
|
55
|
-
### Anchored & Ambiguous Relative Time
|
|
56
|
-
|
|
57
|
-
Phrases like "at the 45 minute mark", "at the top of the hour", "on the half-hour", "at noon", "20 minutes in", or "when I hit an hour" are **clock-position or anchored relative time** expressions. Do NOT treat them as offsets from now.
|
|
58
|
-
|
|
59
|
-
**Resolution rules (in priority order):**
|
|
60
|
-
|
|
61
|
-
1. **Session-anchored expressions** — if the user mentioned a start time earlier in conversation ("I got here at 9", "meeting started at 2:10"), interpret offset-style phrases ("the 45 minute mark", "20 minutes in", "when I hit an hour") as `start_time + offset`. This takes precedence because the conversational anchor overrides any wall-clock interpretation.
|
|
62
|
-
|
|
63
|
-
2. **Clock-position expressions** — when no start time is in context, map directly to a wall-clock time:
|
|
64
|
-
- "top of the hour" / "on the hour" → next :00 (e.g. 10:00 AM)
|
|
65
|
-
- "the X minute mark" / "at :XX" → current hour's :XX; if already past, advance one hour
|
|
66
|
-
- "the half-hour mark" / "half past" → nearest upcoming :30
|
|
67
|
-
- "noon" / "midnight" → 12:00 PM or 12:00 AM today; if past, tomorrow
|
|
68
|
-
- "quarter past" / "quarter to" → :15 or :45 of current or next hour
|
|
69
|
-
|
|
70
|
-
3. **Ask only if truly ambiguous** — if neither rule 1 nor rule 2 resolves, ask: "Do you mean [clock time] or [X minutes from now]?" Never silently default to "from now."
|
|
71
|
-
|
|
72
|
-
**Examples:**
|
|
73
|
-
- "meeting started at 2:10, remind me at the 45 minute mark" → 2:55 PM (start + 45 min)
|
|
74
|
-
- "20 minutes in, I started at 2pm" → 2:20 PM (start + 20 min)
|
|
75
|
-
- "at the 45 min mark" (no start time, now: 9:39) → 9:45 AM (wall-clock)
|
|
76
|
-
- "at the 45 min mark" (no start time, now: 9:50) → 10:45 AM (wall-clock, next hour)
|
|
77
|
-
- "top of the hour" (now: 9:39) → 10:00 AM
|
|
78
|
-
- "at noon" → 12:00 PM today
|
|
79
|
-
- "at the hour mark" with no start time → ask for clarification
|