@rubytech/create-maxy-code 0.1.0
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/__tests__/account-id-env.test.js +48 -0
- package/dist/__tests__/apt-resolve.test.js +179 -0
- package/dist/__tests__/brew-install.test.js +141 -0
- package/dist/__tests__/brew-resolve.test.js +103 -0
- package/dist/__tests__/cdp-port-no-silent-fallback.test.js +53 -0
- package/dist/__tests__/launchd-plist.test.js +149 -0
- package/dist/__tests__/macos-version.test.js +96 -0
- package/dist/__tests__/peer-brand-detect.test.js +103 -0
- package/dist/__tests__/platform-detect.test.js +50 -0
- package/dist/__tests__/port-canonicalisation.test.js +200 -0
- package/dist/__tests__/preflight-port-classifier.test.js +330 -0
- package/dist/__tests__/snap-chromium.test.js +115 -0
- package/dist/apt-resolve.js +73 -0
- package/dist/brew-install.js +175 -0
- package/dist/brew-resolve.js +68 -0
- package/dist/index.js +3325 -0
- package/dist/launchd-plist.js +68 -0
- package/dist/macos-version.js +53 -0
- package/dist/peer-brand-detect.js +39 -0
- package/dist/pinned-binaries.js +12 -0
- package/dist/platform-detect.js +36 -0
- package/dist/port-resolution.js +153 -0
- package/dist/preflight-port-classifier.js +222 -0
- package/dist/snap-chromium.js +89 -0
- package/dist/uninstall.js +861 -0
- package/package.json +32 -0
- package/payload/platform/config/brand-registry.json +20 -0
- package/payload/platform/config/brand.json +54 -0
- package/payload/platform/lib/account-enumeration/dist/__tests__/enumerate.test.d.ts +2 -0
- package/payload/platform/lib/account-enumeration/dist/__tests__/enumerate.test.d.ts.map +1 -0
- package/payload/platform/lib/account-enumeration/dist/__tests__/enumerate.test.js +88 -0
- package/payload/platform/lib/account-enumeration/dist/__tests__/enumerate.test.js.map +1 -0
- package/payload/platform/lib/account-enumeration/dist/__tests__/validate-env.test.d.ts +2 -0
- package/payload/platform/lib/account-enumeration/dist/__tests__/validate-env.test.d.ts.map +1 -0
- package/payload/platform/lib/account-enumeration/dist/__tests__/validate-env.test.js +55 -0
- package/payload/platform/lib/account-enumeration/dist/__tests__/validate-env.test.js.map +1 -0
- package/payload/platform/lib/account-enumeration/dist/index.d.ts +49 -0
- package/payload/platform/lib/account-enumeration/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/account-enumeration/dist/index.js +109 -0
- package/payload/platform/lib/account-enumeration/dist/index.js.map +1 -0
- package/payload/platform/lib/account-enumeration/src/__tests__/enumerate.test.ts +94 -0
- package/payload/platform/lib/account-enumeration/src/__tests__/validate-env.test.ts +57 -0
- package/payload/platform/lib/account-enumeration/src/index.ts +140 -0
- package/payload/platform/lib/account-enumeration/tsconfig.json +8 -0
- package/payload/platform/lib/admins-write/dist/index.d.ts +87 -0
- package/payload/platform/lib/admins-write/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/admins-write/dist/index.js +248 -0
- package/payload/platform/lib/admins-write/dist/index.js.map +1 -0
- package/payload/platform/lib/admins-write/src/index.ts +311 -0
- package/payload/platform/lib/admins-write/tsconfig.json +8 -0
- package/payload/platform/lib/anthropic-key/dist/index.d.ts +22 -0
- package/payload/platform/lib/anthropic-key/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/anthropic-key/dist/index.js +232 -0
- package/payload/platform/lib/anthropic-key/dist/index.js.map +1 -0
- package/payload/platform/lib/brand-templating/dist/index.d.ts +18 -0
- package/payload/platform/lib/brand-templating/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/brand-templating/dist/index.js +69 -0
- package/payload/platform/lib/brand-templating/dist/index.js.map +1 -0
- package/payload/platform/lib/brand-templating/src/index.ts +76 -0
- package/payload/platform/lib/brand-templating/tsconfig.json +8 -0
- package/payload/platform/lib/device-url/dist/index.d.ts +44 -0
- package/payload/platform/lib/device-url/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/device-url/dist/index.js +68 -0
- package/payload/platform/lib/device-url/dist/index.js.map +1 -0
- package/payload/platform/lib/device-url/src/index.ts +78 -0
- package/payload/platform/lib/device-url/tsconfig.json +8 -0
- package/payload/platform/lib/entitlement/PUBKEY-HASH.txt +1 -0
- package/payload/platform/lib/entitlement/dist/canonicalize.d.ts +26 -0
- package/payload/platform/lib/entitlement/dist/canonicalize.d.ts.map +1 -0
- package/payload/platform/lib/entitlement/dist/canonicalize.js +54 -0
- package/payload/platform/lib/entitlement/dist/canonicalize.js.map +1 -0
- package/payload/platform/lib/entitlement/dist/index.d.ts +76 -0
- package/payload/platform/lib/entitlement/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/entitlement/dist/index.js +293 -0
- package/payload/platform/lib/entitlement/dist/index.js.map +1 -0
- package/payload/platform/lib/entitlement/rubytech-pubkey.pem +3 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/cypher-validate-write.test.d.ts +2 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/cypher-validate-write.test.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/cypher-validate-write.test.js +97 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/cypher-validate-write.test.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/cypher-validate.test.d.ts +2 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/cypher-validate.test.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/cypher-validate.test.js +112 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/cypher-validate.test.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/schema-cache.test.d.ts +2 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/schema-cache.test.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/schema-cache.test.js +163 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/schema-cache.test.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/schema-cypher-parser.test.d.ts +2 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/schema-cypher-parser.test.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/schema-cypher-parser.test.js +89 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/schema-cypher-parser.test.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/warnings-envelope.test.d.ts +2 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/warnings-envelope.test.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/warnings-envelope.test.js +140 -0
- package/payload/platform/lib/graph-mcp/dist/__tests__/warnings-envelope.test.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-rewrite-stamp.d.ts +37 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-rewrite-stamp.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-rewrite-stamp.js +333 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-rewrite-stamp.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-shim-read.d.ts +85 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-shim-read.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-shim-read.js +93 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-shim-read.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-shim-write.d.ts +71 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-shim-write.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-shim-write.js +168 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-shim-write.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-validate.d.ts +50 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-validate.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-validate.js +197 -0
- package/payload/platform/lib/graph-mcp/dist/cypher-validate.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/index.d.ts +26 -0
- package/payload/platform/lib/graph-mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/index.js +847 -0
- package/payload/platform/lib/graph-mcp/dist/index.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/schema-cache.d.ts +75 -0
- package/payload/platform/lib/graph-mcp/dist/schema-cache.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/schema-cache.js +217 -0
- package/payload/platform/lib/graph-mcp/dist/schema-cache.js.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/schema-cypher-parser.d.ts +42 -0
- package/payload/platform/lib/graph-mcp/dist/schema-cypher-parser.d.ts.map +1 -0
- package/payload/platform/lib/graph-mcp/dist/schema-cypher-parser.js +87 -0
- package/payload/platform/lib/graph-mcp/dist/schema-cypher-parser.js.map +1 -0
- package/payload/platform/lib/graph-mcp/src/__tests__/cypher-validate-write.test.ts +150 -0
- package/payload/platform/lib/graph-mcp/src/__tests__/cypher-validate.test.ts +141 -0
- package/payload/platform/lib/graph-mcp/src/__tests__/schema-cache.test.ts +169 -0
- package/payload/platform/lib/graph-mcp/src/__tests__/schema-cypher-parser.test.ts +99 -0
- package/payload/platform/lib/graph-mcp/src/__tests__/warnings-envelope.test.ts +151 -0
- package/payload/platform/lib/graph-mcp/src/cypher-rewrite-stamp.ts +349 -0
- package/payload/platform/lib/graph-mcp/src/cypher-shim-read.ts +141 -0
- package/payload/platform/lib/graph-mcp/src/cypher-shim-write.ts +240 -0
- package/payload/platform/lib/graph-mcp/src/cypher-validate.ts +249 -0
- package/payload/platform/lib/graph-mcp/src/index.ts +1076 -0
- package/payload/platform/lib/graph-mcp/src/schema-cache.ts +242 -0
- package/payload/platform/lib/graph-mcp/src/schema-cypher-parser.ts +84 -0
- package/payload/platform/lib/graph-mcp/tsconfig.json +8 -0
- package/payload/platform/lib/graph-search/dist/index.d.ts +227 -0
- package/payload/platform/lib/graph-search/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/graph-search/dist/index.js +525 -0
- package/payload/platform/lib/graph-search/dist/index.js.map +1 -0
- package/payload/platform/lib/graph-search/src/__tests__/bm25-label-gate.test.ts +88 -0
- package/payload/platform/lib/graph-search/src/__tests__/bm25-only.test.ts +129 -0
- package/payload/platform/lib/graph-search/src/__tests__/bm25-strong-bypass-threshold.test.ts +126 -0
- package/payload/platform/lib/graph-search/src/__tests__/brochure-threshold.test.ts +136 -0
- package/payload/platform/lib/graph-search/src/__tests__/escape-and-normalise.test.ts +53 -0
- package/payload/platform/lib/graph-search/src/__tests__/expand-batch.test.ts +206 -0
- package/payload/platform/lib/graph-search/src/__tests__/fulltext-coverage.test.ts +280 -0
- package/payload/platform/lib/graph-search/src/__tests__/hybrid.test.ts +262 -0
- package/payload/platform/lib/graph-search/src/__tests__/vector-threshold.test.ts +170 -0
- package/payload/platform/lib/graph-search/src/index.ts +718 -0
- package/payload/platform/lib/graph-search/tsconfig.json +9 -0
- package/payload/platform/lib/graph-search/vitest.config.ts +9 -0
- package/payload/platform/lib/graph-trash/dist/index.d.ts +99 -0
- package/payload/platform/lib/graph-trash/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/graph-trash/dist/index.js +333 -0
- package/payload/platform/lib/graph-trash/dist/index.js.map +1 -0
- package/payload/platform/lib/graph-trash/src/index.ts +475 -0
- package/payload/platform/lib/graph-trash/tsconfig.json +8 -0
- package/payload/platform/lib/graph-write/dist/__tests__/account-id-gate.test.d.ts +2 -0
- package/payload/platform/lib/graph-write/dist/__tests__/account-id-gate.test.d.ts.map +1 -0
- package/payload/platform/lib/graph-write/dist/__tests__/account-id-gate.test.js +165 -0
- package/payload/platform/lib/graph-write/dist/__tests__/account-id-gate.test.js.map +1 -0
- package/payload/platform/lib/graph-write/dist/__tests__/action-provenance-gate.test.d.ts +2 -0
- package/payload/platform/lib/graph-write/dist/__tests__/action-provenance-gate.test.d.ts.map +1 -0
- package/payload/platform/lib/graph-write/dist/__tests__/action-provenance-gate.test.js +226 -0
- package/payload/platform/lib/graph-write/dist/__tests__/action-provenance-gate.test.js.map +1 -0
- package/payload/platform/lib/graph-write/dist/__tests__/audit.test.d.ts +2 -0
- package/payload/platform/lib/graph-write/dist/__tests__/audit.test.d.ts.map +1 -0
- package/payload/platform/lib/graph-write/dist/__tests__/audit.test.js +147 -0
- package/payload/platform/lib/graph-write/dist/__tests__/audit.test.js.map +1 -0
- package/payload/platform/lib/graph-write/dist/audit.d.ts +84 -0
- package/payload/platform/lib/graph-write/dist/audit.d.ts.map +1 -0
- package/payload/platform/lib/graph-write/dist/audit.js +129 -0
- package/payload/platform/lib/graph-write/dist/audit.js.map +1 -0
- package/payload/platform/lib/graph-write/dist/conversation-provenance.d.ts +26 -0
- package/payload/platform/lib/graph-write/dist/conversation-provenance.d.ts.map +1 -0
- package/payload/platform/lib/graph-write/dist/conversation-provenance.js +81 -0
- package/payload/platform/lib/graph-write/dist/conversation-provenance.js.map +1 -0
- package/payload/platform/lib/graph-write/dist/index.d.ts +124 -0
- package/payload/platform/lib/graph-write/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/graph-write/dist/index.js +288 -0
- package/payload/platform/lib/graph-write/dist/index.js.map +1 -0
- package/payload/platform/lib/graph-write/src/__tests__/account-id-gate.test.ts +189 -0
- package/payload/platform/lib/graph-write/src/__tests__/action-provenance-gate.test.ts +252 -0
- package/payload/platform/lib/graph-write/src/__tests__/audit.test.ts +162 -0
- package/payload/platform/lib/graph-write/src/audit.ts +182 -0
- package/payload/platform/lib/graph-write/src/conversation-provenance.ts +140 -0
- package/payload/platform/lib/graph-write/src/index.ts +386 -0
- package/payload/platform/lib/graph-write/tsconfig.json +8 -0
- package/payload/platform/lib/mcp-eager/dist/index.d.ts +61 -0
- package/payload/platform/lib/mcp-eager/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/mcp-eager/dist/index.js +49 -0
- package/payload/platform/lib/mcp-eager/dist/index.js.map +1 -0
- package/payload/platform/lib/mcp-eager/src/index.ts +78 -0
- package/payload/platform/lib/mcp-eager/tsconfig.json +8 -0
- package/payload/platform/lib/mcp-spawn-tee/dist/index.d.ts +53 -0
- package/payload/platform/lib/mcp-spawn-tee/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/mcp-spawn-tee/dist/index.js +132 -0
- package/payload/platform/lib/mcp-spawn-tee/dist/index.js.map +1 -0
- package/payload/platform/lib/mcp-spawn-tee/src/index.ts +134 -0
- package/payload/platform/lib/mcp-spawn-tee/tsconfig.json +8 -0
- package/payload/platform/lib/mcp-stderr-tee/dist/index.d.ts +51 -0
- package/payload/platform/lib/mcp-stderr-tee/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/mcp-stderr-tee/dist/index.js +196 -0
- package/payload/platform/lib/mcp-stderr-tee/dist/index.js.map +1 -0
- package/payload/platform/lib/mcp-stderr-tee/src/index.ts +206 -0
- package/payload/platform/lib/mcp-stderr-tee/tsconfig.json +8 -0
- package/payload/platform/lib/models/dist/index.d.ts +7 -0
- package/payload/platform/lib/models/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/models/dist/index.js +20 -0
- package/payload/platform/lib/models/dist/index.js.map +1 -0
- package/payload/platform/lib/models/src/index.ts +18 -0
- package/payload/platform/lib/models/tsconfig.json +8 -0
- package/payload/platform/lib/oauth-llm/dist/index.d.ts +118 -0
- package/payload/platform/lib/oauth-llm/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/oauth-llm/dist/index.js +388 -0
- package/payload/platform/lib/oauth-llm/dist/index.js.map +1 -0
- package/payload/platform/lib/oauth-llm/src/index.ts +585 -0
- package/payload/platform/lib/oauth-llm/tsconfig.json +8 -0
- package/payload/platform/lib/persistent-components/dist/index.d.ts +21 -0
- package/payload/platform/lib/persistent-components/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/persistent-components/dist/index.js +32 -0
- package/payload/platform/lib/persistent-components/dist/index.js.map +1 -0
- package/payload/platform/lib/persistent-components/src/index.ts +28 -0
- package/payload/platform/lib/persistent-components/tsconfig.json +8 -0
- package/payload/platform/lib/screening-patterns/dist/index.d.ts +29 -0
- package/payload/platform/lib/screening-patterns/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/screening-patterns/dist/index.js +48 -0
- package/payload/platform/lib/screening-patterns/dist/index.js.map +1 -0
- package/payload/platform/lib/screening-patterns/src/index.ts +51 -0
- package/payload/platform/lib/screening-patterns/tsconfig.json +8 -0
- package/payload/platform/lib/task-secrets/dist/index.d.ts +40 -0
- package/payload/platform/lib/task-secrets/dist/index.d.ts.map +1 -0
- package/payload/platform/lib/task-secrets/dist/index.js +44 -0
- package/payload/platform/lib/task-secrets/dist/index.js.map +1 -0
- package/payload/platform/lib/task-secrets/src/__tests__/redact-secrets.test.ts +127 -0
- package/payload/platform/lib/task-secrets/src/index.ts +77 -0
- package/payload/platform/lib/task-secrets/tsconfig.json +9 -0
- package/payload/platform/lib/task-secrets/vitest.config.ts +9 -0
- package/payload/platform/neo4j/edge-annotations.json +154 -0
- package/payload/platform/neo4j/schema.cypher +1104 -0
- package/payload/platform/package-lock.json +3576 -0
- package/payload/platform/package.json +25 -0
- package/payload/platform/plugins/admin/PLUGIN.md +81 -0
- package/payload/platform/plugins/admin/hooks/__tests__/archive-ingest-surface-gate.test.sh +191 -0
- package/payload/platform/plugins/admin/hooks/__tests__/playwright-file-guard.test.sh +278 -0
- package/payload/platform/plugins/admin/hooks/__tests__/pre-tool-use-base64-guard.test.sh +204 -0
- package/payload/platform/plugins/admin/hooks/archive-ingest-surface-gate.sh +225 -0
- package/payload/platform/plugins/admin/hooks/playwright-file-guard.sh +214 -0
- package/payload/platform/plugins/admin/hooks/pre-tool-use.sh +294 -0
- package/payload/platform/plugins/admin/hooks/webfetch-preflight.mjs +363 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/plugin-read-skill-resolution.test.d.ts +2 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/plugin-read-skill-resolution.test.d.ts.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/plugin-read-skill-resolution.test.js +91 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/plugin-read-skill-resolution.test.js.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/public-hostname.test.d.ts +2 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/public-hostname.test.d.ts.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/public-hostname.test.js +98 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/public-hostname.test.js.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/skill-load-required-inputs.test.d.ts +2 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/skill-load-required-inputs.test.d.ts.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/skill-load-required-inputs.test.js +141 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/skill-load-required-inputs.test.js.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/skill-load.test.d.ts +2 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/skill-load.test.d.ts.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/skill-load.test.js +88 -0
- package/payload/platform/plugins/admin/mcp/dist/__tests__/skill-load.test.js.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/admin/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/index.js +3495 -0
- package/payload/platform/plugins/admin/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/neo4j.d.ts +5 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/neo4j.d.ts.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/neo4j.js +40 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/neo4j.js.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/onboarding.d.ts +39 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/onboarding.d.ts.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/onboarding.js +249 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/onboarding.js.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/public-hostname.d.ts +15 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/public-hostname.d.ts.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/public-hostname.js +73 -0
- package/payload/platform/plugins/admin/mcp/dist/lib/public-hostname.js.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/skill-resolution.d.ts +35 -0
- package/payload/platform/plugins/admin/mcp/dist/skill-resolution.d.ts.map +1 -0
- package/payload/platform/plugins/admin/mcp/dist/skill-resolution.js +140 -0
- package/payload/platform/plugins/admin/mcp/dist/skill-resolution.js.map +1 -0
- package/payload/platform/plugins/admin/mcp/package.json +23 -0
- package/payload/platform/plugins/admin/mcp/vitest.config.ts +9 -0
- package/payload/platform/plugins/admin/references/chat-ui-guide.md +31 -0
- package/payload/platform/plugins/admin/references/contextual-ui.md +107 -0
- package/payload/platform/plugins/admin/skills/a4-print-documents/SKILL.md +241 -0
- package/payload/platform/plugins/admin/skills/access-manager/SKILL.md +28 -0
- package/payload/platform/plugins/admin/skills/access-manager/references/operations.md +197 -0
- package/payload/platform/plugins/admin/skills/business-profile/SKILL.md +53 -0
- package/payload/platform/plugins/admin/skills/datetime/SKILL.md +91 -0
- package/payload/platform/plugins/admin/skills/deck-pages/SKILL.md +418 -0
- package/payload/platform/plugins/admin/skills/onboarding/SKILL.md +255 -0
- package/payload/platform/plugins/admin/skills/plainly/SKILL.md +105 -0
- package/payload/platform/plugins/admin/skills/plainly/references/worked-examples.md +301 -0
- package/payload/platform/plugins/admin/skills/plugin-management/SKILL.md +99 -0
- package/payload/platform/plugins/admin/skills/public-agent-manager/SKILL.md +277 -0
- package/payload/platform/plugins/admin/skills/publish-site/SKILL.md +72 -0
- package/payload/platform/plugins/admin/skills/qr-code/SKILL.md +35 -0
- package/payload/platform/plugins/admin/skills/qr-code/references/data-formats.md +113 -0
- package/payload/platform/plugins/admin/skills/skill-builder/SKILL.md +113 -0
- package/payload/platform/plugins/admin/skills/skill-builder/references/lean-pattern.md +110 -0
- package/payload/platform/plugins/admin/skills/skill-builder/references/pdf-generation.md +30 -0
- package/payload/platform/plugins/admin/skills/specialist-management/SKILL.md +44 -0
- package/payload/platform/plugins/admin/skills/stream-log-review/SKILL.md +71 -0
- package/payload/platform/plugins/admin/skills/stream-log-review/references/analysis-patterns.md +189 -0
- package/payload/platform/plugins/admin/skills/unzip-attachment/SKILL.md +79 -0
- package/payload/platform/plugins/admin/skills/unzip-attachment/__tests__/preflight.sh +148 -0
- package/payload/platform/plugins/admin/skills/unzip-attachment/references/safety.md +116 -0
- package/payload/platform/plugins/admin/skills/update-knowledge/SKILL.md +47 -0
- package/payload/platform/plugins/anthropic/PLUGIN.md +40 -0
- package/payload/platform/plugins/anthropic/references/console-api.md +186 -0
- package/payload/platform/plugins/anthropic/references/setup-guide.md +36 -0
- package/payload/platform/plugins/anthropic/skills/get-api-key/SKILL.md +138 -0
- package/payload/platform/plugins/business-assistant/PLUGIN.md +59 -0
- package/payload/platform/plugins/business-assistant/references/crm.md +112 -0
- package/payload/platform/plugins/business-assistant/references/document-management.md +96 -0
- package/payload/platform/plugins/business-assistant/references/escalation.md +126 -0
- package/payload/platform/plugins/business-assistant/references/invoicing.md +163 -0
- package/payload/platform/plugins/business-assistant/references/profiling.md +50 -0
- package/payload/platform/plugins/business-assistant/references/quoting.md +56 -0
- package/payload/platform/plugins/business-assistant/references/scheduling.md +127 -0
- package/payload/platform/plugins/business-assistant/references/task-management.md +163 -0
- package/payload/platform/plugins/cloudflare/PLUGIN.md +73 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/index.js +29 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/lib/cloudflared.d.ts +283 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/lib/cloudflared.d.ts.map +1 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/lib/cloudflared.js +1155 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/lib/cloudflared.js.map +1 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/lib/setup-orchestrator.d.ts +90 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/lib/setup-orchestrator.d.ts.map +1 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/lib/setup-orchestrator.js +550 -0
- package/payload/platform/plugins/cloudflare/mcp/dist/lib/setup-orchestrator.js.map +1 -0
- package/payload/platform/plugins/cloudflare/mcp/package.json +18 -0
- package/payload/platform/plugins/cloudflare/mcp/vitest.config.ts +10 -0
- package/payload/platform/plugins/cloudflare/references/dashboard-guide.md +108 -0
- package/payload/platform/plugins/cloudflare/references/manual-setup.md +481 -0
- package/payload/platform/plugins/cloudflare/references/reset-guide.md +118 -0
- package/payload/platform/plugins/cloudflare/scripts/_stream-log.sh +154 -0
- package/payload/platform/plugins/cloudflare/scripts/list-cf-domains.sh +98 -0
- package/payload/platform/plugins/cloudflare/scripts/list-cf-domains.ts +751 -0
- package/payload/platform/plugins/cloudflare/scripts/reset-tunnel.sh +107 -0
- package/payload/platform/plugins/cloudflare/scripts/setup-tunnel.sh +826 -0
- package/payload/platform/plugins/cloudflare/skills/setup-tunnel/SKILL.md +107 -0
- package/payload/platform/plugins/contacts/PLUGIN.md +31 -0
- package/payload/platform/plugins/contacts/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/contacts/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/index.js +433 -0
- package/payload/platform/plugins/contacts/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/lib/neo4j.d.ts +5 -0
- package/payload/platform/plugins/contacts/mcp/dist/lib/neo4j.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/lib/neo4j.js +40 -0
- package/payload/platform/plugins/contacts/mcp/dist/lib/neo4j.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/lib/resolve-person.d.ts +33 -0
- package/payload/platform/plugins/contacts/mcp/dist/lib/resolve-person.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/lib/resolve-person.js +53 -0
- package/payload/platform/plugins/contacts/mcp/dist/lib/resolve-person.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-create.d.ts +23 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-create.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-create.js +123 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-create.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-delete.d.ts +28 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-delete.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-delete.js +39 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-delete.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-erase.d.ts +41 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-erase.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-erase.js +142 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-erase.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-export.d.ts +52 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-export.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-export.js +119 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-export.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-list.d.ts +23 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-list.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-list.js +49 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-list.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-lookup.d.ts +21 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-lookup.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-lookup.js +70 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-lookup.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-update.d.ts +14 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-update.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-update.js +43 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/contact-update.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/group-create.d.ts +18 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/group-create.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/group-create.js +95 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/group-create.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/group-manage.d.ts +15 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/group-manage.d.ts.map +1 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/group-manage.js +72 -0
- package/payload/platform/plugins/contacts/mcp/dist/tools/group-manage.js.map +1 -0
- package/payload/platform/plugins/contacts/mcp/package.json +19 -0
- package/payload/platform/plugins/deep-research/PLUGIN.md +13 -0
- package/payload/platform/plugins/deep-research/skills/deep-research/SKILL.md +46 -0
- package/payload/platform/plugins/deep-research/skills/deep-research/references/citation-styles.md +52 -0
- package/payload/platform/plugins/deep-research/skills/deep-research/references/research-modes.md +22 -0
- package/payload/platform/plugins/deep-research/skills/deep-research/references/search-strategy.md +24 -0
- package/payload/platform/plugins/docs/PLUGIN.md +52 -0
- package/payload/platform/plugins/docs/references/access-control.md +73 -0
- package/payload/platform/plugins/docs/references/admin-session.md +80 -0
- package/payload/platform/plugins/docs/references/attachments.md +44 -0
- package/payload/platform/plugins/docs/references/cloudflare.md +111 -0
- package/payload/platform/plugins/docs/references/contacts-guide.md +102 -0
- package/payload/platform/plugins/docs/references/deployment.md +150 -0
- package/payload/platform/plugins/docs/references/getting-started.md +82 -0
- package/payload/platform/plugins/docs/references/graph.md +149 -0
- package/payload/platform/plugins/docs/references/internals.md +512 -0
- package/payload/platform/plugins/docs/references/memory-guide.md +119 -0
- package/payload/platform/plugins/docs/references/migration-guide.md +90 -0
- package/payload/platform/plugins/docs/references/outlook-guide.md +69 -0
- package/payload/platform/plugins/docs/references/platform.md +111 -0
- package/payload/platform/plugins/docs/references/plugins-guide.md +174 -0
- package/payload/platform/plugins/docs/references/projects-guide.md +73 -0
- package/payload/platform/plugins/docs/references/settings.md +82 -0
- package/payload/platform/plugins/docs/references/telegram-guide.md +58 -0
- package/payload/platform/plugins/docs/references/troubleshooting.md +532 -0
- package/payload/platform/plugins/email/PLUGIN.md +49 -0
- package/payload/platform/plugins/email/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/email/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/index.js +291 -0
- package/payload/platform/plugins/email/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/credentials.d.ts +118 -0
- package/payload/platform/plugins/email/mcp/dist/lib/credentials.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/credentials.js +364 -0
- package/payload/platform/plugins/email/mcp/dist/lib/credentials.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/embedding.d.ts +2 -0
- package/payload/platform/plugins/email/mcp/dist/lib/embedding.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/embedding.js +24 -0
- package/payload/platform/plugins/email/mcp/dist/lib/embedding.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/graph.d.ts +87 -0
- package/payload/platform/plugins/email/mcp/dist/lib/graph.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/graph.js +324 -0
- package/payload/platform/plugins/email/mcp/dist/lib/graph.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/imap.d.ts +215 -0
- package/payload/platform/plugins/email/mcp/dist/lib/imap.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/imap.js +735 -0
- package/payload/platform/plugins/email/mcp/dist/lib/imap.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/neo4j.d.ts +5 -0
- package/payload/platform/plugins/email/mcp/dist/lib/neo4j.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/neo4j.js +40 -0
- package/payload/platform/plugins/email/mcp/dist/lib/neo4j.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/providers.d.ts +32 -0
- package/payload/platform/plugins/email/mcp/dist/lib/providers.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/providers.js +569 -0
- package/payload/platform/plugins/email/mcp/dist/lib/providers.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/screening.d.ts +29 -0
- package/payload/platform/plugins/email/mcp/dist/lib/screening.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/screening.js +105 -0
- package/payload/platform/plugins/email/mcp/dist/lib/screening.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/smtp.d.ts +21 -0
- package/payload/platform/plugins/email/mcp/dist/lib/smtp.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/lib/smtp.js +77 -0
- package/payload/platform/plugins/email/mcp/dist/lib/smtp.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/scripts/email-auto-respond.d.ts +38 -0
- package/payload/platform/plugins/email/mcp/dist/scripts/email-auto-respond.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/scripts/email-auto-respond.js +894 -0
- package/payload/platform/plugins/email/mcp/dist/scripts/email-auto-respond.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/scripts/email-fetch.d.ts +25 -0
- package/payload/platform/plugins/email/mcp/dist/scripts/email-fetch.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/scripts/email-fetch.js +227 -0
- package/payload/platform/plugins/email/mcp/dist/scripts/email-fetch.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-auto-respond-config.d.ts +19 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-auto-respond-config.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-auto-respond-config.js +151 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-auto-respond-config.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-graph-query.d.ts +22 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-graph-query.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-graph-query.js +188 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-graph-query.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-otp-extract.d.ts +15 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-otp-extract.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-otp-extract.js +142 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-otp-extract.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-read.d.ts +14 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-read.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-read.js +75 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-read.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-reply.d.ts +10 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-reply.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-reply.js +83 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-reply.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-search.d.ts +15 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-search.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-search.js +63 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-search.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-send.d.ts +10 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-send.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-send.js +31 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-send.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-setup.d.ts +22 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-setup.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-setup.js +183 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-setup.js.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-status.d.ts +6 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-status.d.ts.map +1 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-status.js +43 -0
- package/payload/platform/plugins/email/mcp/dist/tools/email-status.js.map +1 -0
- package/payload/platform/plugins/email/mcp/package.json +23 -0
- package/payload/platform/plugins/email/references/email-reference.md +204 -0
- package/payload/platform/plugins/linkedin-import/PLUGIN.md +27 -0
- package/payload/platform/plugins/linkedin-import/skills/linkedin-import/SKILL.md +142 -0
- package/payload/platform/plugins/linkedin-import/skills/linkedin-import/references/connections.md +135 -0
- package/payload/platform/plugins/linkedin-import/skills/linkedin-import/references/profile.md +95 -0
- package/payload/platform/plugins/memory/PLUGIN.md +146 -0
- package/payload/platform/plugins/memory/bin/conversation-archive-ingest.mjs +879 -0
- package/payload/platform/plugins/memory/bin/conversation-archive-ingest.sh +138 -0
- package/payload/platform/plugins/memory/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/index.js +1813 -0
- package/payload/platform/plugins/memory/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/live-schema-source.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/live-schema-source.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/live-schema-source.test.js +92 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/live-schema-source.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/llm-classifier.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/llm-classifier.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/llm-classifier.test.js +225 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/llm-classifier.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/schema-loader.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/schema-loader.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/schema-loader.test.js +100 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/schema-loader.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/schema-validator.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/schema-validator.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/schema-validator.test.js +448 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/__tests__/schema-validator.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/attachments.d.ts +37 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/attachments.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/attachments.js +69 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/attachments.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/index.d.ts +5 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/index.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/index.js +30 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/index.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/timestamp-scanner.d.ts +49 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/timestamp-scanner.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/timestamp-scanner.js +35 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/timestamp-scanner.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/types.d.ts +47 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/types.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/types.js +31 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/types.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/whatsapp-text.d.ts +3 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/whatsapp-text.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/whatsapp-text.js +155 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-normalisers/whatsapp-text.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/delta-cursor.d.ts +11 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/delta-cursor.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/delta-cursor.js +20 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/delta-cursor.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/derive-keys.d.ts +14 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/derive-keys.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/derive-keys.js +38 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/derive-keys.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/sender-bind.d.ts +16 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/sender-bind.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/sender-bind.js +59 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/sender-bind.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/sessionize.d.ts +9 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/sessionize.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/sessionize.js +32 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/sessionize.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/to-turn-text.d.ts +3 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/to-turn-text.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/to-turn-text.js +29 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/conversation-pipeline/to-turn-text.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/document-chunker.d.ts +45 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/document-chunker.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/document-chunker.js +125 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/document-chunker.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/document-hierarchy.d.ts +9 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/document-hierarchy.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/document-hierarchy.js +61 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/document-hierarchy.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/embeddings.d.ts +3 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/embeddings.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/embeddings.js +29 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/embeddings.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/filter-token.d.ts +36 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/filter-token.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/filter-token.js +86 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/filter-token.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/graph-prune.d.ts +42 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/graph-prune.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/graph-prune.js +114 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/graph-prune.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/graph-write-gate.d.ts +38 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/graph-write-gate.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/graph-write-gate.js +89 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/graph-write-gate.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/live-schema-source.d.ts +136 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/live-schema-source.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/live-schema-source.js +180 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/live-schema-source.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/llm-classifier.d.ts +246 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/llm-classifier.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/llm-classifier.js +828 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/llm-classifier.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/llm-ranker.d.ts +63 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/llm-ranker.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/llm-ranker.js +210 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/llm-ranker.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/neo4j.d.ts +5 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/neo4j.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/neo4j.js +40 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/neo4j.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/schema-loader.d.ts +113 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/schema-loader.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/schema-loader.js +455 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/schema-loader.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/schema-validator.d.ts +83 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/schema-validator.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/schema-validator.js +209 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/schema-validator.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/uuid.d.ts +3 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/uuid.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/uuid.js +12 -0
- package/payload/platform/plugins/memory/mcp/dist/lib/uuid.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-derive-insights.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-derive-insights.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-derive-insights.test.js +97 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-derive-insights.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-enrich-rejection.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-enrich-rejection.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-enrich-rejection.test.js +184 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-enrich-rejection.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-normalisers-source-agnosticism.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-normalisers-source-agnosticism.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-normalisers-source-agnosticism.test.js +73 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-normalisers-source-agnosticism.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-normalisers-whatsapp-text.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-normalisers-whatsapp-text.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-normalisers-whatsapp-text.test.js +109 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-normalisers-whatsapp-text.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/memory-archive-write.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/memory-archive-write.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/memory-archive-write.test.js +84 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/memory-archive-write.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/memory-ingest.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/memory-ingest.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/memory-ingest.test.js +106 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/memory-ingest.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/profile-update-not-applicable.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/profile-update-not-applicable.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/profile-update-not-applicable.test.js +87 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/profile-update-not-applicable.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/profile-update-personfields-open.test.d.ts +2 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/profile-update-personfields-open.test.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/profile-update-personfields-open.test.js +148 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/profile-update-personfields-open.test.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-derive-insights.d.ts +89 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-derive-insights.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-derive-insights.js +542 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-derive-insights.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-enrich-rejection.d.ts +41 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-enrich-rejection.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-enrich-rejection.js +116 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-enrich-rejection.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-memory-expunge.d.ts +8 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-memory-expunge.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-memory-expunge.js +7 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/conversation-memory-expunge.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-add.d.ts +7 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-add.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-add.js +28 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-add.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-list.d.ts +7 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-list.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-list.js +7 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-list.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-remove.d.ts +7 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-remove.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-remove.js +27 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/graph-prune-denylist-remove.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-archive-write.d.ts +54 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-archive-write.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-archive-write.js +231 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-archive-write.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-classify.d.ts +34 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-classify.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-classify.js +58 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-classify.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-delete.d.ts +57 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-delete.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-delete.js +106 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-delete.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-edit-attachment.d.ts +16 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-edit-attachment.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-edit-attachment.js +91 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-edit-attachment.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-empty-trash.d.ts +22 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-empty-trash.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-empty-trash.js +36 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-empty-trash.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-find-candidates.d.ts +58 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-find-candidates.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-find-candidates.js +125 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-find-candidates.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest-extract.d.ts +28 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest-extract.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest-extract.js +93 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest-extract.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest-web.d.ts +20 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest-web.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest-web.js +87 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest-web.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest.d.ts +129 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest.js +827 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-ingest.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-list-attachments.d.ts +19 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-list-attachments.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-list-attachments.js +125 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-list-attachments.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-rank.d.ts +61 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-rank.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-rank.js +102 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-rank.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-read-attachment.d.ts +12 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-read-attachment.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-read-attachment.js +100 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-read-attachment.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-reindex.d.ts +9 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-reindex.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-reindex.js +84 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-reindex.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-rename-attachment.d.ts +13 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-rename-attachment.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-rename-attachment.js +63 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-rename-attachment.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-restore.d.ts +24 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-restore.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-restore.js +40 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-restore.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-search.d.ts +5 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-search.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-search.js +42 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-search.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-update.d.ts +13 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-update.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-update.js +77 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-update.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-write.d.ts +47 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-write.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-write.js +173 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/memory-write.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-delete.d.ts +24 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-delete.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-delete.js +31 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-delete.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-read.d.ts +44 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-read.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-read.js +322 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-read.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-update.d.ts +65 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-update.d.ts.map +1 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-update.js +369 -0
- package/payload/platform/plugins/memory/mcp/dist/tools/profile-update.js.map +1 -0
- package/payload/platform/plugins/memory/mcp/package.json +24 -0
- package/payload/platform/plugins/memory/mcp/scripts/boot-smoke.sh +69 -0
- package/payload/platform/plugins/memory/mcp/scripts/graph/accept.sh +217 -0
- package/payload/platform/plugins/memory/mcp/scripts/graph/fixture.cypher +59 -0
- package/payload/platform/plugins/memory/mcp/vitest.config.ts +15 -0
- package/payload/platform/plugins/memory/references/graph-primitives.md +342 -0
- package/payload/platform/plugins/memory/references/schema-base.md +234 -0
- package/payload/platform/plugins/memory/references/schema-creator.md +35 -0
- package/payload/platform/plugins/memory/references/schema-estate-agent.md +35 -0
- package/payload/platform/plugins/memory/references/schema-food-beverage.md +32 -0
- package/payload/platform/plugins/memory/references/schema-hospitality.md +31 -0
- package/payload/platform/plugins/memory/references/schema-logistics.md +30 -0
- package/payload/platform/plugins/memory/references/schema-professional-services.md +33 -0
- package/payload/platform/plugins/memory/references/schema-retail.md +33 -0
- package/payload/platform/plugins/memory/references/schema-trades.md +36 -0
- package/payload/platform/plugins/memory/skills/conversation-archive/SKILL.md +202 -0
- package/payload/platform/plugins/memory/skills/conversation-archive-enrich/SKILL.md +159 -0
- package/payload/platform/plugins/memory/skills/conversational-memory/SKILL.md +108 -0
- package/payload/platform/plugins/memory/skills/document-ingest/SKILL.md +267 -0
- package/payload/platform/plugins/outlook/PLUGIN.md +48 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/graph-client.test.d.ts +2 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/graph-client.test.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/graph-client.test.js +94 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/graph-client.test.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/log.test.d.ts +2 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/log.test.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/log.test.js +31 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/log.test.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/pkce-flow.test.d.ts +2 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/pkce-flow.test.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/pkce-flow.test.js +213 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/pkce-flow.test.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/token-store.test.d.ts +2 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/token-store.test.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/token-store.test.js +130 -0
- package/payload/platform/plugins/outlook/mcp/dist/__tests__/token-store.test.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/auth/pkce-flow.d.ts +65 -0
- package/payload/platform/plugins/outlook/mcp/dist/auth/pkce-flow.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/auth/pkce-flow.js +261 -0
- package/payload/platform/plugins/outlook/mcp/dist/auth/pkce-flow.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/auth/token-store.d.ts +61 -0
- package/payload/platform/plugins/outlook/mcp/dist/auth/token-store.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/auth/token-store.js +170 -0
- package/payload/platform/plugins/outlook/mcp/dist/auth/token-store.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/index.d.ts +18 -0
- package/payload/platform/plugins/outlook/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/index.js +152 -0
- package/payload/platform/plugins/outlook/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/lib/graph-client.d.ts +60 -0
- package/payload/platform/plugins/outlook/mcp/dist/lib/graph-client.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/lib/graph-client.js +189 -0
- package/payload/platform/plugins/outlook/mcp/dist/lib/graph-client.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/lib/log.d.ts +23 -0
- package/payload/platform/plugins/outlook/mcp/dist/lib/log.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/lib/log.js +53 -0
- package/payload/platform/plugins/outlook/mcp/dist/lib/log.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/account-register.d.ts +26 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/account-register.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/account-register.js +50 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/account-register.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/calendar-event.d.ts +12 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/calendar-event.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/calendar-event.js +32 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/calendar-event.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/calendar-list.d.ts +59 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/calendar-list.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/calendar-list.js +54 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/calendar-list.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/contacts-list.d.ts +14 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/contacts-list.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/contacts-list.js +45 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/contacts-list.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mail-list.d.ts +15 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mail-list.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mail-list.js +48 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mail-list.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mail-search.d.ts +8 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mail-search.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mail-search.js +49 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mail-search.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mailbox-info.d.ts +19 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mailbox-info.d.ts.map +1 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mailbox-info.js +58 -0
- package/payload/platform/plugins/outlook/mcp/dist/tools/mailbox-info.js.map +1 -0
- package/payload/platform/plugins/outlook/mcp/package.json +20 -0
- package/payload/platform/plugins/outlook/mcp/scripts/verify-doc-impl.sh +109 -0
- package/payload/platform/plugins/outlook/references/auth.md +118 -0
- package/payload/platform/plugins/outlook/references/graph-surfaces.md +114 -0
- package/payload/platform/plugins/outlook/skills/outlook/SKILL.md +65 -0
- package/payload/platform/plugins/projects/PLUGIN.md +90 -0
- package/payload/platform/plugins/projects/references/investigation.md +63 -0
- package/payload/platform/plugins/projects/references/retrospective.md +71 -0
- package/payload/platform/plugins/projects/references/review.md +51 -0
- package/payload/platform/plugins/projects/references/sprint.md +168 -0
- package/payload/platform/plugins/replicate/PLUGIN.md +23 -0
- package/payload/platform/plugins/replicate/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/replicate/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/replicate/mcp/dist/index.js +106 -0
- package/payload/platform/plugins/replicate/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/replicate/mcp/dist/lib/replicate-key.d.ts +15 -0
- package/payload/platform/plugins/replicate/mcp/dist/lib/replicate-key.d.ts.map +1 -0
- package/payload/platform/plugins/replicate/mcp/dist/lib/replicate-key.js +73 -0
- package/payload/platform/plugins/replicate/mcp/dist/lib/replicate-key.js.map +1 -0
- package/payload/platform/plugins/replicate/mcp/dist/tools/image-generate.d.ts +14 -0
- package/payload/platform/plugins/replicate/mcp/dist/tools/image-generate.d.ts.map +1 -0
- package/payload/platform/plugins/replicate/mcp/dist/tools/image-generate.js +191 -0
- package/payload/platform/plugins/replicate/mcp/dist/tools/image-generate.js.map +1 -0
- package/payload/platform/plugins/replicate/mcp/package.json +21 -0
- package/payload/platform/plugins/sales/PLUGIN.md +106 -0
- package/payload/platform/plugins/sales/references/close-tracking.md +69 -0
- package/payload/platform/plugins/sales/references/comparisons.md +99 -0
- package/payload/platform/plugins/sales/references/competitive-positioning.md +51 -0
- package/payload/platform/plugins/sales/references/faq.md +77 -0
- package/payload/platform/plugins/sales/references/objection-handling.md +157 -0
- package/payload/platform/plugins/sales/references/pricing.md +101 -0
- package/payload/platform/plugins/scheduling/PLUGIN.md +103 -0
- package/payload/platform/plugins/scheduling/mcp/dist/__tests__/time-resolve-description.test.d.ts +2 -0
- package/payload/platform/plugins/scheduling/mcp/dist/__tests__/time-resolve-description.test.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/__tests__/time-resolve-description.test.js +16 -0
- package/payload/platform/plugins/scheduling/mcp/dist/__tests__/time-resolve-description.test.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/scheduling/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/index.js +315 -0
- package/payload/platform/plugins/scheduling/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/__tests__/getUserTimezone.test.d.ts +2 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/__tests__/getUserTimezone.test.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/__tests__/getUserTimezone.test.js +119 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/__tests__/getUserTimezone.test.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/embedding.d.ts +2 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/embedding.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/embedding.js +19 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/embedding.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/ics.d.ts +47 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/ics.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/ics.js +362 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/ics.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/neo4j.d.ts +30 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/neo4j.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/neo4j.js +89 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/neo4j.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/time-format.d.ts +48 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/time-format.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/time-format.js +140 -0
- package/payload/platform/plugins/scheduling/mcp/dist/lib/time-format.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/scripts/check-due-events.d.ts +20 -0
- package/payload/platform/plugins/scheduling/mcp/dist/scripts/check-due-events.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/scripts/check-due-events.js +568 -0
- package/payload/platform/plugins/scheduling/mcp/dist/scripts/check-due-events.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-cancel.d.ts +7 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-cancel.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-cancel.js +23 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-cancel.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-event.d.ts +25 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-event.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-event.js +121 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-event.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-export-ics.d.ts +9 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-export-ics.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-export-ics.js +76 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-export-ics.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-get.d.ts +25 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-get.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-get.js +53 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-get.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-import-ics.d.ts +8 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-import-ics.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-import-ics.js +48 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-import-ics.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-list.d.ts +20 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-list.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-list.js +76 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-list.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-update.d.ts +18 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-update.d.ts.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-update.js +167 -0
- package/payload/platform/plugins/scheduling/mcp/dist/tools/schedule-update.js.map +1 -0
- package/payload/platform/plugins/scheduling/mcp/package.json +23 -0
- package/payload/platform/plugins/scheduling/mcp/vitest.config.ts +9 -0
- package/payload/platform/plugins/tasks/.claude-plugin/plugin.json +17 -0
- package/payload/platform/plugins/tasks/.mcp.json +13 -0
- package/payload/platform/plugins/tasks/PLUGIN.md +81 -0
- package/payload/platform/plugins/tasks/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/tasks/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/index.js +503 -0
- package/payload/platform/plugins/tasks/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/lib/embeddings.d.ts +7 -0
- package/payload/platform/plugins/tasks/mcp/dist/lib/embeddings.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/lib/embeddings.js +24 -0
- package/payload/platform/plugins/tasks/mcp/dist/lib/embeddings.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/lib/neo4j.d.ts +5 -0
- package/payload/platform/plugins/tasks/mcp/dist/lib/neo4j.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/lib/neo4j.js +40 -0
- package/payload/platform/plugins/tasks/mcp/dist/lib/neo4j.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-complete.d.ts +17 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-complete.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-complete.js +76 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-complete.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-create.d.ts +29 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-create.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-create.js +235 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-create.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-get.d.ts +40 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-get.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-get.js +125 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-get.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-list.d.ts +26 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-list.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-list.js +81 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-list.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-update.d.ts +19 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-update.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-update.js +102 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/project-update.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/session-list.d.ts +20 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/session-list.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/session-list.js +37 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/session-list.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/session-name.d.ts +12 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/session-name.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/session-name.js +28 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/session-name.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-complete.d.ts +16 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-complete.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-complete.js +33 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-complete.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-create.d.ts +63 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-create.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-create.js +141 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-create.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-get.d.ts +19 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-get.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-get.js +51 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-get.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-list.d.ts +18 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-list.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-list.js +66 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-list.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-ready.d.ts +21 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-ready.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-ready.js +54 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-ready.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-relate.d.ts +12 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-relate.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-relate.js +59 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-relate.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-update.d.ts +32 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-update.d.ts.map +1 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-update.js +112 -0
- package/payload/platform/plugins/tasks/mcp/dist/tools/task-update.js.map +1 -0
- package/payload/platform/plugins/tasks/mcp/package.json +20 -0
- package/payload/platform/plugins/telegram/PLUGIN.md +35 -0
- package/payload/platform/plugins/telegram/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/telegram/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/telegram/mcp/dist/index.js +198 -0
- package/payload/platform/plugins/telegram/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/telegram/mcp/dist/lib/telegram.d.ts +41 -0
- package/payload/platform/plugins/telegram/mcp/dist/lib/telegram.d.ts.map +1 -0
- package/payload/platform/plugins/telegram/mcp/dist/lib/telegram.js +70 -0
- package/payload/platform/plugins/telegram/mcp/dist/lib/telegram.js.map +1 -0
- package/payload/platform/plugins/telegram/mcp/dist/tools/message-history.d.ts +16 -0
- package/payload/platform/plugins/telegram/mcp/dist/tools/message-history.d.ts.map +1 -0
- package/payload/platform/plugins/telegram/mcp/dist/tools/message-history.js +68 -0
- package/payload/platform/plugins/telegram/mcp/dist/tools/message-history.js.map +1 -0
- package/payload/platform/plugins/telegram/mcp/dist/tools/message.d.ts +20 -0
- package/payload/platform/plugins/telegram/mcp/dist/tools/message.d.ts.map +1 -0
- package/payload/platform/plugins/telegram/mcp/dist/tools/message.js +34 -0
- package/payload/platform/plugins/telegram/mcp/dist/tools/message.js.map +1 -0
- package/payload/platform/plugins/telegram/mcp/package.json +19 -0
- package/payload/platform/plugins/telegram/references/setup-guide.md +50 -0
- package/payload/platform/plugins/waitlist/PLUGIN.md +63 -0
- package/payload/platform/plugins/waitlist/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/waitlist/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/index.js +328 -0
- package/payload/platform/plugins/waitlist/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/lib/embedding.d.ts +3 -0
- package/payload/platform/plugins/waitlist/mcp/dist/lib/embedding.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/lib/embedding.js +48 -0
- package/payload/platform/plugins/waitlist/mcp/dist/lib/embedding.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/lib/neo4j.d.ts +5 -0
- package/payload/platform/plugins/waitlist/mcp/dist/lib/neo4j.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/lib/neo4j.js +40 -0
- package/payload/platform/plugins/waitlist/mcp/dist/lib/neo4j.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/__tests__/waitlist-persist.test.d.ts +2 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/__tests__/waitlist-persist.test.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/__tests__/waitlist-persist.test.js +70 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/__tests__/waitlist-persist.test.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-heal.d.ts +33 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-heal.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-heal.js +124 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-heal.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-list.d.ts +23 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-list.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-list.js +58 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-list.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-persist.d.ts +83 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-persist.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-persist.js +433 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-persist.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-review.d.ts +19 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-review.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-review.js +81 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-review.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-scan.d.ts +28 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-scan.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-scan.js +50 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-scan.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-setup.d.ts +33 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-setup.d.ts.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-setup.js +335 -0
- package/payload/platform/plugins/waitlist/mcp/dist/tools/waitlist-setup.js.map +1 -0
- package/payload/platform/plugins/waitlist/mcp/package.json +23 -0
- package/payload/platform/plugins/waitlist/mcp/vitest.config.ts +9 -0
- package/payload/platform/plugins/whatsapp/PLUGIN.md +71 -0
- package/payload/platform/plugins/whatsapp/mcp/dist/call-api.d.ts +14 -0
- package/payload/platform/plugins/whatsapp/mcp/dist/call-api.d.ts.map +1 -0
- package/payload/platform/plugins/whatsapp/mcp/dist/call-api.js +42 -0
- package/payload/platform/plugins/whatsapp/mcp/dist/call-api.js.map +1 -0
- package/payload/platform/plugins/whatsapp/mcp/dist/index.d.ts +8 -0
- package/payload/platform/plugins/whatsapp/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/whatsapp/mcp/dist/index.js +469 -0
- package/payload/platform/plugins/whatsapp/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/whatsapp/mcp/package.json +19 -0
- package/payload/platform/plugins/whatsapp/references/channels-whatsapp.md +257 -0
- package/payload/platform/plugins/whatsapp/skills/connect-whatsapp/SKILL.md +82 -0
- package/payload/platform/plugins/whatsapp/skills/manage-whatsapp-config/SKILL.md +99 -0
- package/payload/platform/plugins/workflows/.claude-plugin/plugin.json +16 -0
- package/payload/platform/plugins/workflows/.mcp.json +12 -0
- package/payload/platform/plugins/workflows/PLUGIN.md +297 -0
- package/payload/platform/plugins/workflows/mcp/dist/index.d.ts +2 -0
- package/payload/platform/plugins/workflows/mcp/dist/index.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/index.js +536 -0
- package/payload/platform/plugins/workflows/mcp/dist/index.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/active-runs.d.ts +38 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/active-runs.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/active-runs.js +83 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/active-runs.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/embeddings.d.ts +2 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/embeddings.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/embeddings.js +19 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/embeddings.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/llm-call.d.ts +151 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/llm-call.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/llm-call.js +299 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/llm-call.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/neo4j.d.ts +5 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/neo4j.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/neo4j.js +40 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/neo4j.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/step-resolver.d.ts +153 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/step-resolver.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/step-resolver.js +273 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/step-resolver.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/validate-capabilities.d.ts +32 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/validate-capabilities.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/validate-capabilities.js +97 -0
- package/payload/platform/plugins/workflows/mcp/dist/lib/validate-capabilities.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-create.d.ts +48 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-create.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-create.js +166 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-create.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-delete.d.ts +28 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-delete.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-delete.js +57 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-delete.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-execute.d.ts +64 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-execute.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-execute.js +605 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-execute.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-get.d.ts +29 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-get.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-get.js +55 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-get.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-list.d.ts +16 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-list.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-list.js +44 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-list.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-runs.d.ts +28 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-runs.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-runs.js +71 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-runs.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-update.d.ts +11 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-update.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-update.js +198 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-update.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-validate.d.ts +13 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-validate.d.ts.map +1 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-validate.js +71 -0
- package/payload/platform/plugins/workflows/mcp/dist/tools/workflow-validate.js.map +1 -0
- package/payload/platform/plugins/workflows/mcp/package.json +20 -0
- package/payload/platform/plugins/workflows/mcp/test-runner.mjs +710 -0
- package/payload/platform/plugins/workflows/mcp/test-workflows.sh +77 -0
- package/payload/platform/plugins/workflows/skills/workflow-manager/SKILL.md +88 -0
- package/payload/platform/scripts/__tests__/admin-persist-audit.test.ts +182 -0
- package/payload/platform/scripts/__tests__/first-token-creates-stream-log.test.sh +37 -0
- package/payload/platform/scripts/__tests__/logs-read-prefix.sh +237 -0
- package/payload/platform/scripts/admin-conversation-recover.mjs +386 -0
- package/payload/platform/scripts/admin-persist-audit.ts +217 -0
- package/payload/platform/scripts/check-no-conversation-id-leaks.mjs +165 -0
- package/payload/platform/scripts/check-no-task-id-leaks.mjs +110 -0
- package/payload/platform/scripts/check-sdk-oauth.mjs +185 -0
- package/payload/platform/scripts/check-skill-load-coverage.mjs +100 -0
- package/payload/platform/scripts/component-knowledgedoc-backfill.ts +214 -0
- package/payload/platform/scripts/conversation-id-allowlist.txt +151 -0
- package/payload/platform/scripts/dedupe-userprofile-ghosts.sh +388 -0
- package/payload/platform/scripts/generate-entitlement-fixture.mjs +152 -0
- package/payload/platform/scripts/installer-device-verify.sh +249 -0
- package/payload/platform/scripts/lib/resolve-account-dir.sh +186 -0
- package/payload/platform/scripts/log-adherence-check.sh +125 -0
- package/payload/platform/scripts/logs-read.sh +577 -0
- package/payload/platform/scripts/logs-read.test.sh +159 -0
- package/payload/platform/scripts/migrate-import.sh +437 -0
- package/payload/platform/scripts/redact-install-logs.sh +87 -0
- package/payload/platform/scripts/resume-tunnel.sh +117 -0
- package/payload/platform/scripts/seed-neo4j.sh +590 -0
- package/payload/platform/scripts/taskmaster-export.sh +388 -0
- package/payload/platform/scripts/test-laptop-vnc-boot.sh +88 -0
- package/payload/platform/scripts/verify-skill-tool-surface.sh +255 -0
- package/payload/platform/scripts/vnc.sh +475 -0
- package/payload/platform/scripts/wifi-provision-server/server.js +743 -0
- package/payload/platform/scripts/wifi-provision.sh +492 -0
- package/payload/platform/services/claude-session-manager/dist/config.d.ts +12 -0
- package/payload/platform/services/claude-session-manager/dist/config.d.ts.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/config.js +27 -0
- package/payload/platform/services/claude-session-manager/dist/config.js.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/http-server.d.ts +10 -0
- package/payload/platform/services/claude-session-manager/dist/http-server.d.ts.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/http-server.js +186 -0
- package/payload/platform/services/claude-session-manager/dist/http-server.js.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/index.d.ts +2 -0
- package/payload/platform/services/claude-session-manager/dist/index.d.ts.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/index.js +64 -0
- package/payload/platform/services/claude-session-manager/dist/index.js.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/jsonl-path.d.ts +4 -0
- package/payload/platform/services/claude-session-manager/dist/jsonl-path.d.ts.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/jsonl-path.js +31 -0
- package/payload/platform/services/claude-session-manager/dist/jsonl-path.js.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/pty-spawner.d.ts +34 -0
- package/payload/platform/services/claude-session-manager/dist/pty-spawner.d.ts.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/pty-spawner.js +91 -0
- package/payload/platform/services/claude-session-manager/dist/pty-spawner.js.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/session-store.d.ts +23 -0
- package/payload/platform/services/claude-session-manager/dist/session-store.d.ts.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/session-store.js +31 -0
- package/payload/platform/services/claude-session-manager/dist/session-store.js.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/types.d.ts +33 -0
- package/payload/platform/services/claude-session-manager/dist/types.d.ts.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/types.js +2 -0
- package/payload/platform/services/claude-session-manager/dist/types.js.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/url-capture.d.ts +12 -0
- package/payload/platform/services/claude-session-manager/dist/url-capture.d.ts.map +1 -0
- package/payload/platform/services/claude-session-manager/dist/url-capture.js +68 -0
- package/payload/platform/services/claude-session-manager/dist/url-capture.js.map +1 -0
- package/payload/platform/services/claude-session-manager/package.json +22 -0
- package/payload/platform/templates/account.json +12 -0
- package/payload/platform/templates/agents/admin/AGENTS.md +12 -0
- package/payload/platform/templates/agents/admin/IDENTITY.md +320 -0
- package/payload/platform/templates/agents/admin/LEARNINGS.md +3 -0
- package/payload/platform/templates/agents/admin/SOUL.md +23 -0
- package/payload/platform/templates/agents/public/IDENTITY.md +56 -0
- package/payload/platform/templates/agents/public/SOUL.md +19 -0
- package/payload/platform/templates/agents/public/config.json +9 -0
- package/payload/platform/templates/specialists/.claude-plugin/plugin.json +4 -0
- package/payload/platform/templates/specialists/agents/content-producer.md +104 -0
- package/payload/platform/templates/specialists/agents/database-operator.md +199 -0
- package/payload/platform/templates/specialists/agents/personal-assistant.md +209 -0
- package/payload/platform/templates/specialists/agents/project-manager.md +132 -0
- package/payload/platform/templates/specialists/agents/research-assistant.md +115 -0
- package/payload/platform/templates/systemd/edge.service.template +38 -0
- package/payload/platform/tsconfig.base.json +18 -0
- package/payload/premium-plugins/real-agency/BUNDLE.md +44 -0
- package/payload/premium-plugins/real-agency/agents/buyer-enquiry/IDENTITY.md +13 -0
- package/payload/premium-plugins/real-agency/agents/buyer-enquiry/SOUL.md +9 -0
- package/payload/premium-plugins/real-agency/agents/buyer-enquiry/template.json +9 -0
- package/payload/premium-plugins/real-agency/agents/compliance.md +303 -0
- package/payload/premium-plugins/real-agency/agents/negotiator.md +145 -0
- package/payload/premium-plugins/real-agency/agents/valuer.md +140 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/PLUGIN.md +36 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/commands/make-brochure.md +11 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/a4-print-documents/SKILL.md +478 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/brand-design/SKILL.md +192 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/make-brochure/SKILL.md +354 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/make-brochure/references/seller-brief-template.md +115 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/SKILL.md +119 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/build.md +270 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/copy.md +211 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/images.md +166 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/page-landing.md +376 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/page.html +1288 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/placeholders.md +250 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/registers.md +47 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/seller-brief.md +56 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/structure.md +249 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-brochure/references/template.html +2370 -0
- package/payload/premium-plugins/real-agency/plugins/brochures/skills/property-extract/SKILL.md +372 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/PLUGIN.md +35 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-feedback/SKILL.md +109 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-management/SKILL.md +42 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-management/references/buyer-qualification-questions.md +16 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-management/references/buyer-qualification.md +59 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-management/references/buyer-scripts.md +63 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-management/references/buyer-working-scripts.md +54 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-management/references/feedback-collection.md +42 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-management/references/offer-capture.md +38 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-management/references/viewing-booking.md +32 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-management/references/viewing-management.md +52 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-seller-guides/SKILL.md +407 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-seller-guides/references/care-fees-guide.md +68 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-seller-guides/references/divorce-sales-guide.md +61 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-seller-guides/references/downsizing-guide.md +45 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-seller-guides/references/first-time-buyers.md +92 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-seller-guides/references/first-time-sellers.md +78 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-seller-guides/references/probate-guide.md +53 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/buyer-seller-guides/references/upsizing-guide.md +41 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/property-enquiry/SKILL.md +126 -0
- package/payload/premium-plugins/real-agency/plugins/buyers/skills/viewing-management/SKILL.md +111 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/PLUGIN.md +34 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/SKILL.md +133 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/buy-back-your-time.md +37 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/firewave-gost-scorecards.md +14 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/keller-org-model.md +17 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/lencioni-team-models.md +22 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/listing-management-system.md +11 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/net-figure-form.md +11 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/serhant-bizinbox-notes.md +13 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/team-roles-commission.md +14 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/va-2026-ops.md +43 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-growth/references/wingman-structure.md +13 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-operations/SKILL.md +32 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-operations/references/crm-systems.md +57 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-operations/references/hiring-guide.md +59 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-operations/references/impact-framework.md +47 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-operations/references/minutes-equal-money.md +55 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/business-operations/references/team-management.md +48 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/exp-partnership/SKILL.md +52 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/exp-partnership/references/12-reasons.md +39 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/exp-partnership/references/95-5-system.md +66 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/exp-partnership/references/agent-attraction-scripts.md +90 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/exp-partnership/references/business-partnership.md +92 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/exp-partnership/references/exp-model-overview.md +66 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/exp-partnership/references/model-comparison.md +66 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/exp-partnership/references/revenue-share-explained.md +57 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/SKILL.md +117 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/attraction-agent-notes.md +31 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/attraction-agent.md +58 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/authenticity-boundaries.md +28 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/become-a-brand-leader-notes.md +19 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/blast-formula.md +42 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/brand-leader.md +48 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/brand-strategy-system.md +59 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/content-engine.md +49 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/firewave-blast-and-blogging.md +23 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/gary-v-content.md +52 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/gary-v-principles.md +20 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/oversubscribed-positioning.md +18 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/platforms.md +41 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/priestley-oversubscribed.md +54 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/storeys-style-examples.md +25 -0
- package/payload/premium-plugins/real-agency/plugins/estate-business/skills/personal-branding/references/visual-identity.md +27 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/PLUGIN.md +55 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/agent-performance/SKILL.md +371 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/agent-performance/references/atomic-habits.md +52 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/agent-performance/references/daily-routine-scorecard.md +104 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/agent-performance/references/hp6-model.md +63 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/agent-performance/references/twelve-week-year.md +71 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/bespoke-coaching/SKILL.md +36 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/bespoke-coaching/references/coaching-boundaries.md +56 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/bespoke-coaching/references/feedback-framework.md +61 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/bespoke-coaching/references/performance-framework.md +109 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/coaching-toolkit/SKILL.md +421 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/coaching-toolkit/references/coaching-exercises.md +86 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/coaching-toolkit/references/goal-setting.md +78 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/coaching-toolkit/references/one-to-one-framework.md +92 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/coaching-toolkit/references/soi-workbook.md +103 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/serhant-training/SKILL.md +410 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/serhant-training/references/agent-training-guide.md +70 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/serhant-training/references/business-in-a-box.md +72 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/serhant-training/references/buyers-guide.md +53 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/serhant-training/references/codo-method.md +72 -0
- package/payload/premium-plugins/real-agency/plugins/estate-coaching/skills/serhant-training/references/website-planning-guide.md +79 -0
- package/payload/premium-plugins/real-agency/plugins/estate-onboarding/PLUGIN.md +31 -0
- package/payload/premium-plugins/real-agency/plugins/estate-onboarding/skills/bootstrap/SKILL.md +26 -0
- package/payload/premium-plugins/real-agency/plugins/estate-onboarding/skills/bootstrap/references/onboarding-flow.md +63 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/PLUGIN.md +34 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/negotiation/SKILL.md +35 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/negotiation/references/deal-saving.md +47 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/negotiation/references/negotiation-deep-guide.md +64 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/negotiation/references/negotiation-prep-principles.md +29 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/negotiation/references/negotiation-techniques.md +42 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/negotiation/references/offer-presentation.md +43 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-closer/SKILL.md +24 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-closer/references/serhant-emotion-stages.md +36 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-discovery/SKILL.md +30 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-discovery/references/chris-voss-discovery.md +88 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-discovery/references/firewave-gost-journey.md +68 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-discovery/references/phil-jones-openers.md +78 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-discovery/references/pre-listing-checklist.md +77 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-discovery/references/serhant-improv.md +22 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-discovery/references/tom-ferry-discovery.md +103 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-discovery/references/vendor-motivation-competitor.md +52 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-negotiation/SKILL.md +29 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-negotiation/references/chris-voss-negotiation.md +70 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-negotiation/references/phil-jones-price-words.md +40 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-negotiation/references/serhant-negotiation-plus.md +55 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-negotiation/references/tom-panos-commission-pricing.md +57 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-negotiation/references/tony-morris-questioning.md +54 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-progression/SKILL.md +27 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-progression/references/conveyancing-guide.md +54 -0
- package/payload/premium-plugins/real-agency/plugins/estate-sales/skills/sales-progression/references/transaction-tracking.md +66 -0
- package/payload/premium-plugins/real-agency/plugins/estate-teaching/PLUGIN.md +31 -0
- package/payload/premium-plugins/real-agency/plugins/estate-teaching/skills/content-directory/SKILL.md +39 -0
- package/payload/premium-plugins/real-agency/plugins/estate-teaching/skills/content-directory/references/module-delivery.md +65 -0
- package/payload/premium-plugins/real-agency/plugins/estate-teaching/skills/content-directory/references/progress-tracking.md +47 -0
- package/payload/premium-plugins/real-agency/plugins/leads/PLUGIN.md +32 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/SKILL.md +137 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/buyer-search-letter.md +28 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/buyer-search-letters.md +37 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/database-reactivation.md +30 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/email-nurture-sequences.md +45 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/facebook-referrals.md +30 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/firewave-email-nurture-sequences.md +41 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/keller-33-touch.md +34 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/neighbour-letters.md +31 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/neighbour-notification-letter.md +20 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/ofi-follow-up-dialogue.md +22 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/ofi-follow-up.md +26 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/serhant-three-fs-plus.md +21 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/sharran-10x10x10.md +18 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/sms-templates.md +40 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/sphere-of-influence-notes.md +34 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/sphere-of-influence.md +60 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/lead-nurturing/references/tom-panos-sms-templates.md +59 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/prospecting/SKILL.md +33 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/prospecting/references/database-matching.md +30 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/prospecting/references/database-value.md +53 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/prospecting/references/prospecting-dialogues.md +24 -0
- package/payload/premium-plugins/real-agency/plugins/leads/skills/prospecting/references/reactivation.md +34 -0
- package/payload/premium-plugins/real-agency/plugins/listings/PLUGIN.md +33 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/home-preparation/SKILL.md +28 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/home-preparation/references/kerb-appeal.md +38 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/home-preparation/references/photo-day.md +59 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/home-preparation/references/situational-tips.md +50 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/home-preparation/references/staging-guide.md +52 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/listing-presentation/SKILL.md +286 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/listing-presentation/references/booking-script.md +51 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/listing-presentation/references/objection-scripts.md +193 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/listing-presentation/references/penhaul-presentation.md +123 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/listing-presentation/references/pre-listing-kit.md +139 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/listing-presentation/references/set-to-sell.md +55 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/listing-presentation/references/sharran-frameworks.md +107 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/property-marketing/SKILL.md +337 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/property-marketing/references/auction-report-template.md +41 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/property-marketing/references/coming-soon-campaign.md +43 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/property-marketing/references/direct-mail-templates.md +121 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/property-marketing/references/eoi-form-template.md +62 -0
- package/payload/premium-plugins/real-agency/plugins/listings/skills/property-marketing/references/monthly-scorecard.md +63 -0
- package/payload/premium-plugins/real-agency/plugins/loop/PLUGIN.md +73 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/index.d.ts +2 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/index.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/index.js +293 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/index.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/crypto.d.ts +10 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/crypto.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/crypto.js +88 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/crypto.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/loop-api.d.ts +82 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/loop-api.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/loop-api.js +427 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/loop-api.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/neo4j.d.ts +5 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/neo4j.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/neo4j.js +40 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/lib/neo4j.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/customer-preferences.d.ts +10 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/customer-preferences.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/customer-preferences.js +24 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/customer-preferences.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/feedback.d.ts +16 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/feedback.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/feedback.js +35 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/feedback.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-deregister.d.ts +5 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-deregister.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-deregister.js +19 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-deregister.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-list.d.ts +4 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-list.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-list.js +14 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-list.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-register.d.ts +9 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-register.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-register.js +60 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/key-register.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-enquiry.d.ts +13 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-enquiry.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-enquiry.js +41 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-enquiry.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match-batch.d.ts +9 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match-batch.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match-batch.js +16 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match-batch.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match-request.d.ts +15 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match-request.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match-request.js +11 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match-request.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match.d.ts +10 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match.js +39 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/marketing-match.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/people-detail.d.ts +9 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/people-detail.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/people-detail.js +125 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/people-detail.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/people-search.d.ts +18 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/people-search.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/people-search.js +87 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/people-search.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-detail.d.ts +10 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-detail.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-detail.js +82 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-detail.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-listed.d.ts +12 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-listed.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-listed.js +32 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-listed.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-request.d.ts +15 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-request.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-request.js +11 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-request.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-search.d.ts +16 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-search.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-search.js +41 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/property-search.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/supplier.d.ts +13 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/supplier.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/supplier.js +49 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/supplier.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/team-availability.d.ts +7 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/team-availability.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/team-availability.js +19 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/team-availability.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/team-info.d.ts +5 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/team-info.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/team-info.js +32 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/team-info.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-create.d.ts +14 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-create.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-create.js +11 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-create.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-detail.d.ts +9 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-detail.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-detail.js +85 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-detail.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-search.d.ts +13 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-search.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-search.js +44 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-search.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-update.d.ts +14 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-update.d.ts.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-update.js +18 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/dist/tools/viewing-update.js.map +1 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/package-lock.json +2549 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/package.json +21 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/__tests__/loop-swagger.snapshot.json +26467 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/__tests__/swagger-write-coverage.test.ts +153 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/index.ts +444 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/lib/crypto.ts +105 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/lib/loop-api.ts +604 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/lib/neo4j.ts +51 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/customer-preferences.ts +66 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/feedback.ts +86 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/key-deregister.ts +27 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/key-list.ts +19 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/key-register.ts +95 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/marketing-enquiry.ts +113 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/marketing-match-batch.ts +53 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/marketing-match-request.ts +42 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/marketing-match.ts +84 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/people-detail.ts +245 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/people-search.ts +180 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/property-detail.ts +145 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/property-listed.ts +88 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/property-request.ts +42 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/property-search.ts +92 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/supplier.ts +129 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/team-availability.ts +52 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/team-info.ts +95 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/viewing-create.ts +41 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/viewing-detail.ts +171 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/viewing-search.ts +92 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/src/tools/viewing-update.ts +53 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/tsconfig.json +20 -0
- package/payload/premium-plugins/real-agency/plugins/loop/mcp/vitest.config.ts +9 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/PLUGIN.md +34 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/SKILL.md +42 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/fee-protection-and-agenda.md +28 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/listing-scripts.md +44 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/negotiation-deep-guide.md +70 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/price-alignment-scripts.md +33 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/price-alignment.md +34 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/scenario-scripts.md +38 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/seller-engagement.md +51 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/valuation-booking.md +76 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/vendor-scripts.md +63 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-communication/references/vendor-updates.md +41 -0
- package/payload/premium-plugins/real-agency/plugins/vendors/skills/vendor-updates/SKILL.md +153 -0
- package/payload/premium-plugins/teaching/PLUGIN.md +57 -0
- package/payload/premium-plugins/teaching/skills/interactive-tutor/SKILL.md +59 -0
- package/payload/premium-plugins/teaching/skills/interactive-tutor/references/assessment.md +70 -0
- package/payload/premium-plugins/teaching/skills/interactive-tutor/references/classroom-conduct.md +43 -0
- package/payload/premium-plugins/teaching/skills/interactive-tutor/references/teaching-modes.md +83 -0
- package/payload/premium-plugins/teaching/skills/lesson-planner/SKILL.md +48 -0
- package/payload/premium-plugins/teaching/skills/lesson-planner/references/context-gathering.md +41 -0
- package/payload/premium-plugins/teaching/skills/lesson-planner/references/plan-structure.md +94 -0
- package/payload/premium-plugins/teaching/skills/study-pack-builder/SKILL.md +52 -0
- package/payload/premium-plugins/teaching/skills/study-pack-builder/references/disaggregation.md +49 -0
- package/payload/premium-plugins/teaching/skills/study-pack-builder/references/materials.md +116 -0
- package/payload/premium-plugins/writer-craft/PLUGIN.md +87 -0
- package/payload/premium-plugins/writer-craft/agents/writer-craft--manuscript-reviewer.md +92 -0
- package/payload/premium-plugins/writer-craft/skills/citation-style/SKILL.md +94 -0
- package/payload/premium-plugins/writer-craft/skills/citation-style/references/book-and-chapter-models.md +77 -0
- package/payload/premium-plugins/writer-craft/skills/citation-style/references/citation-rules.md +103 -0
- package/payload/premium-plugins/writer-craft/skills/citation-style/references/journal-article-models.md +74 -0
- package/payload/premium-plugins/writer-craft/skills/citation-style/references/other-source-models.md +146 -0
- package/payload/premium-plugins/writer-craft/skills/citation-style/references/reference-list-rules.md +70 -0
- package/payload/premium-plugins/writer-craft/skills/editorial-practice/SKILL.md +108 -0
- package/payload/premium-plugins/writer-craft/skills/editorial-practice/references/copyediting.md +73 -0
- package/payload/premium-plugins/writer-craft/skills/editorial-practice/references/developmental-editing.md +85 -0
- package/payload/premium-plugins/writer-craft/skills/editorial-practice/references/genre-specific-editing.md +78 -0
- package/payload/premium-plugins/writer-craft/skills/editorial-practice/references/line-editing.md +55 -0
- package/payload/premium-plugins/writer-craft/skills/editorial-practice/references/self-editing.md +89 -0
- package/payload/premium-plugins/writer-craft/skills/persuasive-storytelling/SKILL.md +114 -0
- package/payload/premium-plugins/writer-craft/skills/persuasive-storytelling/references/audience-analysis.md +73 -0
- package/payload/premium-plugins/writer-craft/skills/persuasive-storytelling/references/crafting-persuasive-story.md +76 -0
- package/payload/premium-plugins/writer-craft/skills/persuasive-storytelling/references/persuasion-case-studies.md +67 -0
- package/payload/premium-plugins/writer-craft/skills/persuasive-storytelling/references/transformation-framework.md +86 -0
- package/payload/premium-plugins/writer-craft/skills/point-of-view/SKILL.md +97 -0
- package/payload/premium-plugins/writer-craft/skills/point-of-view/references/indirect-narration.md +72 -0
- package/payload/premium-plugins/writer-craft/skills/point-of-view/references/pov-types-and-voice.md +91 -0
- package/payload/premium-plugins/writer-craft/skills/point-of-view/references/protagonist-filter.md +71 -0
- package/payload/premium-plugins/writer-craft/skills/point-of-view/references/tense-and-person.md +85 -0
- package/payload/premium-plugins/writer-craft/skills/prose-craft/SKILL.md +100 -0
- package/payload/premium-plugins/writer-craft/skills/prose-craft/references/punctuation-and-grammar.md +72 -0
- package/payload/premium-plugins/writer-craft/skills/prose-craft/references/repetition.md +71 -0
- package/payload/premium-plugins/writer-craft/skills/prose-craft/references/sound-and-rhythm.md +64 -0
- package/payload/premium-plugins/writer-craft/skills/prose-craft/references/word-economy.md +93 -0
- package/payload/premium-plugins/writer-craft/skills/reader-engagement/SKILL.md +100 -0
- package/payload/premium-plugins/writer-craft/skills/reader-engagement/references/cause-effect-setup-payoff.md +79 -0
- package/payload/premium-plugins/writer-craft/skills/reader-engagement/references/conflict-escalation.md +81 -0
- package/payload/premium-plugins/writer-craft/skills/reader-engagement/references/hooking-readers.md +67 -0
- package/payload/premium-plugins/writer-craft/skills/reader-engagement/references/neurochemistry-of-engagement.md +94 -0
- package/payload/premium-plugins/writer-craft/skills/review-manuscript/SKILL.md +111 -0
- package/payload/premium-plugins/writer-craft/skills/review-manuscript/references/review-manuscript-checklist.md +119 -0
- package/payload/premium-plugins/writer-craft/skills/review-prose/SKILL.md +99 -0
- package/payload/premium-plugins/writer-craft/skills/review-prose/references/prose-review-checklist.md +112 -0
- package/payload/premium-plugins/writer-craft/skills/review-scene/SKILL.md +99 -0
- package/payload/premium-plugins/writer-craft/skills/review-scene/references/scene-analysis-framework.md +95 -0
- package/payload/premium-plugins/writer-craft/skills/story-architecture/SKILL.md +106 -0
- package/payload/premium-plugins/writer-craft/skills/story-architecture/references/blueprinting-and-scene-cards.md +118 -0
- package/payload/premium-plugins/writer-craft/skills/story-architecture/references/inner-issue-and-protagonist-goal.md +66 -0
- package/payload/premium-plugins/writer-craft/skills/story-architecture/references/misbelief-desire-worldview.md +87 -0
- package/payload/premium-plugins/writer-craft/skills/story-architecture/references/origin-scenes-and-escalation.md +82 -0
- package/payload/premium-plugins/writer-craft/skills/story-blueprint/SKILL.md +133 -0
- package/payload/premium-plugins/writer-craft/skills/story-blueprint/references/blueprinting-exercises.md +118 -0
- package/payload/premium-plugins/writer-craft/skills/story-blueprint/references/blueprinting-process.md +128 -0
- package/payload/server/adminuser-self-heal-QAWOZ3JV.js +45 -0
- package/payload/server/chunk-5FM432JB.js +4148 -0
- package/payload/server/chunk-6S5JTXAN.js +1544 -0
- package/payload/server/chunk-JSBRDJBE.js +30 -0
- package/payload/server/chunk-RNW625CL.js +759 -0
- package/payload/server/cloudflare-task-tracker-VC7QVU5H.js +22 -0
- package/payload/server/maxy-edge.js +1021 -0
- package/payload/server/package.json +13 -0
- package/payload/server/public/assets/Checkbox-C6ZCsPvl.js +1 -0
- package/payload/server/public/assets/_baseFor-BHtDrjIo.js +1 -0
- package/payload/server/public/assets/admin-CWMpccrR.css +1 -0
- package/payload/server/public/assets/admin-DVGJmN-k.js +216 -0
- package/payload/server/public/assets/arc-DMDAZHAN.js +1 -0
- package/payload/server/public/assets/architecture-YZFGNWBL-COhEvUpo.js +1 -0
- package/payload/server/public/assets/architectureDiagram-Q4EWVU46-DwN6H0y2.js +36 -0
- package/payload/server/public/assets/array-DetWRiSa.js +1 -0
- package/payload/server/public/assets/blockDiagram-DXYQGD6D-TUk_F7H6.js +132 -0
- package/payload/server/public/assets/c4Diagram-AHTNJAMY-CTjGko0X.js +10 -0
- package/payload/server/public/assets/channel-Cv-65bLZ.js +1 -0
- package/payload/server/public/assets/chunk-2KRD3SAO-Di4bO8ir.js +1 -0
- package/payload/server/public/assets/chunk-336JU56O-DulT46bV.js +2 -0
- package/payload/server/public/assets/chunk-426QAEUC-BwKj8yqp.js +1 -0
- package/payload/server/public/assets/chunk-4BX2VUAB-DyEhFk-Z.js +1 -0
- package/payload/server/public/assets/chunk-4TB4RGXK-CewO8YaZ.js +206 -0
- package/payload/server/public/assets/chunk-55IACEB6-BRJOZLpU.js +1 -0
- package/payload/server/public/assets/chunk-5FUZZQ4R-B3IWYz-k.js +62 -0
- package/payload/server/public/assets/chunk-5PVQY5BW-DyiDEtXY.js +2 -0
- package/payload/server/public/assets/chunk-67CJDMHE-BG6-9r6c.js +1 -0
- package/payload/server/public/assets/chunk-7N4EOEYR-BvMbitX7.js +1 -0
- package/payload/server/public/assets/chunk-AA7GKIK3-CE8mGBD5.js +1 -0
- package/payload/server/public/assets/chunk-BSJP7CBP-DP7LTBll.js +1 -0
- package/payload/server/public/assets/chunk-CIAEETIT-VfnIdN-h.js +1 -0
- package/payload/server/public/assets/chunk-DD-I1_y5.js +1 -0
- package/payload/server/public/assets/chunk-EDXVE4YY-B3u7wU36.js +1 -0
- package/payload/server/public/assets/chunk-ENJZ2VHE-BesS5YY4.js +10 -0
- package/payload/server/public/assets/chunk-FMBD7UC4-w-yBZsN2.js +15 -0
- package/payload/server/public/assets/chunk-FOC6F5B3-f9cFywhd.js +1 -0
- package/payload/server/public/assets/chunk-ICPOFSXX-C5_hbB6H.js +122 -0
- package/payload/server/public/assets/chunk-K5T4RW27-B_ZUrFUq.js +94 -0
- package/payload/server/public/assets/chunk-KGLVRYIC-CcWTvRlI.js +1 -0
- package/payload/server/public/assets/chunk-LIHQZDEY-D-5-peQw.js +1 -0
- package/payload/server/public/assets/chunk-ORNJ4GCN-B4Z5L25I.js +1 -0
- package/payload/server/public/assets/chunk-OYMX7WX6-CrL4rhBa.js +231 -0
- package/payload/server/public/assets/chunk-QZHKN3VN-CWh_0JsP.js +1 -0
- package/payload/server/public/assets/chunk-U2HBQHQK-CQpbcqRS.js +70 -0
- package/payload/server/public/assets/chunk-X2U36JSP-1HG7T4gX.js +1 -0
- package/payload/server/public/assets/chunk-XPW4576I-m1Y_r88I.js +32 -0
- package/payload/server/public/assets/chunk-YZCP3GAM-boN5wjX9.js +1 -0
- package/payload/server/public/assets/chunk-ZZ45TVLE-D6CiPO0Q.js +1 -0
- package/payload/server/public/assets/classDiagram-6PBFFD2Q-wQ2-BRyB.js +1 -0
- package/payload/server/public/assets/classDiagram-v2-HSJHXN6E-B_YLNNHy.js +1 -0
- package/payload/server/public/assets/clone-VLK-GPZZ.js +1 -0
- package/payload/server/public/assets/cormorant-cyrillic-300-normal-CzPHYadL.woff +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-300-normal-DFUoTmrg.woff2 +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-400-normal-C8QS47vb.woff2 +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-400-normal-D3EsxgFc.woff +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-500-normal-B7dJQtg-.woff +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-500-normal-BLlg2W5x.woff2 +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-ext-300-normal-BXl3lXsi.woff2 +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-ext-300-normal-DmxSOTe3.woff +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-ext-400-normal-Bgrpe4p1.woff +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-ext-400-normal-BlcaxZtM.woff2 +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-ext-500-normal-CdQuyvtc.woff +0 -0
- package/payload/server/public/assets/cormorant-cyrillic-ext-500-normal-pZw22qtS.woff2 +0 -0
- package/payload/server/public/assets/cormorant-latin-300-normal-CJ5dfen0.woff2 +0 -0
- package/payload/server/public/assets/cormorant-latin-300-normal-DQZObO_3.woff +0 -0
- package/payload/server/public/assets/cormorant-latin-400-normal-BGH8Vunh.woff2 +0 -0
- package/payload/server/public/assets/cormorant-latin-400-normal-C3_-2Ua-.woff +0 -0
- package/payload/server/public/assets/cormorant-latin-500-normal-Dj3SQ6fR.woff +0 -0
- package/payload/server/public/assets/cormorant-latin-500-normal-EBdSCOD3.woff2 +0 -0
- package/payload/server/public/assets/cormorant-latin-ext-300-normal-CkiUx0UG.woff +0 -0
- package/payload/server/public/assets/cormorant-latin-ext-300-normal-De3D72RL.woff2 +0 -0
- package/payload/server/public/assets/cormorant-latin-ext-400-normal-DuQ88yz3.woff2 +0 -0
- package/payload/server/public/assets/cormorant-latin-ext-400-normal-DuXFa1Dr.woff +0 -0
- package/payload/server/public/assets/cormorant-latin-ext-500-normal-AH9qog1s.woff2 +0 -0
- package/payload/server/public/assets/cormorant-latin-ext-500-normal-DAuUCO41.woff +0 -0
- package/payload/server/public/assets/cormorant-vietnamese-300-normal-BVqIp_mg.woff2 +0 -0
- package/payload/server/public/assets/cormorant-vietnamese-300-normal-CEMS9Pw-.woff +0 -0
- package/payload/server/public/assets/cormorant-vietnamese-400-normal-C-RiYxEf.woff2 +0 -0
- package/payload/server/public/assets/cormorant-vietnamese-400-normal-DmUuA7Y2.woff +0 -0
- package/payload/server/public/assets/cormorant-vietnamese-500-normal-DsPuwQHi.woff2 +0 -0
- package/payload/server/public/assets/cormorant-vietnamese-500-normal-tGBW_mI7.woff +0 -0
- package/payload/server/public/assets/cose-bilkent-S5V4N54A-BhtgY3T7.js +1 -0
- package/payload/server/public/assets/cytoscape.esm-C9yNhe1u.js +321 -0
- package/payload/server/public/assets/dagre-CncXYNX1.js +1 -0
- package/payload/server/public/assets/dagre-KV5264BT-C0CcgCHW.js +4 -0
- package/payload/server/public/assets/data-Bt4Wsocg.js +1 -0
- package/payload/server/public/assets/defaultLocale-_WRwicXn.js +1 -0
- package/payload/server/public/assets/diagram-5BDNPKRD-CkUlWbsI.js +10 -0
- package/payload/server/public/assets/diagram-G4DWMVQ6-DVZBG1Ul.js +24 -0
- package/payload/server/public/assets/diagram-MMDJMWI5-BIb06ZkK.js +43 -0
- package/payload/server/public/assets/diagram-TYMM5635-BcT0_WR8.js +24 -0
- package/payload/server/public/assets/dist-Bd4S37oi.js +1 -0
- package/payload/server/public/assets/dm-sans-latin-400-normal-BwCSEQnW.woff +0 -0
- package/payload/server/public/assets/dm-sans-latin-400-normal-CW0RaeGs.woff2 +0 -0
- package/payload/server/public/assets/dm-sans-latin-500-normal-B9HHJjqV.woff2 +0 -0
- package/payload/server/public/assets/dm-sans-latin-500-normal-Dr3UlScf.woff +0 -0
- package/payload/server/public/assets/dm-sans-latin-ext-400-normal-BjWJ59Pq.woff +0 -0
- package/payload/server/public/assets/dm-sans-latin-ext-400-normal-BtiwyxMk.woff2 +0 -0
- package/payload/server/public/assets/dm-sans-latin-ext-500-normal-BJfUCQsA.woff2 +0 -0
- package/payload/server/public/assets/dm-sans-latin-ext-500-normal-DR84L5F-.woff +0 -0
- package/payload/server/public/assets/erDiagram-SMLLAGMA-BHk6lxIT.js +85 -0
- package/payload/server/public/assets/flatten-BsWEYbBB.js +1 -0
- package/payload/server/public/assets/flowDiagram-DWJPFMVM-CjeJn490.js +162 -0
- package/payload/server/public/assets/ganttDiagram-T4ZO3ILL-BGYvX3Lv.js +292 -0
- package/payload/server/public/assets/gitGraph-7Q5UKJZL-DeTNsAO0.js +1 -0
- package/payload/server/public/assets/gitGraphDiagram-UUTBAWPF-Br4WLGzW.js +106 -0
- package/payload/server/public/assets/graph-CRSLozxc.js +1 -0
- package/payload/server/public/assets/graph-labels-CQyZQ0u6.js +1 -0
- package/payload/server/public/assets/graphlib-BWd9sMeP.js +1 -0
- package/payload/server/public/assets/info-OMHHGYJF-DJJ9GlS6.js +1 -0
- package/payload/server/public/assets/infoDiagram-42DDH7IO-BjZeQoNZ.js +2 -0
- package/payload/server/public/assets/init-sTEcj9YX.js +1 -0
- package/payload/server/public/assets/isEmpty-BWl67LAZ.js +1 -0
- package/payload/server/public/assets/ishikawaDiagram-UXIWVN3A-POMae6Ni.js +70 -0
- package/payload/server/public/assets/jetbrains-mono-cyrillic-400-normal-BEIGL1Tu.woff2 +0 -0
- package/payload/server/public/assets/jetbrains-mono-cyrillic-400-normal-ugxPyKxw.woff +0 -0
- package/payload/server/public/assets/jetbrains-mono-cyrillic-500-normal-DJqRU3vO.woff +0 -0
- package/payload/server/public/assets/jetbrains-mono-cyrillic-500-normal-DmUKJPL_.woff2 +0 -0
- package/payload/server/public/assets/jetbrains-mono-greek-400-normal-B9oWc5Lo.woff +0 -0
- package/payload/server/public/assets/jetbrains-mono-greek-400-normal-C190GLew.woff2 +0 -0
- package/payload/server/public/assets/jetbrains-mono-greek-500-normal-D7SFKleX.woff +0 -0
- package/payload/server/public/assets/jetbrains-mono-greek-500-normal-JpySY46c.woff2 +0 -0
- package/payload/server/public/assets/jetbrains-mono-latin-400-normal-6-qcROiO.woff +0 -0
- package/payload/server/public/assets/jetbrains-mono-latin-400-normal-V6pRDFza.woff2 +0 -0
- package/payload/server/public/assets/jetbrains-mono-latin-500-normal-BWZEU5yA.woff2 +0 -0
- package/payload/server/public/assets/jetbrains-mono-latin-500-normal-CJOVTJB7.woff +0 -0
- package/payload/server/public/assets/jetbrains-mono-latin-ext-400-normal-Bc8Ftmh3.woff2 +0 -0
- package/payload/server/public/assets/jetbrains-mono-latin-ext-400-normal-fXTG6kC5.woff +0 -0
- package/payload/server/public/assets/jetbrains-mono-latin-ext-500-normal-Cut-4mMH.woff2 +0 -0
- package/payload/server/public/assets/jetbrains-mono-latin-ext-500-normal-ckzbgY84.woff +0 -0
- package/payload/server/public/assets/jetbrains-mono-vietnamese-400-normal-CqNFfHCs.woff +0 -0
- package/payload/server/public/assets/jetbrains-mono-vietnamese-500-normal-DNRqzVM1.woff +0 -0
- package/payload/server/public/assets/journeyDiagram-VCZTEJTY-ledtLV6x.js +139 -0
- package/payload/server/public/assets/jsx-runtime-DvanDPKm.css +1 -0
- package/payload/server/public/assets/jsx-runtime-vPsBTwUp.js +9 -0
- package/payload/server/public/assets/kanban-definition-6JOO6SKY-DI0T4W9z.js +89 -0
- package/payload/server/public/assets/katex-s61Rgv6l.js +257 -0
- package/payload/server/public/assets/lib-W5Jcz4p8.js +33 -0
- package/payload/server/public/assets/line-D1281H12.js +1 -0
- package/payload/server/public/assets/linear-0O14Y6uf.js +1 -0
- package/payload/server/public/assets/mermaid-parser.core-Dt95U7zk.js +4 -0
- package/payload/server/public/assets/mermaid.core-BuYSs1fU.js +11 -0
- package/payload/server/public/assets/mindmap-definition-QFDTVHPH-CFE1lmfX.js +96 -0
- package/payload/server/public/assets/ordinal-krseTxxN.js +1 -0
- package/payload/server/public/assets/packet-4T2RLAQJ-CGbvGkvF.js +1 -0
- package/payload/server/public/assets/page-CSUcuVW0.js +1 -0
- package/payload/server/public/assets/page-TARBO-Yr.js +50 -0
- package/payload/server/public/assets/path-B0Ik7Tu9.js +1 -0
- package/payload/server/public/assets/pie-ZZUOXDRM-BZy8rjFn.js +1 -0
- package/payload/server/public/assets/pieDiagram-DEJITSTG-BSd9xa7v.js +30 -0
- package/payload/server/public/assets/public-5r6aRXrb.js +8 -0
- package/payload/server/public/assets/quadrantDiagram-34T5L4WZ-xYehPVw5.js +7 -0
- package/payload/server/public/assets/radar-PYXPWWZC-DcfWIVXr.js +1 -0
- package/payload/server/public/assets/reduce-tk-xY6Fv.js +1 -0
- package/payload/server/public/assets/requirementDiagram-MS252O5E-C6n77V1S.js +84 -0
- package/payload/server/public/assets/rough.esm-DKRO8IF-.js +1 -0
- package/payload/server/public/assets/sankeyDiagram-XADWPNL6-CWIfeO1M.js +10 -0
- package/payload/server/public/assets/sequenceDiagram-FGHM5R23-DDv2DuMo.js +157 -0
- package/payload/server/public/assets/src-B6XdH6xq.js +1 -0
- package/payload/server/public/assets/stateDiagram-FHFEXIEX-BPZdmsww.js +1 -0
- package/payload/server/public/assets/stateDiagram-v2-QKLJ7IA2-33eC4TwE.js +1 -0
- package/payload/server/public/assets/timeline-definition-GMOUNBTQ-BpRT_wSX.js +120 -0
- package/payload/server/public/assets/treeView-SZITEDCU-3WugwVdj.js +1 -0
- package/payload/server/public/assets/treemap-W4RFUUIX-Cf5mDLlu.js +1 -0
- package/payload/server/public/assets/vennDiagram-DHZGUBPP-BG8ubucH.js +34 -0
- package/payload/server/public/assets/wardley-RL74JXVD-Bv4md4b3.js +1 -0
- package/payload/server/public/assets/wardleyDiagram-NUSXRM2D-D4E7PU1B.js +20 -0
- package/payload/server/public/assets/xychartDiagram-5P7HB3ND-Ur2xVM-c.js +7 -0
- package/payload/server/public/brand/claude.png +0 -0
- package/payload/server/public/brand/favicon.ico +0 -0
- package/payload/server/public/brand/maxy-black.png +0 -0
- package/payload/server/public/brand/maxy-horizontal.png +0 -0
- package/payload/server/public/brand/maxy-monochrome.png +0 -0
- package/payload/server/public/brand/maxy-square.png +0 -0
- package/payload/server/public/brand/maxy.png +0 -0
- package/payload/server/public/brand/star.png +0 -0
- package/payload/server/public/brand-constants.json +8 -0
- package/payload/server/public/brand-defaults.css +12 -0
- package/payload/server/public/data.html +18 -0
- package/payload/server/public/favicon.ico +0 -0
- package/payload/server/public/graph.html +19 -0
- package/payload/server/public/index.html +23 -0
- package/payload/server/public/public.html +19 -0
- package/payload/server/public/robots.txt +5 -0
- package/payload/server/public/vnc-popout.html +63 -0
- package/payload/server/server-init.cjs +115 -0
- package/payload/server/server.js +14960 -0
|
@@ -0,0 +1,1155 @@
|
|
|
1
|
+
import { execFileSync, spawn } from "node:child_process";
|
|
2
|
+
import { existsSync, readFileSync, writeFileSync, mkdirSync, openSync, unlinkSync, copyFileSync, statSync, } from "node:fs";
|
|
3
|
+
import { join } from "node:path";
|
|
4
|
+
import { homedir } from "node:os";
|
|
5
|
+
import { Resolver } from "node:dns/promises";
|
|
6
|
+
let cachedBrand = null;
|
|
7
|
+
export function loadBrand() {
|
|
8
|
+
if (cachedBrand)
|
|
9
|
+
return cachedBrand;
|
|
10
|
+
const platformRoot = process.env.PLATFORM_ROOT;
|
|
11
|
+
if (!platformRoot) {
|
|
12
|
+
throw new Error("PLATFORM_ROOT env var is not set — cannot determine brand configuration");
|
|
13
|
+
}
|
|
14
|
+
const brandPath = join(platformRoot, "config", "brand.json");
|
|
15
|
+
if (!existsSync(brandPath)) {
|
|
16
|
+
throw new Error(`brand.json not found at ${brandPath} — PLATFORM_ROOT may be incorrect`);
|
|
17
|
+
}
|
|
18
|
+
const parsed = JSON.parse(readFileSync(brandPath, "utf-8"));
|
|
19
|
+
cachedBrand = {
|
|
20
|
+
configDir: parsed.configDir ?? ".maxy",
|
|
21
|
+
productName: parsed.productName ?? "Maxy",
|
|
22
|
+
vncDisplay: typeof parsed.vncDisplay === "number" ? parsed.vncDisplay : 99,
|
|
23
|
+
};
|
|
24
|
+
return cachedBrand;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Test-only: reset the cached brand so a subsequent loadBrand() re-reads
|
|
28
|
+
* the manifest. Production code never calls this.
|
|
29
|
+
*/
|
|
30
|
+
export function _resetBrandCache() {
|
|
31
|
+
cachedBrand = null;
|
|
32
|
+
}
|
|
33
|
+
// ---------------------------------------------------------------------------
|
|
34
|
+
// Binary detection
|
|
35
|
+
// ---------------------------------------------------------------------------
|
|
36
|
+
let cachedBinaryPath = null;
|
|
37
|
+
const SEARCH_PATHS = [
|
|
38
|
+
"/usr/local/bin/cloudflared",
|
|
39
|
+
"/usr/bin/cloudflared",
|
|
40
|
+
join(homedir(), ".local/bin/cloudflared"),
|
|
41
|
+
];
|
|
42
|
+
export function findBinary() {
|
|
43
|
+
if (cachedBinaryPath)
|
|
44
|
+
return cachedBinaryPath;
|
|
45
|
+
try {
|
|
46
|
+
cachedBinaryPath = execFileSync("which", ["cloudflared"], {
|
|
47
|
+
encoding: "utf-8",
|
|
48
|
+
timeout: 5000,
|
|
49
|
+
}).trim();
|
|
50
|
+
return cachedBinaryPath;
|
|
51
|
+
}
|
|
52
|
+
catch {
|
|
53
|
+
// not on PATH
|
|
54
|
+
}
|
|
55
|
+
for (const p of SEARCH_PATHS) {
|
|
56
|
+
if (existsSync(p)) {
|
|
57
|
+
cachedBinaryPath = p;
|
|
58
|
+
return p;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
63
|
+
export function isInstalled() {
|
|
64
|
+
return findBinary() !== null;
|
|
65
|
+
}
|
|
66
|
+
export function version() {
|
|
67
|
+
const bin = findBinary();
|
|
68
|
+
if (!bin)
|
|
69
|
+
return null;
|
|
70
|
+
try {
|
|
71
|
+
const out = execFileSync(bin, ["--version"], {
|
|
72
|
+
encoding: "utf-8",
|
|
73
|
+
timeout: 5000,
|
|
74
|
+
});
|
|
75
|
+
const match = out.match(/cloudflared version (\S+)/);
|
|
76
|
+
return match?.[1] ?? out.trim();
|
|
77
|
+
}
|
|
78
|
+
catch {
|
|
79
|
+
return null;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
function bindingDir() {
|
|
83
|
+
return join(homedir(), loadBrand().configDir, "cloudflare");
|
|
84
|
+
}
|
|
85
|
+
function bindingFile() {
|
|
86
|
+
return join(bindingDir(), "account-binding.json");
|
|
87
|
+
}
|
|
88
|
+
export function readAccountBinding() {
|
|
89
|
+
try {
|
|
90
|
+
const path = bindingFile();
|
|
91
|
+
if (!existsSync(path))
|
|
92
|
+
return null;
|
|
93
|
+
const parsed = JSON.parse(readFileSync(path, "utf-8"));
|
|
94
|
+
if (typeof parsed?.accountId !== "string" || typeof parsed?.boundAt !== "string") {
|
|
95
|
+
console.error(`[cloudflare:binding] malformed account-binding.json at ${path} — treating as absent`);
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
return { accountId: parsed.accountId, boundAt: parsed.boundAt };
|
|
99
|
+
}
|
|
100
|
+
catch (err) {
|
|
101
|
+
console.error(`[cloudflare:binding] failed to read ${bindingFile()}: ${err}`);
|
|
102
|
+
return null;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* @internal — production code MUST go through `materializeBinding` so the
|
|
107
|
+
* source-of-truth lifecycle (fresh-login vs migration) is preserved and
|
|
108
|
+
* logged. Exported only so unit tests can pre-seed bindings without
|
|
109
|
+
* re-implementing the file format.
|
|
110
|
+
*/
|
|
111
|
+
export function writeAccountBinding(accountId) {
|
|
112
|
+
const dir = bindingDir();
|
|
113
|
+
mkdirSync(dir, { recursive: true });
|
|
114
|
+
const binding = { accountId, boundAt: new Date().toISOString() };
|
|
115
|
+
writeFileSync(bindingFile(), JSON.stringify(binding, null, 2), { mode: 0o600 });
|
|
116
|
+
return binding;
|
|
117
|
+
}
|
|
118
|
+
function resetAccountBinding() {
|
|
119
|
+
const path = bindingFile();
|
|
120
|
+
try {
|
|
121
|
+
unlinkSync(path);
|
|
122
|
+
console.error(`[cloudflare:binding] reset ${path}`);
|
|
123
|
+
return true;
|
|
124
|
+
}
|
|
125
|
+
catch (err) {
|
|
126
|
+
const code = err.code;
|
|
127
|
+
if (code === "ENOENT")
|
|
128
|
+
return false;
|
|
129
|
+
console.error(`[cloudflare:binding] failed to reset ${path}: ${err}`);
|
|
130
|
+
return false;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
export function logRefuse(detail) {
|
|
134
|
+
const brand = (() => {
|
|
135
|
+
try {
|
|
136
|
+
return loadBrand();
|
|
137
|
+
}
|
|
138
|
+
catch {
|
|
139
|
+
return null;
|
|
140
|
+
}
|
|
141
|
+
})();
|
|
142
|
+
const f = detail.fields ?? {};
|
|
143
|
+
const fields = {
|
|
144
|
+
reason: detail.reason,
|
|
145
|
+
brand: brand?.productName ?? "unknown",
|
|
146
|
+
boundAccountId: f.boundAccountId ?? null,
|
|
147
|
+
certAccountId: f.certAccountId ?? null,
|
|
148
|
+
requestedDomain: f.requestedDomain ?? null,
|
|
149
|
+
requestedHostname: f.requestedHostname ?? null,
|
|
150
|
+
actualFqdn: f.actualFqdn ?? null,
|
|
151
|
+
tunnelId: f.tunnelId ?? null,
|
|
152
|
+
};
|
|
153
|
+
console.error(`[cloudflare:refuse] ${JSON.stringify(fields)}`);
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* The only recovery instruction — every refusal that involves the wrong
|
|
157
|
+
* Cloudflare account points here. Single source of truth so the four
|
|
158
|
+
* surfaces that quote it (tunnel-status, tunnel-add-hostname, personal
|
|
159
|
+
* assistant template, setup-tunnel skill) cannot drift.
|
|
160
|
+
*/
|
|
161
|
+
export const DASHBOARD_SWITCH_ACCOUNTS_INSTRUCTION = "Open Cloudflare in your browser. Look at the name in the top-left — " +
|
|
162
|
+
"that is the Cloudflare account this laptop will talk to. If it is not " +
|
|
163
|
+
"the account that owns the domain you want to use, switch accounts using " +
|
|
164
|
+
"the top-left dropdown. Once the correct account is showing, tell me and " +
|
|
165
|
+
"I will start the sign-in again.";
|
|
166
|
+
export function recoveryMessage() {
|
|
167
|
+
return ("Recovery: confirm you are signed into the correct Cloudflare account " +
|
|
168
|
+
"in your browser, then ask me to run tunnel-login. If you recently switched " +
|
|
169
|
+
"accounts, ask me to run tunnel-login with force=true so the current sign-in " +
|
|
170
|
+
"is cleared before the new one starts.");
|
|
171
|
+
}
|
|
172
|
+
// ---------------------------------------------------------------------------
|
|
173
|
+
// Reset auth — unlinks cert.pem (both paths) and the account binding
|
|
174
|
+
//
|
|
175
|
+
// Kill order matters: terminate any in-flight `cloudflared tunnel login`
|
|
176
|
+
// process BEFORE deleting cert state, otherwise its browser handshake can
|
|
177
|
+
// complete between our unlink and return, writing a fresh cert.pem to the
|
|
178
|
+
// legacy path that findCert() would silently re-import on the next read.
|
|
179
|
+
// Same pattern Task 531 closed; preserved here.
|
|
180
|
+
// ---------------------------------------------------------------------------
|
|
181
|
+
export function resetAuth() {
|
|
182
|
+
const result = { deletedCert: false, deletedBinding: false };
|
|
183
|
+
const loginState = readLoginState();
|
|
184
|
+
if (loginState?.pid && isProcessAlive(loginState.pid)) {
|
|
185
|
+
try {
|
|
186
|
+
process.kill(loginState.pid, "SIGTERM");
|
|
187
|
+
console.error(`[tunnel-login] killed stale login process PID ${loginState.pid}`);
|
|
188
|
+
}
|
|
189
|
+
catch {
|
|
190
|
+
// Process may have exited between check and kill
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
clearLoginState();
|
|
194
|
+
const cp = certPath();
|
|
195
|
+
try {
|
|
196
|
+
unlinkSync(cp);
|
|
197
|
+
result.deletedCert = true;
|
|
198
|
+
console.error(`[tunnel-login] deleted: ${cp}`);
|
|
199
|
+
}
|
|
200
|
+
catch (err) {
|
|
201
|
+
const code = err.code;
|
|
202
|
+
if (code === "ENOENT") {
|
|
203
|
+
// File already gone — no-op
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
console.error(`[tunnel-login] failed to delete cert.pem ${cp}: ${err}`);
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
const legacyCp = legacyCertPath();
|
|
210
|
+
try {
|
|
211
|
+
unlinkSync(legacyCp);
|
|
212
|
+
console.error(`[tunnel-login] deleted legacy cert.pem: ${legacyCp}`);
|
|
213
|
+
}
|
|
214
|
+
catch (err) {
|
|
215
|
+
const code = err.code;
|
|
216
|
+
if (code === "ENOENT") {
|
|
217
|
+
console.error(`[tunnel-login] legacy cert.pem absent: ${legacyCp}`);
|
|
218
|
+
}
|
|
219
|
+
else {
|
|
220
|
+
console.error(`[tunnel-login] failed to delete legacy cert.pem ${legacyCp}: ${err}`);
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
result.deletedBinding = resetAccountBinding();
|
|
224
|
+
return result;
|
|
225
|
+
}
|
|
226
|
+
// ---------------------------------------------------------------------------
|
|
227
|
+
// cert.pem — written by `cloudflared tunnel login`
|
|
228
|
+
//
|
|
229
|
+
// Stored under ~/{configDir}/cloudflared/ so each brand has its own cert.
|
|
230
|
+
// Function (not const) because loadBrand() requires PLATFORM_ROOT at runtime.
|
|
231
|
+
// ---------------------------------------------------------------------------
|
|
232
|
+
function certPath() {
|
|
233
|
+
return join(homedir(), loadBrand().configDir, "cloudflared/cert.pem");
|
|
234
|
+
}
|
|
235
|
+
// cloudflared tunnel login always writes here regardless of --origincert.
|
|
236
|
+
// Same literal lives in the installer's cloudflared migration block.
|
|
237
|
+
function legacyCertPath() {
|
|
238
|
+
return join(homedir(), ".cloudflared", "cert.pem");
|
|
239
|
+
}
|
|
240
|
+
/**
|
|
241
|
+
* Find cert.pem, checking the brand-specific path first, then cloudflared's
|
|
242
|
+
* default location. cloudflared tunnel login ALWAYS writes to
|
|
243
|
+
* ~/.cloudflared/cert.pem regardless of --origincert, so we must check
|
|
244
|
+
* there as a fallback.
|
|
245
|
+
*
|
|
246
|
+
* Move-on-read: when the cert is found at the legacy path, copy it to the
|
|
247
|
+
* brand path AND unlink the legacy file. Without the unlink, the legacy
|
|
248
|
+
* file would survive `tunnel-login force=true` (which only deletes brand
|
|
249
|
+
* paths) and silently re-import on the next read — defeating the recovery
|
|
250
|
+
* path operators rely on after switching Cloudflare accounts.
|
|
251
|
+
*/
|
|
252
|
+
function findCert() {
|
|
253
|
+
const brandPath = certPath();
|
|
254
|
+
if (existsSync(brandPath))
|
|
255
|
+
return brandPath;
|
|
256
|
+
const defaultPath = legacyCertPath();
|
|
257
|
+
if (existsSync(defaultPath)) {
|
|
258
|
+
const dir = join(homedir(), loadBrand().configDir, "cloudflared");
|
|
259
|
+
mkdirSync(dir, { recursive: true });
|
|
260
|
+
copyFileSync(defaultPath, brandPath);
|
|
261
|
+
try {
|
|
262
|
+
unlinkSync(defaultPath);
|
|
263
|
+
console.error(`[tunnel-login] cert.pem migrated from ${defaultPath} to ${brandPath}`);
|
|
264
|
+
}
|
|
265
|
+
catch (err) {
|
|
266
|
+
console.error(`[tunnel-login] WARNING: cert.pem migrated to ${brandPath} but legacy ${defaultPath} could not be removed: ${err}`);
|
|
267
|
+
}
|
|
268
|
+
return brandPath;
|
|
269
|
+
}
|
|
270
|
+
return null;
|
|
271
|
+
}
|
|
272
|
+
export function hasCert() {
|
|
273
|
+
return findCert() !== null;
|
|
274
|
+
}
|
|
275
|
+
/**
|
|
276
|
+
* Parse the ARGO TUNNEL TOKEN PEM block from cert.pem to extract the
|
|
277
|
+
* AccountTag. Only the account ID is returned — nothing else in cert.pem
|
|
278
|
+
* is used by this codebase. The cert itself stays on disk; `cloudflared`
|
|
279
|
+
* shell-outs read it via `--origincert` for tunnel CRUD and DNS routing.
|
|
280
|
+
*/
|
|
281
|
+
export function parseCertPem() {
|
|
282
|
+
try {
|
|
283
|
+
const cert = findCert();
|
|
284
|
+
if (!cert)
|
|
285
|
+
return null;
|
|
286
|
+
const pem = readFileSync(cert, "utf-8");
|
|
287
|
+
const beginMarker = "-----BEGIN ARGO TUNNEL TOKEN-----";
|
|
288
|
+
const endMarker = "-----END ARGO TUNNEL TOKEN-----";
|
|
289
|
+
const beginIdx = pem.indexOf(beginMarker);
|
|
290
|
+
const endIdx = pem.indexOf(endMarker);
|
|
291
|
+
if (beginIdx === -1 || endIdx === -1)
|
|
292
|
+
return null;
|
|
293
|
+
const b64 = pem
|
|
294
|
+
.slice(beginIdx + beginMarker.length, endIdx)
|
|
295
|
+
.replace(/\s+/g, "");
|
|
296
|
+
const json = Buffer.from(b64, "base64").toString("utf-8");
|
|
297
|
+
const data = JSON.parse(json);
|
|
298
|
+
const accountId = data.AccountTag ?? data.accountTag ?? data.AccountID ?? data.accountID ?? data.accountId;
|
|
299
|
+
if (!accountId)
|
|
300
|
+
return null;
|
|
301
|
+
return { accountId };
|
|
302
|
+
}
|
|
303
|
+
catch {
|
|
304
|
+
return null;
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
/** Wraps a structured RefusalDetail so call sites can branch on `reason`. */
|
|
308
|
+
export class CloudflareRefusalError extends Error {
|
|
309
|
+
refusal;
|
|
310
|
+
constructor(detail) {
|
|
311
|
+
super(detail.message);
|
|
312
|
+
this.name = "CloudflareRefusalError";
|
|
313
|
+
this.refusal = detail;
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
export function validateAuth() {
|
|
317
|
+
const creds = parseCertPem();
|
|
318
|
+
const binding = readAccountBinding();
|
|
319
|
+
return {
|
|
320
|
+
hasCert: !!creds,
|
|
321
|
+
hasBinding: !!binding,
|
|
322
|
+
bound: !!(creds && binding && creds.accountId === binding.accountId),
|
|
323
|
+
certAccountId: creds?.accountId ?? null,
|
|
324
|
+
boundAccountId: binding?.accountId ?? null,
|
|
325
|
+
};
|
|
326
|
+
}
|
|
327
|
+
/**
|
|
328
|
+
* Establish the device-local account binding from cert.pem. Used by:
|
|
329
|
+
* (1) tunnel-login fresh-success path — first time creds are derived.
|
|
330
|
+
* (2) migration path — when cert.pem exists from a prior install but no
|
|
331
|
+
* binding has yet been written (silent materialization, since the
|
|
332
|
+
* cert was already trust-established by the operator's prior login).
|
|
333
|
+
*/
|
|
334
|
+
export function materializeBinding(source) {
|
|
335
|
+
const creds = parseCertPem();
|
|
336
|
+
if (!creds) {
|
|
337
|
+
throw new Error("Cannot materialize binding — cert.pem absent or unparseable");
|
|
338
|
+
}
|
|
339
|
+
const binding = writeAccountBinding(creds.accountId);
|
|
340
|
+
console.error(`[cloudflare:binding-materialized] source=${source} accountId=${creds.accountId} boundAt=${binding.boundAt}`);
|
|
341
|
+
return binding;
|
|
342
|
+
}
|
|
343
|
+
// Alias-domains read/write lived here historically; Task 554 removed the MCP
|
|
344
|
+
// tool that wrote it, and Task 563 moved the writer to
|
|
345
|
+
// platform/ui/app/lib/alias-domains.ts so the reader (server/index.ts
|
|
346
|
+
// watchFile loop) and the writer share one process. The file on disk
|
|
347
|
+
// (~/{configDir}/alias-domains.json) is still the interchange format.
|
|
348
|
+
// ---------------------------------------------------------------------------
|
|
349
|
+
// CLI-based tunnel operations
|
|
350
|
+
//
|
|
351
|
+
// `cloudflared` CLI uses cert.pem directly for tunnel CRUD and DNS routing.
|
|
352
|
+
// Shelling out to the CLI is architecturally indistinguishable from the
|
|
353
|
+
// operator clicking the same action in the dashboard — both use the
|
|
354
|
+
// operator's OAuth-bound cert, nothing more.
|
|
355
|
+
// ---------------------------------------------------------------------------
|
|
356
|
+
// Name convention: `{product}-{device}` — e.g. "maxy-laptop". Encodes product identity and physical location in one label.
|
|
357
|
+
export function createTunnelCli(name) {
|
|
358
|
+
const bin = findBinary();
|
|
359
|
+
if (!bin)
|
|
360
|
+
throw new Error("cloudflared is not installed");
|
|
361
|
+
const cert = findCert();
|
|
362
|
+
if (!cert)
|
|
363
|
+
throw new Error("No cert.pem found — run tunnel-login first");
|
|
364
|
+
// Check for existing tunnel with this name first
|
|
365
|
+
try {
|
|
366
|
+
const listOutput = execFileSync(bin, ["tunnel", "--origincert", cert, "list", "-o", "json"], { encoding: "utf-8", timeout: 30000 });
|
|
367
|
+
const tunnels = JSON.parse(listOutput);
|
|
368
|
+
const existing = tunnels.find((t) => t.name === name && !t.deleted_at);
|
|
369
|
+
if (existing) {
|
|
370
|
+
console.error(`[tunnel-create] CLI: tunnel "${name}" already exists (${existing.id})`);
|
|
371
|
+
const brandCredPath = join(homedir(), loadBrand().configDir, "cloudflared", `${existing.id}.json`);
|
|
372
|
+
const defaultCredPath = join(homedir(), ".cloudflared", `${existing.id}.json`);
|
|
373
|
+
if (!existsSync(brandCredPath) && existsSync(defaultCredPath)) {
|
|
374
|
+
const dir = join(homedir(), loadBrand().configDir, "cloudflared");
|
|
375
|
+
mkdirSync(dir, { recursive: true });
|
|
376
|
+
copyFileSync(defaultCredPath, brandCredPath);
|
|
377
|
+
console.error(`[tunnel-create] credentials copied to ${brandCredPath}`);
|
|
378
|
+
}
|
|
379
|
+
return {
|
|
380
|
+
tunnelId: existing.id,
|
|
381
|
+
tunnelName: name,
|
|
382
|
+
credentialsPath: brandCredPath,
|
|
383
|
+
};
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
catch {
|
|
387
|
+
// list failed — proceed to create
|
|
388
|
+
}
|
|
389
|
+
const output = execFileSync(bin, ["tunnel", "--origincert", cert, "create", name], { encoding: "utf-8", timeout: 30000 });
|
|
390
|
+
console.error(`[tunnel-create] CLI: ${output.trim()}`);
|
|
391
|
+
// Parse tunnel ID from output: "Created tunnel <name> with id <uuid>"
|
|
392
|
+
const idMatch = output.match(/with id ([0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12})/i);
|
|
393
|
+
if (!idMatch) {
|
|
394
|
+
throw new Error(`cloudflared tunnel create succeeded but could not parse tunnel ID from output: ${output.trim()}`);
|
|
395
|
+
}
|
|
396
|
+
const tunnelId = idMatch[1];
|
|
397
|
+
// cloudflared writes credentials to ~/.cloudflared/<id>.json — copy to brand path
|
|
398
|
+
const defaultCredPath = join(homedir(), ".cloudflared", `${tunnelId}.json`);
|
|
399
|
+
const brandDir = join(homedir(), loadBrand().configDir, "cloudflared");
|
|
400
|
+
mkdirSync(brandDir, { recursive: true });
|
|
401
|
+
const brandCredPath = join(brandDir, `${tunnelId}.json`);
|
|
402
|
+
if (existsSync(defaultCredPath)) {
|
|
403
|
+
copyFileSync(defaultCredPath, brandCredPath);
|
|
404
|
+
console.error(`[tunnel-create] credentials copied to ${brandCredPath}`);
|
|
405
|
+
}
|
|
406
|
+
return { tunnelId, tunnelName: name, credentialsPath: brandCredPath };
|
|
407
|
+
}
|
|
408
|
+
export function getTunnelTokenCli(tunnelId) {
|
|
409
|
+
const bin = findBinary();
|
|
410
|
+
if (!bin)
|
|
411
|
+
throw new Error("cloudflared is not installed");
|
|
412
|
+
const cert = findCert();
|
|
413
|
+
if (!cert)
|
|
414
|
+
throw new Error("No cert.pem found — run tunnel-login first");
|
|
415
|
+
const output = execFileSync(bin, ["tunnel", "--origincert", cert, "token", tunnelId], { encoding: "utf-8", timeout: 30000, stdio: ["pipe", "pipe", "pipe"] });
|
|
416
|
+
const token = output.trim();
|
|
417
|
+
if (!token) {
|
|
418
|
+
throw new Error("cloudflared tunnel token returned empty output");
|
|
419
|
+
}
|
|
420
|
+
console.error(`[tunnel-token] CLI: obtained connector token for tunnel ${tunnelId}`);
|
|
421
|
+
return token;
|
|
422
|
+
}
|
|
423
|
+
/**
|
|
424
|
+
* Write a local config.yml for cloudflared tunnel run.
|
|
425
|
+
* This is the ONLY tunnel startup configuration — no remote config, no API.
|
|
426
|
+
* hostnames: the actual FQDNs to route (e.g. ["joel.maxy.bot", "shop.maxy.bot"]).
|
|
427
|
+
*/
|
|
428
|
+
export function writeLocalConfig(tunnelId, credentialsPath, hostnames, port) {
|
|
429
|
+
const dir = join(homedir(), loadBrand().configDir, "cloudflared");
|
|
430
|
+
mkdirSync(dir, { recursive: true });
|
|
431
|
+
const configPath = join(dir, "config.yml");
|
|
432
|
+
const ingressLines = hostnames.flatMap((h) => [
|
|
433
|
+
` - hostname: ${h}`,
|
|
434
|
+
` service: http://localhost:${port}`,
|
|
435
|
+
]);
|
|
436
|
+
const yaml = [
|
|
437
|
+
`tunnel: ${tunnelId}`,
|
|
438
|
+
`credentials-file: ${credentialsPath}`,
|
|
439
|
+
`ingress:`,
|
|
440
|
+
...ingressLines,
|
|
441
|
+
` - service: http_status:404`,
|
|
442
|
+
"",
|
|
443
|
+
].join("\n");
|
|
444
|
+
writeFileSync(configPath, yaml, "utf-8");
|
|
445
|
+
console.error(`[tunnel-create] config written to ${configPath} hostnames=${JSON.stringify(hostnames)}`);
|
|
446
|
+
return configPath;
|
|
447
|
+
}
|
|
448
|
+
// ---------------------------------------------------------------------------
|
|
449
|
+
// Parse configured hostnames from config.yml
|
|
450
|
+
//
|
|
451
|
+
// `tunnel-status`'s end-to-end probe reads the hostnames from config.yml
|
|
452
|
+
// rather than from tunnel.state — config.yml is the authoritative source
|
|
453
|
+
// for what `cloudflared` is actually ingressing. State-file hostnames may
|
|
454
|
+
// drift from on-disk config; the running tunnel only honours config.yml.
|
|
455
|
+
// ---------------------------------------------------------------------------
|
|
456
|
+
export function parseConfiguredHostnames(configYmlPath) {
|
|
457
|
+
try {
|
|
458
|
+
if (!existsSync(configYmlPath))
|
|
459
|
+
return [];
|
|
460
|
+
const yaml = readFileSync(configYmlPath, "utf-8");
|
|
461
|
+
const hostnames = [];
|
|
462
|
+
for (const line of yaml.split("\n")) {
|
|
463
|
+
const m = line.match(/^\s*-\s*hostname:\s*(\S+)\s*$/);
|
|
464
|
+
if (m)
|
|
465
|
+
hostnames.push(m[1]);
|
|
466
|
+
}
|
|
467
|
+
return hostnames;
|
|
468
|
+
}
|
|
469
|
+
catch (err) {
|
|
470
|
+
console.error(`[tunnel-status] failed to parse ${configYmlPath}: ${err}`);
|
|
471
|
+
return [];
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
// ---------------------------------------------------------------------------
|
|
475
|
+
// Nameserver pre-flight — zone-parent routability without any API
|
|
476
|
+
//
|
|
477
|
+
// Before shelling `cloudflared tunnel route dns`, confirm the hostname's
|
|
478
|
+
// registrable parent has its NS records pointing at Cloudflare. When they
|
|
479
|
+
// don't, `cloudflared` silently falls through to whichever zone the cert's
|
|
480
|
+
// account does own and creates a malformed CNAME (the historical
|
|
481
|
+
// `admin.maxy.bot.joelsmalley.xyz` failure mode). Refusing pre-flight is
|
|
482
|
+
// the only way to prevent that drift from inside this codebase.
|
|
483
|
+
//
|
|
484
|
+
// Heuristic for registrable parent: take the last two labels. This fails
|
|
485
|
+
// for multi-label public suffixes (e.g. `.co.uk`, `.com.au`) — not worth
|
|
486
|
+
// correctness here because Cloudflare's own sign-up flow rejects those
|
|
487
|
+
// at zone-add time, so the NS lookup will also fail for them, giving the
|
|
488
|
+
// same "not on Cloudflare yet" message.
|
|
489
|
+
// ---------------------------------------------------------------------------
|
|
490
|
+
function registrableParent(hostname) {
|
|
491
|
+
const labels = hostname.toLowerCase().split(".");
|
|
492
|
+
if (labels.length <= 2)
|
|
493
|
+
return hostname.toLowerCase();
|
|
494
|
+
return labels.slice(-2).join(".");
|
|
495
|
+
}
|
|
496
|
+
export async function checkZoneParentOnCloudflare(hostname) {
|
|
497
|
+
const zoneParent = registrableParent(hostname);
|
|
498
|
+
const resolver = new Resolver();
|
|
499
|
+
resolver.setServers(["1.1.1.1", "8.8.8.8"]);
|
|
500
|
+
try {
|
|
501
|
+
const ns = await resolver.resolveNs(zoneParent);
|
|
502
|
+
const onCloudflare = ns.some((n) => /\.ns\.cloudflare\.com\.?$/i.test(n));
|
|
503
|
+
return { zoneParent, nameservers: ns, onCloudflare };
|
|
504
|
+
}
|
|
505
|
+
catch (err) {
|
|
506
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
507
|
+
return { zoneParent, nameservers: [], onCloudflare: false, error: msg };
|
|
508
|
+
}
|
|
509
|
+
}
|
|
510
|
+
// ---------------------------------------------------------------------------
|
|
511
|
+
// CLI-based DNS routing — shells `cloudflared tunnel route dns` with defence
|
|
512
|
+
// in depth against the known malformed-CNAME fall-through.
|
|
513
|
+
//
|
|
514
|
+
// (1) Pre-flight: zone-parent NS records must point to Cloudflare.
|
|
515
|
+
// Refusal reason `hostname-zone-not-routable` tells the operator
|
|
516
|
+
// to add the domain in the dashboard before coming back.
|
|
517
|
+
// (2) Post-flight: the FQDN `cloudflared` wrote must equal the requested
|
|
518
|
+
// hostname. A mismatch means `cloudflared` routed to a zone owned by
|
|
519
|
+
// the currently-bound account instead of the intended zone — usually
|
|
520
|
+
// because the device signed into the wrong Cloudflare account.
|
|
521
|
+
// Refusal reason `post-flight-fqdn-mismatch` tells the operator to
|
|
522
|
+
// check the dashboard account name and re-login if wrong.
|
|
523
|
+
//
|
|
524
|
+
// Authentication pre-condition is just "cert.pem + binding + they agree" —
|
|
525
|
+
// enforced by validateAuth().bound. No API client is constructed anywhere.
|
|
526
|
+
// ---------------------------------------------------------------------------
|
|
527
|
+
export async function routeDnsCli(tunnelId, hostname) {
|
|
528
|
+
const bin = findBinary();
|
|
529
|
+
if (!bin)
|
|
530
|
+
throw new Error("cloudflared is not installed");
|
|
531
|
+
const auth = validateAuth();
|
|
532
|
+
if (!auth.bound) {
|
|
533
|
+
const reason = auth.hasCert && auth.hasBinding
|
|
534
|
+
? "account-drift"
|
|
535
|
+
: "unbound-device";
|
|
536
|
+
const detail = {
|
|
537
|
+
reason,
|
|
538
|
+
message: `This laptop is not signed into Cloudflare yet${auth.hasCert ? " (sign-in has drifted since it was set up)" : ""}. ` +
|
|
539
|
+
`${DASHBOARD_SWITCH_ACCOUNTS_INSTRUCTION}`,
|
|
540
|
+
fields: {
|
|
541
|
+
boundAccountId: auth.boundAccountId,
|
|
542
|
+
certAccountId: auth.certAccountId,
|
|
543
|
+
requestedHostname: hostname,
|
|
544
|
+
},
|
|
545
|
+
};
|
|
546
|
+
logRefuse(detail);
|
|
547
|
+
throw new CloudflareRefusalError(detail);
|
|
548
|
+
}
|
|
549
|
+
// (1) Pre-flight zone-parent routability.
|
|
550
|
+
console.error(`[cloudflare:tunnel-add-hostname:preflight] hostname=${hostname}`);
|
|
551
|
+
const preflight = await checkZoneParentOnCloudflare(hostname);
|
|
552
|
+
if (!preflight.onCloudflare) {
|
|
553
|
+
const detail = {
|
|
554
|
+
reason: "hostname-zone-not-routable",
|
|
555
|
+
message: `The domain ${preflight.zoneParent} is not on Cloudflare yet — this laptop cannot ` +
|
|
556
|
+
`reach it. Open Cloudflare in your browser and add ${preflight.zoneParent} under the ` +
|
|
557
|
+
`Cloudflare account you want to use (Websites → Add a site). When the domain shows as ` +
|
|
558
|
+
`Active, tell me and I will add the address again.`,
|
|
559
|
+
fields: {
|
|
560
|
+
requestedHostname: hostname,
|
|
561
|
+
requestedDomain: preflight.zoneParent,
|
|
562
|
+
},
|
|
563
|
+
};
|
|
564
|
+
logRefuse(detail);
|
|
565
|
+
throw new CloudflareRefusalError(detail);
|
|
566
|
+
}
|
|
567
|
+
const cert = findCert();
|
|
568
|
+
if (!cert)
|
|
569
|
+
throw new Error("No cert.pem found — validateAuth() should have refused first");
|
|
570
|
+
let output;
|
|
571
|
+
try {
|
|
572
|
+
output = execFileSync(bin, ["tunnel", "--origincert", cert, "route", "dns", "--overwrite-dns", tunnelId, hostname], { encoding: "utf-8", timeout: 30000 });
|
|
573
|
+
}
|
|
574
|
+
catch (err) {
|
|
575
|
+
const errObj = err;
|
|
576
|
+
const rawStderr = errObj.stderr;
|
|
577
|
+
const stderrMsg = typeof rawStderr === "string"
|
|
578
|
+
? rawStderr
|
|
579
|
+
: Buffer.isBuffer(rawStderr) ? rawStderr.toString("utf-8") : "";
|
|
580
|
+
const msg = stderrMsg || errObj.message || String(err);
|
|
581
|
+
if (msg.includes("already exists")) {
|
|
582
|
+
console.error(`[tunnel-route-dns] WARNING: ${hostname} "already exists" despite --overwrite-dns: ${msg}`);
|
|
583
|
+
return { created: false, output: msg, fqdn: hostname };
|
|
584
|
+
}
|
|
585
|
+
throw new Error(`cloudflared tunnel route dns failed: ${msg}`);
|
|
586
|
+
}
|
|
587
|
+
// (2) Post-flight FQDN assertion.
|
|
588
|
+
const fqdnMatch = output.match(/Added CNAME\s+(\S+?)\s+which will route/);
|
|
589
|
+
if (!fqdnMatch) {
|
|
590
|
+
console.error(`[tunnel-route-dns] WARNING: could not parse CNAME FQDN from cloudflared output — format may have changed. Output: ${output.trim()}`);
|
|
591
|
+
return { created: true, output: output.trim(), fqdn: hostname };
|
|
592
|
+
}
|
|
593
|
+
const actualFqdn = fqdnMatch[1];
|
|
594
|
+
if (actualFqdn !== hostname) {
|
|
595
|
+
// cloudflared wrote the address under a different domain than requested.
|
|
596
|
+
// That means the laptop is signed into a Cloudflare account that does
|
|
597
|
+
// not own the target domain, and `cloudflared` fell through to whichever
|
|
598
|
+
// domain the signed-in account does own. The agent cannot clean this up
|
|
599
|
+
// (no API access by design) — the operator cleans it up in the dashboard.
|
|
600
|
+
console.error(`[cloudflare:post-flight-mismatch] ${JSON.stringify({
|
|
601
|
+
requestedHostname: hostname,
|
|
602
|
+
actualFqdn,
|
|
603
|
+
tunnelId,
|
|
604
|
+
boundAccountId: auth.boundAccountId,
|
|
605
|
+
})}`);
|
|
606
|
+
const detail = {
|
|
607
|
+
reason: "post-flight-fqdn-mismatch",
|
|
608
|
+
message: `Cloudflare created the address under ${actualFqdn} instead of the requested ${hostname}. ` +
|
|
609
|
+
`This laptop is signed into a Cloudflare account that does not own ${registrableParent(hostname)}. ` +
|
|
610
|
+
`Two things to do: (a) open Cloudflare in your browser, sign into the account that does own ` +
|
|
611
|
+
`${registrableParent(hostname)}, and tell me so I can re-login; (b) in the same browser, delete the ` +
|
|
612
|
+
`stray record at ${actualFqdn} from the other account so it does not confuse anything.`,
|
|
613
|
+
fields: {
|
|
614
|
+
requestedHostname: hostname,
|
|
615
|
+
actualFqdn,
|
|
616
|
+
tunnelId,
|
|
617
|
+
boundAccountId: auth.boundAccountId,
|
|
618
|
+
},
|
|
619
|
+
};
|
|
620
|
+
logRefuse(detail);
|
|
621
|
+
throw new CloudflareRefusalError(detail);
|
|
622
|
+
}
|
|
623
|
+
console.error(`[tunnel-route-dns] CLI: routed ${hostname} → tunnel ${tunnelId} (overwrite) fqdn=${actualFqdn}`);
|
|
624
|
+
return { created: true, output: output.trim(), fqdn: actualFqdn };
|
|
625
|
+
}
|
|
626
|
+
// ---------------------------------------------------------------------------
|
|
627
|
+
// tunnel login — spawn `cloudflared tunnel login` and capture the auth URL
|
|
628
|
+
// ---------------------------------------------------------------------------
|
|
629
|
+
function loginStatePath() {
|
|
630
|
+
return join(homedir(), loadBrand().configDir, "cloudflared/login.state");
|
|
631
|
+
}
|
|
632
|
+
function readLoginState() {
|
|
633
|
+
try {
|
|
634
|
+
const p = loginStatePath();
|
|
635
|
+
if (!existsSync(p))
|
|
636
|
+
return null;
|
|
637
|
+
return JSON.parse(readFileSync(p, "utf-8"));
|
|
638
|
+
}
|
|
639
|
+
catch {
|
|
640
|
+
return null;
|
|
641
|
+
}
|
|
642
|
+
}
|
|
643
|
+
function writeLoginState(state) {
|
|
644
|
+
const dir = join(homedir(), loadBrand().configDir, "cloudflared");
|
|
645
|
+
mkdirSync(dir, { recursive: true });
|
|
646
|
+
writeFileSync(loginStatePath(), JSON.stringify(state), "utf-8");
|
|
647
|
+
}
|
|
648
|
+
function clearLoginState() {
|
|
649
|
+
try {
|
|
650
|
+
const p = loginStatePath();
|
|
651
|
+
if (existsSync(p)) {
|
|
652
|
+
writeFileSync(p, "", "utf-8");
|
|
653
|
+
}
|
|
654
|
+
}
|
|
655
|
+
catch {
|
|
656
|
+
// best-effort
|
|
657
|
+
}
|
|
658
|
+
}
|
|
659
|
+
/**
|
|
660
|
+
* Fingerprint emitted by `cloudflared tunnel login` into its log when its
|
|
661
|
+
* browser-launch subcommand cannot reach a display. A plain substring — the
|
|
662
|
+
* cloudflared log format is stable and regex gymnastics would hide the
|
|
663
|
+
* failure mode, not detect it.
|
|
664
|
+
*
|
|
665
|
+
* Critical semantic distinction (Task 545): this marker is a *courtesy*
|
|
666
|
+
* warning — cloudflared attempted `xdg-open` against the argotunnel auth
|
|
667
|
+
* URL, failed, wrote the marker, and then CONTINUED RUNNING. Its local
|
|
668
|
+
* OAuth-callback listener is still alive; a user who opens the URL in any
|
|
669
|
+
* reachable browser can still complete sign-in and cert.pem will still
|
|
670
|
+
* land. Treating the marker as terminal loops the restart path
|
|
671
|
+
* hermetically because the respawn will re-emit the same marker the first
|
|
672
|
+
* time it tries to open a browser. `getLoginStatus` therefore only treats
|
|
673
|
+
* the marker as *advisory* when the PID is alive — liveness + cert are
|
|
674
|
+
* the source of truth for terminal-vs-live, not log content.
|
|
675
|
+
*/
|
|
676
|
+
const BROWSER_LAUNCH_FAILED_MARKER = "Failed to fetch resource";
|
|
677
|
+
function parseLoginLogForBrowserLaunchFailure(logPath, logOffsetBytes) {
|
|
678
|
+
try {
|
|
679
|
+
if (!existsSync(logPath))
|
|
680
|
+
return false;
|
|
681
|
+
// Read as Buffer so the byte offset is honoured exactly — logs are
|
|
682
|
+
// mostly ASCII but using a byte-level slice protects against any
|
|
683
|
+
// future multi-byte content producing a character-vs-byte drift.
|
|
684
|
+
const buf = readFileSync(logPath);
|
|
685
|
+
const sliced = buf.length > logOffsetBytes ? buf.subarray(logOffsetBytes) : Buffer.alloc(0);
|
|
686
|
+
const content = sliced.toString("utf-8");
|
|
687
|
+
return content.includes(BROWSER_LAUNCH_FAILED_MARKER);
|
|
688
|
+
}
|
|
689
|
+
catch (err) {
|
|
690
|
+
console.error(`[cloudflare:tunnel-login:log-parse-error] path=${logPath} err=${err instanceof Error ? err.message : String(err)}`);
|
|
691
|
+
return false;
|
|
692
|
+
}
|
|
693
|
+
}
|
|
694
|
+
export function getLoginStatus() {
|
|
695
|
+
const loginState = readLoginState();
|
|
696
|
+
if (!loginState || !loginState.pid) {
|
|
697
|
+
return { state: "idle" };
|
|
698
|
+
}
|
|
699
|
+
const alive = isProcessAlive(loginState.pid);
|
|
700
|
+
const browserLaunchFailed = parseLoginLogForBrowserLaunchFailure(loginState.logPath, loginState.logOffset ?? 0);
|
|
701
|
+
if (alive) {
|
|
702
|
+
// The OAuth-callback listener is still running. The marker is advisory
|
|
703
|
+
// only — the login flow can still complete if a human opens the URL.
|
|
704
|
+
return { state: "in-progress", loginState, browserLaunchFailed };
|
|
705
|
+
}
|
|
706
|
+
// PID is dead. Cert presence decides terminal state vs TOCTOU-idle.
|
|
707
|
+
if (findCert() !== null) {
|
|
708
|
+
// Upstream (tunnel-login handler) checks cert before calling this, so
|
|
709
|
+
// this branch is only reachable on a TOCTOU race where cert appeared
|
|
710
|
+
// between the top-level check and here. Treat as idle so the handler
|
|
711
|
+
// re-examines from the top on the next call.
|
|
712
|
+
return { state: "idle" };
|
|
713
|
+
}
|
|
714
|
+
// Terminal failure. Reason encodes whether the courtesy marker was
|
|
715
|
+
// emitted during the process's lifetime — useful for post-mortem grep
|
|
716
|
+
// ("did cloudflared try and fail to open the browser before dying?").
|
|
717
|
+
return {
|
|
718
|
+
state: "failed",
|
|
719
|
+
loginState,
|
|
720
|
+
reason: browserLaunchFailed
|
|
721
|
+
? "login-process-exited-with-marker"
|
|
722
|
+
: "login-process-exited-without-cert",
|
|
723
|
+
};
|
|
724
|
+
}
|
|
725
|
+
/**
|
|
726
|
+
* Resolve the spawn env for `cloudflared tunnel login`. `cloudflared`'s
|
|
727
|
+
* first action after printing the auth URL is `xdg-open` against that URL
|
|
728
|
+
* so the operator's browser jumps straight to the Authorize screen. The
|
|
729
|
+
* MCP server's spawn context does not inherit DISPLAY (the chain platform
|
|
730
|
+
* → claude-agent → MCP server drops it along the way), so `xdg-open` has
|
|
731
|
+
* no X display to reach and the courtesy-fetch-resource marker lands in
|
|
732
|
+
* the login log every time.
|
|
733
|
+
*
|
|
734
|
+
* When this brand's Xtigervnc Unix socket is live we plumb DISPLAY
|
|
735
|
+
* explicitly so the browser launch has a chance of succeeding. The display
|
|
736
|
+
* number is per-brand (Task 553): Maxy=:99, Real Agent=:100. Xtigervnc
|
|
737
|
+
* runs `-SecurityTypes None` locally, so XAUTHORITY is not required to
|
|
738
|
+
* connect. When this brand's VNC socket is absent (headless /
|
|
739
|
+
* not-yet-booted / native-mode device) we return null so the caller
|
|
740
|
+
* spawns with the default inherited env, and the new classification
|
|
741
|
+
* (marker alone is non-terminal) keeps the session alive via the
|
|
742
|
+
* advisory path.
|
|
743
|
+
*/
|
|
744
|
+
function vncSpawnEnv() {
|
|
745
|
+
const display = `:${loadBrand().vncDisplay}`;
|
|
746
|
+
const socket = `/tmp/.X11-unix/X${display.slice(1)}`;
|
|
747
|
+
if (!existsSync(socket))
|
|
748
|
+
return null;
|
|
749
|
+
return {
|
|
750
|
+
env: { ...process.env, DISPLAY: display },
|
|
751
|
+
display,
|
|
752
|
+
};
|
|
753
|
+
}
|
|
754
|
+
export function tunnelLogin() {
|
|
755
|
+
const bin = findBinary();
|
|
756
|
+
if (!bin)
|
|
757
|
+
throw new Error("cloudflared is not installed");
|
|
758
|
+
const status = getLoginStatus();
|
|
759
|
+
if (status.state === "in-progress") {
|
|
760
|
+
console.error(`[cloudflare:tunnel-login:waiting] pid=${status.loginState.pid} authUrl=${status.loginState.authUrl}`);
|
|
761
|
+
return Promise.resolve({ authUrl: status.loginState.authUrl, alreadyRunning: true });
|
|
762
|
+
}
|
|
763
|
+
const logDir = join(homedir(), loadBrand().configDir, "logs");
|
|
764
|
+
mkdirSync(logDir, { recursive: true });
|
|
765
|
+
const logPath = join(logDir, "cloudflared-login.log");
|
|
766
|
+
const logFd = openSync(logPath, "a");
|
|
767
|
+
// Record the log's byte size before the spawn writes anything. This is
|
|
768
|
+
// the watermark for any marker parsing: every subsequent call slices
|
|
769
|
+
// the log from this offset forward so historical markers from prior
|
|
770
|
+
// attempts cannot be re-attributed to the new process. Task 545
|
|
771
|
+
// narrowed the marker's role from terminal signal to advisory, so the
|
|
772
|
+
// watermark is no longer load-bearing for loop prevention — but it is
|
|
773
|
+
// still correct for attribution: a new process's courtesy-marker
|
|
774
|
+
// advisory should not count log content written by its predecessor.
|
|
775
|
+
const logOffset = existsSync(logPath) ? statSync(logPath).size : 0;
|
|
776
|
+
const certDir = join(homedir(), loadBrand().configDir, "cloudflared");
|
|
777
|
+
mkdirSync(certDir, { recursive: true });
|
|
778
|
+
const originCert = join(certDir, "cert.pem");
|
|
779
|
+
const vncEnv = vncSpawnEnv();
|
|
780
|
+
const displayField = vncEnv ? vncEnv.display : "inherit";
|
|
781
|
+
console.error(`[cloudflare:tunnel-login:spawn] log=${logPath} origincert=${originCert} ` +
|
|
782
|
+
`log-offset=${logOffset} display=${displayField}`);
|
|
783
|
+
const child = spawn(bin, ["tunnel", "--origincert", originCert, "login"], {
|
|
784
|
+
stdio: ["ignore", logFd, logFd],
|
|
785
|
+
detached: true,
|
|
786
|
+
env: vncEnv?.env,
|
|
787
|
+
});
|
|
788
|
+
child.unref();
|
|
789
|
+
if (!child.pid) {
|
|
790
|
+
throw new Error("Failed to spawn cloudflared tunnel login — no PID returned");
|
|
791
|
+
}
|
|
792
|
+
console.error(`[cloudflare:tunnel-login:spawn] pid=${child.pid}`);
|
|
793
|
+
const urlPattern = /https:\/\/dash\.cloudflare\.com[^\s]*/;
|
|
794
|
+
return new Promise((resolve, reject) => {
|
|
795
|
+
let elapsed = 0;
|
|
796
|
+
const interval = 500;
|
|
797
|
+
const timeout = 15000;
|
|
798
|
+
const poller = setInterval(() => {
|
|
799
|
+
elapsed += interval;
|
|
800
|
+
if (!isProcessAlive(child.pid)) {
|
|
801
|
+
clearInterval(poller);
|
|
802
|
+
console.error(`[cloudflare:tunnel-login:failed] reason=process-exited-before-auth-url pid=${child.pid}`);
|
|
803
|
+
clearLoginState();
|
|
804
|
+
try {
|
|
805
|
+
const output = readFileSync(logPath, "utf-8").slice(-500);
|
|
806
|
+
reject(new Error(`cloudflared exited before producing an auth URL. Last output: ${output}`));
|
|
807
|
+
}
|
|
808
|
+
catch {
|
|
809
|
+
reject(new Error("cloudflared exited before producing an auth URL"));
|
|
810
|
+
}
|
|
811
|
+
return;
|
|
812
|
+
}
|
|
813
|
+
try {
|
|
814
|
+
const content = readFileSync(logPath, "utf-8");
|
|
815
|
+
const match = content.match(urlPattern);
|
|
816
|
+
if (match) {
|
|
817
|
+
clearInterval(poller);
|
|
818
|
+
const authUrl = match[0];
|
|
819
|
+
console.error(`[cloudflare:tunnel-login:waiting] pid=${child.pid} authUrl=${authUrl}`);
|
|
820
|
+
writeLoginState({
|
|
821
|
+
pid: child.pid,
|
|
822
|
+
startedAt: Date.now(),
|
|
823
|
+
authUrl,
|
|
824
|
+
logPath,
|
|
825
|
+
logOffset,
|
|
826
|
+
});
|
|
827
|
+
resolve({ authUrl });
|
|
828
|
+
return;
|
|
829
|
+
}
|
|
830
|
+
}
|
|
831
|
+
catch {
|
|
832
|
+
// log file may not be flushed yet — retry
|
|
833
|
+
}
|
|
834
|
+
if (elapsed >= timeout) {
|
|
835
|
+
clearInterval(poller);
|
|
836
|
+
console.error(`[cloudflare:tunnel-login:failed] reason=auth-url-timeout pid=${child.pid} timeout-ms=${timeout}`);
|
|
837
|
+
try {
|
|
838
|
+
process.kill(child.pid, "SIGTERM");
|
|
839
|
+
}
|
|
840
|
+
catch { /* already gone */ }
|
|
841
|
+
clearLoginState();
|
|
842
|
+
try {
|
|
843
|
+
const output = readFileSync(logPath, "utf-8").slice(-500);
|
|
844
|
+
reject(new Error(`cloudflared did not produce an auth URL within ${timeout / 1000} seconds. Output: ${output}`));
|
|
845
|
+
}
|
|
846
|
+
catch {
|
|
847
|
+
reject(new Error(`cloudflared did not produce an auth URL within ${timeout / 1000} seconds`));
|
|
848
|
+
}
|
|
849
|
+
}
|
|
850
|
+
}, interval);
|
|
851
|
+
});
|
|
852
|
+
}
|
|
853
|
+
// ---------------------------------------------------------------------------
|
|
854
|
+
// Process management — detached, survives MCP server exit
|
|
855
|
+
// ---------------------------------------------------------------------------
|
|
856
|
+
function statePath() {
|
|
857
|
+
return join(homedir(), loadBrand().configDir, "cloudflared/tunnel.state");
|
|
858
|
+
}
|
|
859
|
+
function readState() {
|
|
860
|
+
try {
|
|
861
|
+
const p = statePath();
|
|
862
|
+
if (!existsSync(p))
|
|
863
|
+
return null;
|
|
864
|
+
return JSON.parse(readFileSync(p, "utf-8"));
|
|
865
|
+
}
|
|
866
|
+
catch {
|
|
867
|
+
return null;
|
|
868
|
+
}
|
|
869
|
+
}
|
|
870
|
+
function writeState(state) {
|
|
871
|
+
const dir = join(homedir(), loadBrand().configDir, "cloudflared");
|
|
872
|
+
mkdirSync(dir, { recursive: true });
|
|
873
|
+
writeFileSync(statePath(), JSON.stringify(state), "utf-8");
|
|
874
|
+
}
|
|
875
|
+
function isProcessAlive(pid) {
|
|
876
|
+
if (pid === null || pid <= 0)
|
|
877
|
+
return false;
|
|
878
|
+
try {
|
|
879
|
+
process.kill(pid, 0);
|
|
880
|
+
return true;
|
|
881
|
+
}
|
|
882
|
+
catch {
|
|
883
|
+
return false;
|
|
884
|
+
}
|
|
885
|
+
}
|
|
886
|
+
export function getPersistedTunnelId() {
|
|
887
|
+
return readState()?.tunnelId ?? null;
|
|
888
|
+
}
|
|
889
|
+
export function getPersistedDomain() {
|
|
890
|
+
return readState()?.domain ?? null;
|
|
891
|
+
}
|
|
892
|
+
export function getPersistedState() {
|
|
893
|
+
return readState();
|
|
894
|
+
}
|
|
895
|
+
export function saveTunnelIdentity(params) {
|
|
896
|
+
writeState({
|
|
897
|
+
tunnelId: params.tunnelId,
|
|
898
|
+
tunnelName: params.tunnelName,
|
|
899
|
+
domain: params.domain,
|
|
900
|
+
configPath: params.configPath,
|
|
901
|
+
credentialsPath: params.credentialsPath,
|
|
902
|
+
adminHostname: params.adminHostname,
|
|
903
|
+
publicHostname: params.publicHostname,
|
|
904
|
+
pid: null,
|
|
905
|
+
startedAt: null,
|
|
906
|
+
});
|
|
907
|
+
}
|
|
908
|
+
/**
|
|
909
|
+
* Return the actual hostnames from persisted state (or derive from domain
|
|
910
|
+
* for pre-521 state files).
|
|
911
|
+
*/
|
|
912
|
+
export function getPersistedHostnames() {
|
|
913
|
+
const state = readState();
|
|
914
|
+
if (!state)
|
|
915
|
+
return [];
|
|
916
|
+
if (state.adminHostname) {
|
|
917
|
+
return state.publicHostname
|
|
918
|
+
? [state.adminHostname, state.publicHostname]
|
|
919
|
+
: [state.adminHostname];
|
|
920
|
+
}
|
|
921
|
+
if (state.domain) {
|
|
922
|
+
console.error(`[tunnel] backward-compat: deriving hostnames from domain=${state.domain} (no adminHostname in state)`);
|
|
923
|
+
return [`admin.${state.domain}`, `public.${state.domain}`];
|
|
924
|
+
}
|
|
925
|
+
return [];
|
|
926
|
+
}
|
|
927
|
+
export async function probeHostname(hostname, expectedTunnelId) {
|
|
928
|
+
const resolver = new Resolver();
|
|
929
|
+
resolver.setServers(["1.1.1.1", "8.8.8.8"]);
|
|
930
|
+
let cname = null;
|
|
931
|
+
try {
|
|
932
|
+
const cnames = await resolver.resolveCname(hostname);
|
|
933
|
+
cname = cnames[0] ?? null;
|
|
934
|
+
}
|
|
935
|
+
catch (err) {
|
|
936
|
+
const code = err.code;
|
|
937
|
+
if (code === "ENODATA") {
|
|
938
|
+
// Proxied records can flatten — try A records as a secondary signal
|
|
939
|
+
// that the name exists, but without a CNAME we cannot confirm this
|
|
940
|
+
// tunnel. Treat as cname-points-elsewhere (name exists but does not
|
|
941
|
+
// point here) only when an A record is present; otherwise dns-missing.
|
|
942
|
+
try {
|
|
943
|
+
await resolver.resolve4(hostname);
|
|
944
|
+
cname = null; // flattened — still need edge probe to confirm
|
|
945
|
+
}
|
|
946
|
+
catch {
|
|
947
|
+
return { hostname, resolves: false, cname: null, httpStatus: null, failureMode: "dns-missing" };
|
|
948
|
+
}
|
|
949
|
+
}
|
|
950
|
+
else if (code === "ENOTFOUND" || code === "ESERVFAIL") {
|
|
951
|
+
return { hostname, resolves: false, cname: null, httpStatus: null, failureMode: "dns-missing" };
|
|
952
|
+
}
|
|
953
|
+
else {
|
|
954
|
+
console.error(`[cloudflare:tunnel-status:probe] unexpected DNS error for ${hostname}: ${err}`);
|
|
955
|
+
return { hostname, resolves: false, cname: null, httpStatus: null, failureMode: "dns-missing" };
|
|
956
|
+
}
|
|
957
|
+
}
|
|
958
|
+
if (expectedTunnelId && cname) {
|
|
959
|
+
const cnameLc = cname.toLowerCase().replace(/\.$/, "");
|
|
960
|
+
const expected = `${expectedTunnelId}.cfargotunnel.com`.toLowerCase();
|
|
961
|
+
if (cnameLc !== expected) {
|
|
962
|
+
return { hostname, resolves: true, cname, httpStatus: null, failureMode: "cname-points-elsewhere" };
|
|
963
|
+
}
|
|
964
|
+
}
|
|
965
|
+
// HTTPS probe — any response proves edge routing is wired up.
|
|
966
|
+
let httpStatus = null;
|
|
967
|
+
try {
|
|
968
|
+
const controller = new AbortController();
|
|
969
|
+
const to = setTimeout(() => controller.abort(), 10000);
|
|
970
|
+
try {
|
|
971
|
+
const res = await fetch(`https://${hostname}/`, {
|
|
972
|
+
method: "GET",
|
|
973
|
+
redirect: "manual",
|
|
974
|
+
signal: controller.signal,
|
|
975
|
+
});
|
|
976
|
+
httpStatus = res.status;
|
|
977
|
+
}
|
|
978
|
+
finally {
|
|
979
|
+
clearTimeout(to);
|
|
980
|
+
}
|
|
981
|
+
}
|
|
982
|
+
catch (err) {
|
|
983
|
+
console.error(`[cloudflare:tunnel-status:probe] HTTPS probe failed for ${hostname}: ${err instanceof Error ? err.message : String(err)}`);
|
|
984
|
+
return { hostname, resolves: true, cname, httpStatus: null, failureMode: "edge-unreachable" };
|
|
985
|
+
}
|
|
986
|
+
// Cloudflare edge error page status codes that indicate the tunnel is
|
|
987
|
+
// either not connected (530) or the hostname is not served by any tunnel
|
|
988
|
+
// (1033/1016 surface as 530 or 502 at the HTTP layer; Cloudflare sometimes
|
|
989
|
+
// uses 502/503 for unreachable origins). Any 5xx from the edge with
|
|
990
|
+
// missing CNAME match means the tunnel-edge wiring is wrong.
|
|
991
|
+
if (httpStatus >= 500 && httpStatus < 600) {
|
|
992
|
+
return { hostname, resolves: true, cname, httpStatus, failureMode: "tunnel-not-matched" };
|
|
993
|
+
}
|
|
994
|
+
return { hostname, resolves: true, cname, httpStatus, failureMode: "ok" };
|
|
995
|
+
}
|
|
996
|
+
export async function getStatus(domain) {
|
|
997
|
+
const auth = validateAuth();
|
|
998
|
+
const state = readState();
|
|
999
|
+
const running = state !== null && isProcessAlive(state.pid);
|
|
1000
|
+
const effectiveDomain = domain ?? state?.domain ?? null;
|
|
1001
|
+
const persistedHostnames = getPersistedHostnames();
|
|
1002
|
+
const configuredHostnames = state?.configPath
|
|
1003
|
+
? parseConfiguredHostnames(state.configPath)
|
|
1004
|
+
: [];
|
|
1005
|
+
// Probe the authoritative set (config.yml). If config.yml is absent, fall
|
|
1006
|
+
// back to persisted hostnames so partial-setup states still surface.
|
|
1007
|
+
const hostnamesToProbe = configuredHostnames.length > 0
|
|
1008
|
+
? configuredHostnames
|
|
1009
|
+
: persistedHostnames;
|
|
1010
|
+
let probes = [];
|
|
1011
|
+
let boundAccountOwnsHostnames = false;
|
|
1012
|
+
let healthy = false;
|
|
1013
|
+
let unhealthyReason = null;
|
|
1014
|
+
if (!running || !state?.tunnelId || hostnamesToProbe.length === 0) {
|
|
1015
|
+
unhealthyReason = !running
|
|
1016
|
+
? "not-running"
|
|
1017
|
+
: "no-tunnel-configured";
|
|
1018
|
+
}
|
|
1019
|
+
else {
|
|
1020
|
+
probes = await Promise.all(hostnamesToProbe.map((h) => probeHostname(h, state.tunnelId)));
|
|
1021
|
+
// A probe reaching the edge with a non-5xx response proves the signed-in
|
|
1022
|
+
// account owns the domain: the edge only routes to this tunnel's origin
|
|
1023
|
+
// when the domain's DNS on this account points at this tunnel. The CNAME
|
|
1024
|
+
// check inside probeHostname already short-circuits the "points to a
|
|
1025
|
+
// different tunnel" case to `cname-points-elsewhere` — so here we trust
|
|
1026
|
+
// `ok`. We do not gate on `p.cname !== null` because Cloudflare can flatten
|
|
1027
|
+
// CNAMEs (zone-apex records, some proxy configurations) — in that case
|
|
1028
|
+
// cname is null but the HTTPS response is still authoritative.
|
|
1029
|
+
boundAccountOwnsHostnames = probes.some((p) => p.failureMode === "ok");
|
|
1030
|
+
healthy = probes.every((p) => p.failureMode === "ok");
|
|
1031
|
+
if (!healthy) {
|
|
1032
|
+
// Distinguishing "wrong account" from "right account, tunnel broken":
|
|
1033
|
+
// a probe that resolved DNS at all is evidence the domain lives on
|
|
1034
|
+
// some Cloudflare account (the NS is Cloudflare's). A probe that
|
|
1035
|
+
// resolved AND doesn't point elsewhere is evidence this laptop's
|
|
1036
|
+
// account owns it — any other failure mode (edge-unreachable,
|
|
1037
|
+
// tunnel-not-matched, or a healthy flattened probe) indicates the
|
|
1038
|
+
// DNS points at *something* on the signed-in account, just not
|
|
1039
|
+
// working. Only when every probe is `dns-missing` or
|
|
1040
|
+
// `cname-points-elsewhere` do we conclude the bound account does
|
|
1041
|
+
// not own the hostnames.
|
|
1042
|
+
const anyCnamePointsHere = probes.some((p) => p.resolves &&
|
|
1043
|
+
p.failureMode !== "cname-points-elsewhere" &&
|
|
1044
|
+
p.failureMode !== "dns-missing");
|
|
1045
|
+
unhealthyReason = anyCnamePointsHere
|
|
1046
|
+
? "hostname-probes-failed"
|
|
1047
|
+
: "bound-account-does-not-own-hostname";
|
|
1048
|
+
}
|
|
1049
|
+
}
|
|
1050
|
+
if (unhealthyReason === "bound-account-does-not-own-hostname") {
|
|
1051
|
+
// Surface the structured refusal reason — same channel the
|
|
1052
|
+
// agent-facing text uses, but keyed on the enum.
|
|
1053
|
+
logRefuse({
|
|
1054
|
+
reason: "bound-account-does-not-own-hostname",
|
|
1055
|
+
message: "tunnel-status probe: no configured hostname's DNS lands on this tunnel. " +
|
|
1056
|
+
`${DASHBOARD_SWITCH_ACCOUNTS_INSTRUCTION}`,
|
|
1057
|
+
fields: {
|
|
1058
|
+
boundAccountId: auth.boundAccountId,
|
|
1059
|
+
certAccountId: auth.certAccountId,
|
|
1060
|
+
tunnelId: state?.tunnelId ?? undefined,
|
|
1061
|
+
},
|
|
1062
|
+
});
|
|
1063
|
+
}
|
|
1064
|
+
// Single-line branch-selection observability. The handler's trailing text
|
|
1065
|
+
// is driven off unhealthyReason + per-hostname failureMode; logging the
|
|
1066
|
+
// enum here means the branch taken is post-diagnosable from MCP stderr
|
|
1067
|
+
// without having to parse the returned JSON.
|
|
1068
|
+
console.error(`[cloudflare:tunnel-status:result] reason=${unhealthyReason ?? "healthy"} ` +
|
|
1069
|
+
`boundAccountOwnsHostnames=${boundAccountOwnsHostnames} ` +
|
|
1070
|
+
`probes=${probes.map((p) => `${p.hostname}:${p.failureMode}`).join(",") || "none"}`);
|
|
1071
|
+
return {
|
|
1072
|
+
installed: isInstalled(),
|
|
1073
|
+
version: version(),
|
|
1074
|
+
hasCert: auth.hasCert,
|
|
1075
|
+
hasBinding: auth.hasBinding,
|
|
1076
|
+
bound: auth.bound,
|
|
1077
|
+
certAccountId: auth.certAccountId,
|
|
1078
|
+
boundAccountId: auth.boundAccountId,
|
|
1079
|
+
running,
|
|
1080
|
+
pid: running ? state.pid : null,
|
|
1081
|
+
tunnelId: state?.tunnelId ?? null,
|
|
1082
|
+
domain: effectiveDomain,
|
|
1083
|
+
configuredHostnames,
|
|
1084
|
+
persistedHostnames,
|
|
1085
|
+
adminHostname: state?.adminHostname ?? (effectiveDomain ? `admin.${effectiveDomain}` : null),
|
|
1086
|
+
publicHostname: state?.publicHostname ?? (effectiveDomain ? `public.${effectiveDomain}` : null),
|
|
1087
|
+
upSince: running ? state.startedAt : null,
|
|
1088
|
+
probes,
|
|
1089
|
+
boundAccountOwnsHostnames,
|
|
1090
|
+
healthy,
|
|
1091
|
+
unhealthyReason,
|
|
1092
|
+
};
|
|
1093
|
+
}
|
|
1094
|
+
export function startTunnel(params) {
|
|
1095
|
+
const bin = findBinary();
|
|
1096
|
+
if (!bin)
|
|
1097
|
+
throw new Error("cloudflared is not installed");
|
|
1098
|
+
const cert = findCert();
|
|
1099
|
+
if (!cert)
|
|
1100
|
+
throw new Error("No cert.pem found — run tunnel-login first");
|
|
1101
|
+
const state = readState();
|
|
1102
|
+
if (state && isProcessAlive(state.pid)) {
|
|
1103
|
+
throw new Error(`Tunnel is already running (PID ${state.pid})`);
|
|
1104
|
+
}
|
|
1105
|
+
const logDir = join(homedir(), loadBrand().configDir, "logs");
|
|
1106
|
+
mkdirSync(logDir, { recursive: true });
|
|
1107
|
+
const logPath = join(logDir, "cloudflared.log");
|
|
1108
|
+
const logFd = openSync(logPath, "a");
|
|
1109
|
+
const child = spawn(bin, ["--origincert", cert, "--config", params.configPath, "tunnel", "run"], {
|
|
1110
|
+
stdio: ["ignore", logFd, logFd],
|
|
1111
|
+
detached: true,
|
|
1112
|
+
});
|
|
1113
|
+
child.unref();
|
|
1114
|
+
if (!child.pid)
|
|
1115
|
+
throw new Error("Failed to spawn tunnel process");
|
|
1116
|
+
console.error(`[tunnel-enable] started PID ${child.pid} with config ${params.configPath}`);
|
|
1117
|
+
const existingState = readState();
|
|
1118
|
+
writeState({
|
|
1119
|
+
pid: child.pid,
|
|
1120
|
+
tunnelId: params.tunnelId,
|
|
1121
|
+
tunnelName: params.tunnelName,
|
|
1122
|
+
domain: params.domain,
|
|
1123
|
+
configPath: params.configPath,
|
|
1124
|
+
credentialsPath: params.credentialsPath,
|
|
1125
|
+
adminHostname: existingState?.adminHostname ?? null,
|
|
1126
|
+
publicHostname: existingState?.publicHostname ?? null,
|
|
1127
|
+
startedAt: Date.now(),
|
|
1128
|
+
});
|
|
1129
|
+
}
|
|
1130
|
+
export function stopTunnel() {
|
|
1131
|
+
const state = readState();
|
|
1132
|
+
if (!state)
|
|
1133
|
+
return;
|
|
1134
|
+
const pid = state.pid;
|
|
1135
|
+
if (pid !== null && isProcessAlive(pid)) {
|
|
1136
|
+
try {
|
|
1137
|
+
process.kill(pid, "SIGTERM");
|
|
1138
|
+
}
|
|
1139
|
+
catch {
|
|
1140
|
+
// process may have exited between check and kill
|
|
1141
|
+
}
|
|
1142
|
+
setTimeout(() => {
|
|
1143
|
+
if (isProcessAlive(pid)) {
|
|
1144
|
+
try {
|
|
1145
|
+
process.kill(pid, "SIGKILL");
|
|
1146
|
+
}
|
|
1147
|
+
catch {
|
|
1148
|
+
/* already gone */
|
|
1149
|
+
}
|
|
1150
|
+
}
|
|
1151
|
+
}, 5000);
|
|
1152
|
+
}
|
|
1153
|
+
writeState({ ...state, pid: null, startedAt: null });
|
|
1154
|
+
}
|
|
1155
|
+
//# sourceMappingURL=cloudflared.js.map
|