@steno-ai/mcp 0.1.3 → 0.1.4
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/cli.js +830 -921
- package/package.json +3 -5
- package/src/cli.ts +10 -46
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@steno-ai/mcp",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.4",
|
|
4
4
|
"description": "MCP server for Claude Code, Claude Desktop, and other MCP clients",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -26,10 +26,8 @@
|
|
|
26
26
|
},
|
|
27
27
|
"dependencies": {
|
|
28
28
|
"@modelcontextprotocol/sdk": "^1",
|
|
29
|
-
"@
|
|
30
|
-
"
|
|
31
|
-
"@steno-ai/supabase-adapter": "workspace:*",
|
|
32
|
-
"@steno-ai/openai-adapter": "workspace:*",
|
|
29
|
+
"@supabase/supabase-js": "^2.49.0",
|
|
30
|
+
"openai": "^4.0.0",
|
|
33
31
|
"zod": "^3.25"
|
|
34
32
|
},
|
|
35
33
|
"devDependencies": {
|
package/src/cli.ts
CHANGED
|
@@ -1,16 +1,13 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
/**
|
|
3
3
|
* Standalone Steno MCP server — installable via npx @steno-ai/mcp
|
|
4
|
-
*
|
|
5
|
-
* Required env vars:
|
|
6
|
-
* SUPABASE_URL, SUPABASE_SERVICE_ROLE_KEY, OPENAI_API_KEY
|
|
7
|
-
*
|
|
8
|
-
* Optional:
|
|
9
|
-
* PERPLEXITY_API_KEY (cheaper embeddings)
|
|
10
|
-
* STENO_SCOPE_ID (default: "default")
|
|
4
|
+
* Everything is bundled — no npm dependencies needed at runtime.
|
|
11
5
|
*/
|
|
12
6
|
import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
|
|
13
7
|
import { createLocalServer } from './local-server.js';
|
|
8
|
+
import { createSupabaseClient, SupabaseStorageAdapter } from '../../supabase-adapter/src/index.js';
|
|
9
|
+
import { OpenAILLMAdapter, OpenAIEmbeddingAdapter } from '../../openai-adapter/src/index.js';
|
|
10
|
+
import { PerplexityEmbeddingAdapter } from '../../engine/src/adapters/perplexity-embedding.js';
|
|
14
11
|
|
|
15
12
|
async function main(): Promise<void> {
|
|
16
13
|
const supabaseUrl = process.env.SUPABASE_URL;
|
|
@@ -26,23 +23,6 @@ async function main(): Promise<void> {
|
|
|
26
23
|
process.exit(1);
|
|
27
24
|
}
|
|
28
25
|
|
|
29
|
-
// Dynamic imports — these resolve from npm packages when installed standalone
|
|
30
|
-
let createSupabaseClient: any, SupabaseStorageAdapter: any, OpenAILLMAdapter: any;
|
|
31
|
-
try {
|
|
32
|
-
const supa = await import('@steno-ai/supabase-adapter');
|
|
33
|
-
createSupabaseClient = supa.createSupabaseClient;
|
|
34
|
-
SupabaseStorageAdapter = supa.SupabaseStorageAdapter;
|
|
35
|
-
const oai = await import('@steno-ai/openai-adapter');
|
|
36
|
-
OpenAILLMAdapter = oai.OpenAILLMAdapter;
|
|
37
|
-
} catch {
|
|
38
|
-
// Fallback to relative imports (monorepo dev)
|
|
39
|
-
const supa = await import('../../supabase-adapter/src/index.js');
|
|
40
|
-
createSupabaseClient = supa.createSupabaseClient;
|
|
41
|
-
SupabaseStorageAdapter = supa.SupabaseStorageAdapter;
|
|
42
|
-
const oai = await import('../../openai-adapter/src/index.js');
|
|
43
|
-
OpenAILLMAdapter = oai.OpenAILLMAdapter;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
26
|
const supabase = createSupabaseClient({ url: supabaseUrl, serviceRoleKey: supabaseKey });
|
|
47
27
|
const storage = new SupabaseStorageAdapter(supabase);
|
|
48
28
|
const cheapLLM = new OpenAILLMAdapter({ apiKey: openaiKey, model: 'gpt-5.4-mini' });
|
|
@@ -52,31 +32,15 @@ async function main(): Promise<void> {
|
|
|
52
32
|
let embeddingDim: number;
|
|
53
33
|
|
|
54
34
|
if (process.env.PERPLEXITY_API_KEY) {
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
dimensions: 2000,
|
|
61
|
-
});
|
|
62
|
-
} catch {
|
|
63
|
-
const { PerplexityEmbeddingAdapter } = await import('../../engine/src/adapters/perplexity-embedding.js');
|
|
64
|
-
embedding = new PerplexityEmbeddingAdapter({
|
|
65
|
-
apiKey: process.env.PERPLEXITY_API_KEY,
|
|
66
|
-
model: 'pplx-embed-v1-4b',
|
|
67
|
-
dimensions: 2000,
|
|
68
|
-
});
|
|
69
|
-
}
|
|
35
|
+
embedding = new PerplexityEmbeddingAdapter({
|
|
36
|
+
apiKey: process.env.PERPLEXITY_API_KEY,
|
|
37
|
+
model: 'pplx-embed-v1-4b',
|
|
38
|
+
dimensions: 2000,
|
|
39
|
+
});
|
|
70
40
|
embeddingModel = 'pplx-embed-v1-4b';
|
|
71
41
|
embeddingDim = 2000;
|
|
72
42
|
} else {
|
|
73
|
-
|
|
74
|
-
const { OpenAIEmbeddingAdapter } = await import('@steno-ai/openai-adapter');
|
|
75
|
-
embedding = new OpenAIEmbeddingAdapter({ apiKey: openaiKey, model: 'text-embedding-3-large', dimensions: 3072 });
|
|
76
|
-
} catch {
|
|
77
|
-
const { OpenAIEmbeddingAdapter } = await import('../../openai-adapter/src/index.js');
|
|
78
|
-
embedding = new OpenAIEmbeddingAdapter({ apiKey: openaiKey, model: 'text-embedding-3-large', dimensions: 3072 });
|
|
79
|
-
}
|
|
43
|
+
embedding = new OpenAIEmbeddingAdapter({ apiKey: openaiKey, model: 'text-embedding-3-large', dimensions: 3072 });
|
|
80
44
|
embeddingModel = 'text-embedding-3-large';
|
|
81
45
|
embeddingDim = 3072;
|
|
82
46
|
}
|