@hailer/mcp 1.1.11 → 1.1.13
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/app.js +18 -5
- package/dist/bot/bot-config.d.ts +12 -1
- package/dist/bot/bot-config.js +98 -14
- package/dist/bot/bot-manager.d.ts +13 -3
- package/dist/bot/bot-manager.js +80 -25
- package/dist/bot/bot.d.ts +46 -0
- package/dist/bot/bot.js +542 -166
- package/dist/bot/services/message-classifier.js +17 -0
- package/dist/bot/services/permission-guard.d.ts +52 -0
- package/dist/bot/services/permission-guard.js +149 -0
- package/dist/bot/services/types.d.ts +5 -0
- package/dist/bot/services/typing-indicator.d.ts +6 -1
- package/dist/bot/services/typing-indicator.js +19 -3
- package/dist/config.d.ts +6 -1
- package/dist/config.js +43 -0
- package/dist/core.js +3 -6
- package/dist/mcp/UserContextCache.d.ts +5 -0
- package/dist/mcp/UserContextCache.js +51 -19
- package/dist/mcp/hailer-clients.d.ts +19 -1
- package/dist/mcp/hailer-clients.js +157 -20
- package/dist/mcp/session-store.d.ts +68 -0
- package/dist/mcp/session-store.js +169 -0
- package/dist/mcp/signal-handler.js +12 -12
- package/dist/mcp/tool-registry.d.ts +17 -4
- package/dist/mcp/tool-registry.js +37 -7
- package/dist/mcp/tools/activity.js +99 -7
- package/dist/mcp/tools/app-scaffold.js +304 -336
- package/dist/mcp/tools/company.d.ts +9 -0
- package/dist/mcp/tools/company.js +88 -0
- package/dist/mcp/tools/discussion.js +68 -0
- package/dist/mcp/tools/workflow-permissions.d.ts +15 -0
- package/dist/mcp/tools/workflow-permissions.js +204 -0
- package/dist/mcp/tools/workflow.js +57 -18
- package/dist/mcp/utils/index.d.ts +2 -0
- package/dist/mcp/utils/index.js +12 -1
- package/dist/mcp/utils/role-utils.d.ts +74 -0
- package/dist/mcp/utils/role-utils.js +151 -0
- package/dist/mcp/utils/types.d.ts +43 -1
- package/dist/mcp/utils/types.js +14 -0
- package/dist/mcp/webhook-handler.d.ts +6 -0
- package/dist/mcp/webhook-handler.js +11 -0
- package/dist/mcp-server.d.ts +23 -2
- package/dist/mcp-server.js +639 -111
- package/dist/plugins/vipunen/client.d.ts +150 -0
- package/dist/plugins/vipunen/client.js +535 -0
- package/dist/plugins/vipunen/config/schema-config.json +19 -0
- package/dist/plugins/vipunen/config/schema-doc.json +22 -0
- package/dist/plugins/vipunen/index.d.ts +41 -0
- package/dist/plugins/vipunen/index.js +88 -0
- package/dist/plugins/vipunen/tools.d.ts +26 -0
- package/dist/plugins/vipunen/tools.js +501 -0
- package/package.json +2 -1
- package/.claude/.context-watchdog.json +0 -1
- package/.claude/.session-checked +0 -1
- package/.claude/CLAUDE.md +0 -370
- package/.claude/agents/agent-ada-skill-builder.md +0 -94
- package/.claude/agents/agent-alejandro-function-fields.md +0 -342
- package/.claude/agents/agent-bjorn-config-audit.md +0 -103
- package/.claude/agents/agent-builder-agent-creator.md +0 -130
- package/.claude/agents/agent-code-simplifier.md +0 -53
- package/.claude/agents/agent-dmitri-activity-crud.md +0 -159
- package/.claude/agents/agent-giuseppe-app-builder.md +0 -247
- package/.claude/agents/agent-gunther-mcp-tools.md +0 -39
- package/.claude/agents/agent-helga-workflow-config.md +0 -204
- package/.claude/agents/agent-igor-activity-mover-automation.md +0 -125
- package/.claude/agents/agent-ingrid-doc-templates.md +0 -261
- package/.claude/agents/agent-ivan-monolith.md +0 -154
- package/.claude/agents/agent-kenji-data-reader.md +0 -86
- package/.claude/agents/agent-lars-code-inspector.md +0 -102
- package/.claude/agents/agent-marco-mockup-builder.md +0 -110
- package/.claude/agents/agent-marcus-api-documenter.md +0 -323
- package/.claude/agents/agent-marketplace-publisher.md +0 -280
- package/.claude/agents/agent-marketplace-reviewer.md +0 -309
- package/.claude/agents/agent-permissions-handler.md +0 -208
- package/.claude/agents/agent-simple-writer.md +0 -48
- package/.claude/agents/agent-svetlana-code-review.md +0 -171
- package/.claude/agents/agent-tanya-test-runner.md +0 -333
- package/.claude/agents/agent-ui-designer.md +0 -100
- package/.claude/agents/agent-viktor-sql-insights.md +0 -212
- package/.claude/agents/agent-web-search.md +0 -55
- package/.claude/agents/agent-yevgeni-discussions.md +0 -45
- package/.claude/agents/agent-zara-zapier.md +0 -159
- package/.claude/commands/app-squad.md +0 -135
- package/.claude/commands/audit-squad.md +0 -158
- package/.claude/commands/autoplan.md +0 -563
- package/.claude/commands/cleanup-squad.md +0 -98
- package/.claude/commands/config-squad.md +0 -106
- package/.claude/commands/crud-squad.md +0 -87
- package/.claude/commands/data-squad.md +0 -97
- package/.claude/commands/debug-squad.md +0 -303
- package/.claude/commands/doc-squad.md +0 -65
- package/.claude/commands/handoff.md +0 -137
- package/.claude/commands/health.md +0 -49
- package/.claude/commands/help.md +0 -29
- package/.claude/commands/help:agents.md +0 -151
- package/.claude/commands/help:commands.md +0 -78
- package/.claude/commands/help:faq.md +0 -79
- package/.claude/commands/help:plugins.md +0 -50
- package/.claude/commands/help:skills.md +0 -93
- package/.claude/commands/help:tools.md +0 -75
- package/.claude/commands/hotfix-squad.md +0 -112
- package/.claude/commands/integration-squad.md +0 -82
- package/.claude/commands/janitor-squad.md +0 -167
- package/.claude/commands/learn-auto.md +0 -120
- package/.claude/commands/learn.md +0 -120
- package/.claude/commands/mcp-list.md +0 -27
- package/.claude/commands/onboard-squad.md +0 -140
- package/.claude/commands/plan-workspace.md +0 -732
- package/.claude/commands/prd.md +0 -130
- package/.claude/commands/project-status.md +0 -82
- package/.claude/commands/publish.md +0 -138
- package/.claude/commands/recap.md +0 -69
- package/.claude/commands/restore.md +0 -64
- package/.claude/commands/review-squad.md +0 -152
- package/.claude/commands/save.md +0 -24
- package/.claude/commands/stats.md +0 -19
- package/.claude/commands/swarm.md +0 -210
- package/.claude/commands/tool-builder.md +0 -39
- package/.claude/commands/ws-pull.md +0 -44
- package/.claude/hooks/_shared-memory.cjs +0 -305
- package/.claude/hooks/_utils.cjs +0 -108
- package/.claude/hooks/agent-failure-detector.cjs +0 -383
- package/.claude/hooks/agent-usage-logger.cjs +0 -204
- package/.claude/hooks/app-edit-guard.cjs +0 -494
- package/.claude/hooks/auto-learn.cjs +0 -304
- package/.claude/hooks/bash-guard.cjs +0 -272
- package/.claude/hooks/builder-mode-manager.cjs +0 -354
- package/.claude/hooks/bulk-activity-guard.cjs +0 -271
- package/.claude/hooks/context-watchdog.cjs +0 -230
- package/.claude/hooks/delegation-reminder.cjs +0 -465
- package/.claude/hooks/design-system-lint.cjs +0 -271
- package/.claude/hooks/post-scaffold-hook.cjs +0 -181
- package/.claude/hooks/prompt-guard.cjs +0 -354
- package/.claude/hooks/publish-template-guard.cjs +0 -147
- package/.claude/hooks/session-start.cjs +0 -35
- package/.claude/hooks/shared-memory-writer.cjs +0 -147
- package/.claude/hooks/skill-injector.cjs +0 -140
- package/.claude/hooks/skill-usage-logger.cjs +0 -258
- package/.claude/hooks/src-edit-guard.cjs +0 -240
- package/.claude/hooks/sync-marketplace-agents.cjs +0 -346
- package/.claude/settings.json +0 -257
- package/.claude/skills/SDK-activity-patterns/SKILL.md +0 -428
- package/.claude/skills/SDK-document-templates/SKILL.md +0 -1033
- package/.claude/skills/SDK-function-fields/SKILL.md +0 -542
- package/.claude/skills/SDK-generate-skill/SKILL.md +0 -92
- package/.claude/skills/SDK-init-skill/SKILL.md +0 -127
- package/.claude/skills/SDK-insight-queries/SKILL.md +0 -787
- package/.claude/skills/SDK-ws-config-skill/SKILL.md +0 -1139
- package/.claude/skills/agent-structure/SKILL.md +0 -98
- package/.claude/skills/api-documentation-patterns/SKILL.md +0 -474
- package/.claude/skills/chrome-mcp-reference/SKILL.md +0 -370
- package/.claude/skills/delegation-routing/SKILL.md +0 -202
- package/.claude/skills/frontend-design/SKILL.md +0 -254
- package/.claude/skills/hailer-activity-mover/SKILL.md +0 -213
- package/.claude/skills/hailer-api-client/SKILL.md +0 -518
- package/.claude/skills/hailer-app-builder/SKILL.md +0 -1434
- package/.claude/skills/hailer-apps-pictures/SKILL.md +0 -269
- package/.claude/skills/hailer-design-system/SKILL.md +0 -235
- package/.claude/skills/hailer-monolith-automations/SKILL.md +0 -686
- package/.claude/skills/hailer-permissions-system/SKILL.md +0 -121
- package/.claude/skills/hailer-project-protocol/SKILL.md +0 -488
- package/.claude/skills/hailer-rest-api/SKILL.md +0 -61
- package/.claude/skills/hailer-rest-api/hailer-activities.md +0 -184
- package/.claude/skills/hailer-rest-api/hailer-admin.md +0 -473
- package/.claude/skills/hailer-rest-api/hailer-calendar.md +0 -256
- package/.claude/skills/hailer-rest-api/hailer-feed.md +0 -249
- package/.claude/skills/hailer-rest-api/hailer-insights.md +0 -195
- package/.claude/skills/hailer-rest-api/hailer-messaging.md +0 -276
- package/.claude/skills/hailer-rest-api/hailer-workflows.md +0 -283
- package/.claude/skills/insight-join-patterns/SKILL.md +0 -174
- package/.claude/skills/integration-patterns/SKILL.md +0 -421
- package/.claude/skills/json-only-output/SKILL.md +0 -72
- package/.claude/skills/lsp-setup/SKILL.md +0 -160
- package/.claude/skills/mcp-direct-tools/SKILL.md +0 -153
- package/.claude/skills/optional-parameters/SKILL.md +0 -72
- package/.claude/skills/publish-hailer-app/SKILL.md +0 -244
- package/.claude/skills/testing-patterns/SKILL.md +0 -630
- package/.claude/skills/tool-builder/SKILL.md +0 -250
- package/.claude/skills/tool-parameter-usage/SKILL.md +0 -126
- package/.claude/skills/tool-response-verification/SKILL.md +0 -92
- package/.claude/skills/zapier-hailer-patterns/SKILL.md +0 -581
- package/.hailer-mcp-port +0 -1
- package/.mcp.json +0 -13
- package/.opencode/agent/agent-ada-skill-builder.md +0 -35
- package/.opencode/agent/agent-alejandro-function-fields.md +0 -39
- package/.opencode/agent/agent-bjorn-config-audit.md +0 -36
- package/.opencode/agent/agent-builder-agent-creator.md +0 -39
- package/.opencode/agent/agent-code-simplifier.md +0 -31
- package/.opencode/agent/agent-dmitri-activity-crud.md +0 -40
- package/.opencode/agent/agent-giuseppe-app-builder.md +0 -37
- package/.opencode/agent/agent-gunther-mcp-tools.md +0 -39
- package/.opencode/agent/agent-helga-workflow-config.md +0 -204
- package/.opencode/agent/agent-igor-activity-mover-automation.md +0 -46
- package/.opencode/agent/agent-ingrid-doc-templates.md +0 -39
- package/.opencode/agent/agent-ivan-monolith.md +0 -46
- package/.opencode/agent/agent-kenji-data-reader.md +0 -53
- package/.opencode/agent/agent-lars-code-inspector.md +0 -28
- package/.opencode/agent/agent-marco-mockup-builder.md +0 -42
- package/.opencode/agent/agent-marcus-api-documenter.md +0 -53
- package/.opencode/agent/agent-marketplace-publisher.md +0 -44
- package/.opencode/agent/agent-marketplace-reviewer.md +0 -42
- package/.opencode/agent/agent-permissions-handler.md +0 -50
- package/.opencode/agent/agent-simple-writer.md +0 -45
- package/.opencode/agent/agent-svetlana-code-review.md +0 -39
- package/.opencode/agent/agent-tanya-test-runner.md +0 -57
- package/.opencode/agent/agent-ui-designer.md +0 -56
- package/.opencode/agent/agent-viktor-sql-insights.md +0 -34
- package/.opencode/agent/agent-web-search.md +0 -42
- package/.opencode/agent/agent-yevgeni-discussions.md +0 -37
- package/.opencode/agent/agent-zara-zapier.md +0 -53
- package/.opencode/commands/app-squad.md +0 -135
- package/.opencode/commands/audit-squad.md +0 -158
- package/.opencode/commands/autoplan.md +0 -563
- package/.opencode/commands/cleanup-squad.md +0 -98
- package/.opencode/commands/config-squad.md +0 -106
- package/.opencode/commands/crud-squad.md +0 -87
- package/.opencode/commands/data-squad.md +0 -97
- package/.opencode/commands/debug-squad.md +0 -303
- package/.opencode/commands/doc-squad.md +0 -65
- package/.opencode/commands/handoff.md +0 -137
- package/.opencode/commands/health.md +0 -49
- package/.opencode/commands/help-agents.md +0 -151
- package/.opencode/commands/help-commands.md +0 -32
- package/.opencode/commands/help-faq.md +0 -29
- package/.opencode/commands/help-plugins.md +0 -28
- package/.opencode/commands/help-skills.md +0 -7
- package/.opencode/commands/help-tools.md +0 -40
- package/.opencode/commands/help.md +0 -28
- package/.opencode/commands/hotfix-squad.md +0 -112
- package/.opencode/commands/integration-squad.md +0 -82
- package/.opencode/commands/janitor-squad.md +0 -167
- package/.opencode/commands/learn-auto.md +0 -120
- package/.opencode/commands/learn.md +0 -120
- package/.opencode/commands/mcp-list.md +0 -27
- package/.opencode/commands/onboard-squad.md +0 -140
- package/.opencode/commands/plan-workspace.md +0 -732
- package/.opencode/commands/prd.md +0 -131
- package/.opencode/commands/project-status.md +0 -82
- package/.opencode/commands/publish.md +0 -138
- package/.opencode/commands/recap.md +0 -69
- package/.opencode/commands/restore.md +0 -64
- package/.opencode/commands/review-squad.md +0 -152
- package/.opencode/commands/save.md +0 -24
- package/.opencode/commands/stats.md +0 -19
- package/.opencode/commands/swarm.md +0 -210
- package/.opencode/commands/tool-builder.md +0 -39
- package/.opencode/commands/ws-pull.md +0 -44
- package/.opencode/opencode.json +0 -21
- package/inbox/failures.log +0 -1
- package/inbox/usage.jsonl +0 -4
- package/scripts/postinstall.cjs +0 -64
- package/scripts/test-hal-tools.ts +0 -154
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"vectorizer": "none",
|
|
3
|
+
"properties": [
|
|
4
|
+
{ "name": "artifact_type", "dataType": ["text"], "description": "One of: hook, agent, claude-md, pointer, skill" },
|
|
5
|
+
{ "name": "artifact_name", "dataType": ["text"], "description": "Unique artifact identifier" },
|
|
6
|
+
{ "name": "install_tier", "dataType": ["text"], "description": "One of: user, repo" },
|
|
7
|
+
{ "name": "target_path", "dataType": ["text"], "description": "Relative install path from target root" },
|
|
8
|
+
{ "name": "content", "dataType": ["text"], "description": "Complete deployable artifact content" },
|
|
9
|
+
{ "name": "version", "dataType": ["text"], "description": "Semver version of this artifact" },
|
|
10
|
+
{ "name": "dependencies", "dataType": ["text"], "description": "Comma-separated artifact_names this depends on" },
|
|
11
|
+
{ "name": "project_types", "dataType": ["text"], "description": "Comma-separated project types this applies to (empty = all)" },
|
|
12
|
+
{ "name": "placeholders", "dataType": ["text"], "description": "Comma-separated <TOKEN> names in content" },
|
|
13
|
+
{ "name": "description", "dataType": ["text"], "description": "Human-readable summary of this artifact" },
|
|
14
|
+
{ "name": "tags", "dataType": ["text"], "description": "Comma-separated keywords" },
|
|
15
|
+
{ "name": "install_instructions", "dataType": ["text"], "description": "Natural language instructions for Claude: how to install, register, and uninstall this artifact" },
|
|
16
|
+
{ "name": "created_by", "dataType": ["text"], "description": "Identity of creator" },
|
|
17
|
+
{ "name": "verified_by", "dataType": ["text"], "description": "Identity of verifier or null" }
|
|
18
|
+
]
|
|
19
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
{
|
|
2
|
+
"vectorizer": "text2vec-transformers",
|
|
3
|
+
"moduleConfig": {
|
|
4
|
+
"text2vec-transformers": {
|
|
5
|
+
"vectorizeClassName": false
|
|
6
|
+
}
|
|
7
|
+
},
|
|
8
|
+
"properties": [
|
|
9
|
+
{ "name": "scope", "dataType": ["text"], "description": "System or product within this collection", "moduleConfig": { "text2vec-transformers": { "skip": true } } },
|
|
10
|
+
{ "name": "topic", "dataType": ["text"], "description": "Specific aspect within scope", "moduleConfig": { "text2vec-transformers": { "skip": true } } },
|
|
11
|
+
{ "name": "title", "dataType": ["text"], "description": "Descriptive searchable chunk title" },
|
|
12
|
+
{ "name": "content", "dataType": ["text"], "description": "The actual chunk text" },
|
|
13
|
+
{ "name": "source_file", "dataType": ["text"], "description": "Path to original source document", "moduleConfig": { "text2vec-transformers": { "skip": true } } },
|
|
14
|
+
{ "name": "source_section", "dataType": ["text"], "description": "Heading breadcrumb from source", "moduleConfig": { "text2vec-transformers": { "skip": true } } },
|
|
15
|
+
{ "name": "doc_type", "dataType": ["text"], "description": "One of: reference, tutorial, api, conceptual, configuration", "moduleConfig": { "text2vec-transformers": { "skip": true } } },
|
|
16
|
+
{ "name": "tags", "dataType": ["text"], "description": "Comma-separated keywords" },
|
|
17
|
+
{ "name": "chunk_index", "dataType": ["int"], "description": "Position in sequence within topic", "moduleConfig": { "text2vec-transformers": { "skip": true } } },
|
|
18
|
+
{ "name": "total_chunks", "dataType": ["int"], "description": "Total chunks in this topic", "moduleConfig": { "text2vec-transformers": { "skip": true } } },
|
|
19
|
+
{ "name": "created_by", "dataType": ["text"], "description": "Identity of creator (agent name, user ID, or API key alias)", "moduleConfig": { "text2vec-transformers": { "skip": true } } },
|
|
20
|
+
{ "name": "verified_by", "dataType": ["text"], "description": "Identity of verifier (night-owl tier, username) or null", "moduleConfig": { "text2vec-transformers": { "skip": true } } }
|
|
21
|
+
]
|
|
22
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Vipunen Plugin — Weaviate RAG Knowledge Base
|
|
3
|
+
*
|
|
4
|
+
* Provides tools for querying and managing vectorized documentation.
|
|
5
|
+
* Conditionally registered: only active when weaviateHost is provided.
|
|
6
|
+
*
|
|
7
|
+
* Auth model:
|
|
8
|
+
* - Server authenticates to Weaviate with a single WEAVIATE_API_KEY (env var).
|
|
9
|
+
* - Clients authenticate to MCP with their own API keys (VIPUNEN_API_KEYS env var).
|
|
10
|
+
* - Each client key belongs to a group: admin, dev, or readonly.
|
|
11
|
+
* - Groups control what operations and collections are accessible.
|
|
12
|
+
*/
|
|
13
|
+
import { Tool } from '../../mcp/tool-registry';
|
|
14
|
+
import { VipunenGroup, VipunenContext } from './tools';
|
|
15
|
+
export interface VipunenPluginOptions {
|
|
16
|
+
weaviateHost?: string;
|
|
17
|
+
weaviateApiKey?: string;
|
|
18
|
+
vipunenApiKeys?: Record<string, VipunenGroup>;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Register Vipunen tools if weaviateHost is provided.
|
|
22
|
+
* Returns the tools array (empty if not configured).
|
|
23
|
+
*/
|
|
24
|
+
export declare function registerVipunenTools(options?: VipunenPluginOptions): Tool[];
|
|
25
|
+
/**
|
|
26
|
+
* Resolve a client API key to a VipunenContext with group.
|
|
27
|
+
* Throws if the key is not recognized.
|
|
28
|
+
*/
|
|
29
|
+
export declare function resolveVipunenContext(apiKey: string): VipunenContext;
|
|
30
|
+
/**
|
|
31
|
+
* Check if a Vipunen API key is valid (exists in the configured key map).
|
|
32
|
+
*/
|
|
33
|
+
export declare function isValidVipunenKey(apiKey: string): boolean;
|
|
34
|
+
/**
|
|
35
|
+
* Reset plugin state — for tests only.
|
|
36
|
+
*/
|
|
37
|
+
export declare function resetVipunenPlugin(): void;
|
|
38
|
+
export { WeaviateClient, WeaviateAuthError } from './client';
|
|
39
|
+
export { createVipunenTools } from './tools';
|
|
40
|
+
export type { VipunenGroup, VipunenContext } from './tools';
|
|
41
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Vipunen Plugin — Weaviate RAG Knowledge Base
|
|
4
|
+
*
|
|
5
|
+
* Provides tools for querying and managing vectorized documentation.
|
|
6
|
+
* Conditionally registered: only active when weaviateHost is provided.
|
|
7
|
+
*
|
|
8
|
+
* Auth model:
|
|
9
|
+
* - Server authenticates to Weaviate with a single WEAVIATE_API_KEY (env var).
|
|
10
|
+
* - Clients authenticate to MCP with their own API keys (VIPUNEN_API_KEYS env var).
|
|
11
|
+
* - Each client key belongs to a group: admin, dev, or readonly.
|
|
12
|
+
* - Groups control what operations and collections are accessible.
|
|
13
|
+
*/
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.createVipunenTools = exports.WeaviateAuthError = exports.WeaviateClient = void 0;
|
|
16
|
+
exports.registerVipunenTools = registerVipunenTools;
|
|
17
|
+
exports.resolveVipunenContext = resolveVipunenContext;
|
|
18
|
+
exports.isValidVipunenKey = isValidVipunenKey;
|
|
19
|
+
exports.resetVipunenPlugin = resetVipunenPlugin;
|
|
20
|
+
const client_1 = require("./client");
|
|
21
|
+
const tools_1 = require("./tools");
|
|
22
|
+
const logger_1 = require("../../lib/logger");
|
|
23
|
+
const logger = (0, logger_1.createLogger)({ component: 'vipunen-plugin' });
|
|
24
|
+
let activeClient = null;
|
|
25
|
+
let apiKeyMap = {};
|
|
26
|
+
/**
|
|
27
|
+
* Register Vipunen tools if weaviateHost is provided.
|
|
28
|
+
* Returns the tools array (empty if not configured).
|
|
29
|
+
*/
|
|
30
|
+
function registerVipunenTools(options) {
|
|
31
|
+
const host = options?.weaviateHost;
|
|
32
|
+
if (!host) {
|
|
33
|
+
logger.debug('Vipunen plugin not activated (no weaviateHost)');
|
|
34
|
+
return [];
|
|
35
|
+
}
|
|
36
|
+
if (activeClient) {
|
|
37
|
+
throw new Error('Vipunen plugin already registered — call resetVipunenPlugin() before re-registering');
|
|
38
|
+
}
|
|
39
|
+
const client = new client_1.WeaviateClient({
|
|
40
|
+
host,
|
|
41
|
+
apiKey: options?.weaviateApiKey,
|
|
42
|
+
});
|
|
43
|
+
activeClient = client;
|
|
44
|
+
// Store the API key → group mapping (validated by Zod in config.ts)
|
|
45
|
+
apiKeyMap = Object.freeze({ ...(options?.vipunenApiKeys ?? {}) });
|
|
46
|
+
const keyCount = Object.keys(apiKeyMap).length;
|
|
47
|
+
if (keyCount === 0) {
|
|
48
|
+
logger.warn('Vipunen plugin activated with NO client API keys — all requests will be rejected');
|
|
49
|
+
}
|
|
50
|
+
const tools = (0, tools_1.createVipunenTools)(client);
|
|
51
|
+
logger.info('Vipunen plugin activated', {
|
|
52
|
+
toolCount: tools.length,
|
|
53
|
+
tools: tools.map(t => t.name),
|
|
54
|
+
clientKeys: keyCount,
|
|
55
|
+
groups: [...new Set(Object.values(apiKeyMap))],
|
|
56
|
+
});
|
|
57
|
+
return tools;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Resolve a client API key to a VipunenContext with group.
|
|
61
|
+
* Throws if the key is not recognized.
|
|
62
|
+
*/
|
|
63
|
+
function resolveVipunenContext(apiKey) {
|
|
64
|
+
const group = apiKeyMap[apiKey];
|
|
65
|
+
if (!group) {
|
|
66
|
+
throw new Error('Invalid Vipunen API key');
|
|
67
|
+
}
|
|
68
|
+
return { group };
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Check if a Vipunen API key is valid (exists in the configured key map).
|
|
72
|
+
*/
|
|
73
|
+
function isValidVipunenKey(apiKey) {
|
|
74
|
+
return apiKey in apiKeyMap;
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Reset plugin state — for tests only.
|
|
78
|
+
*/
|
|
79
|
+
function resetVipunenPlugin() {
|
|
80
|
+
activeClient = null;
|
|
81
|
+
apiKeyMap = {};
|
|
82
|
+
}
|
|
83
|
+
var client_2 = require("./client");
|
|
84
|
+
Object.defineProperty(exports, "WeaviateClient", { enumerable: true, get: function () { return client_2.WeaviateClient; } });
|
|
85
|
+
Object.defineProperty(exports, "WeaviateAuthError", { enumerable: true, get: function () { return client_2.WeaviateAuthError; } });
|
|
86
|
+
var tools_2 = require("./tools");
|
|
87
|
+
Object.defineProperty(exports, "createVipunenTools", { enumerable: true, get: function () { return tools_2.createVipunenTools; } });
|
|
88
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Vipunen Tools — Weaviate RAG Knowledge Base
|
|
3
|
+
*
|
|
4
|
+
* Tools for querying and managing vectorized documentation in Weaviate.
|
|
5
|
+
* All tools use contextType: 'none' — they don't need Hailer authentication.
|
|
6
|
+
*
|
|
7
|
+
* Auth model:
|
|
8
|
+
* - Server authenticates to Weaviate with a single WEAVIATE_API_KEY
|
|
9
|
+
* - Clients authenticate to MCP with their own API keys (VIPUNEN_API_KEYS)
|
|
10
|
+
* - Each client key belongs to a group: admin, dev, or readonly
|
|
11
|
+
* - Groups control what operations and collections are accessible
|
|
12
|
+
*
|
|
13
|
+
* Permission tiers:
|
|
14
|
+
* - readonly: 5 tools (query, find-similar, list-sources, count, filter)
|
|
15
|
+
* - dev: 8 tools (readonly + insert-one, update-chunks, delete-source) — no VipunenConfig writes
|
|
16
|
+
* - admin: 13 tools (dev + get-schema, export, batch-insert, create-collection, delete-collection)
|
|
17
|
+
*/
|
|
18
|
+
import { Tool } from '../../mcp/tool-registry';
|
|
19
|
+
import { WeaviateClient } from './client';
|
|
20
|
+
export type VipunenGroup = 'admin' | 'dev' | 'readonly';
|
|
21
|
+
/** Execution context passed to each tool — resolved by the plugin from the client's API key */
|
|
22
|
+
export interface VipunenContext {
|
|
23
|
+
group: VipunenGroup;
|
|
24
|
+
}
|
|
25
|
+
export declare function createVipunenTools(client: WeaviateClient): Tool[];
|
|
26
|
+
//# sourceMappingURL=tools.d.ts.map
|