@powerhousedao/reactor-mcp 4.1.0-dev.3 → 4.1.0-dev.31

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.
Files changed (58) hide show
  1. package/dist/src/cli.js +7 -3
  2. package/dist/src/cli.js.map +1 -1
  3. package/dist/src/express.d.ts +5 -0
  4. package/dist/src/express.d.ts.map +1 -0
  5. package/dist/src/express.js +59 -0
  6. package/dist/src/express.js.map +1 -0
  7. package/dist/src/index.d.ts +1 -1
  8. package/dist/src/index.d.ts.map +1 -1
  9. package/dist/src/index.js +1 -10
  10. package/dist/src/index.js.map +1 -1
  11. package/dist/src/logger.d.ts +3 -0
  12. package/dist/src/logger.d.ts.map +1 -0
  13. package/dist/src/logger.js +3 -0
  14. package/dist/src/logger.js.map +1 -0
  15. package/dist/src/sdk/chat.d.ts +19 -0
  16. package/dist/src/sdk/chat.d.ts.map +1 -0
  17. package/dist/src/sdk/chat.js +60 -0
  18. package/dist/src/sdk/chat.js.map +1 -0
  19. package/dist/src/server.d.ts +3 -2
  20. package/dist/src/server.d.ts.map +1 -1
  21. package/dist/src/server.js +38 -762
  22. package/dist/src/server.js.map +1 -1
  23. package/dist/src/stdio/index.d.ts +7 -0
  24. package/dist/src/stdio/index.d.ts.map +1 -0
  25. package/dist/src/stdio/index.js +84 -0
  26. package/dist/src/stdio/index.js.map +1 -0
  27. package/dist/src/stdio/loader.d.ts +18 -0
  28. package/dist/src/stdio/loader.d.ts.map +1 -0
  29. package/dist/src/stdio/loader.js +86 -0
  30. package/dist/src/stdio/loader.js.map +1 -0
  31. package/dist/src/tools/reactor.d.ts +847 -0
  32. package/dist/src/tools/reactor.d.ts.map +1 -0
  33. package/dist/src/{mcp → tools}/reactor.js +200 -146
  34. package/dist/src/tools/reactor.js.map +1 -0
  35. package/dist/src/tools/types.d.ts.map +1 -0
  36. package/dist/src/{mcp → tools}/types.js.map +1 -1
  37. package/dist/src/{mcp → tools}/utils.d.ts +8 -21
  38. package/dist/src/tools/utils.d.ts.map +1 -0
  39. package/dist/src/{utils.js → tools/utils.js} +46 -3
  40. package/dist/src/tools/utils.js.map +1 -0
  41. package/dist/tsconfig.lib.tsbuildinfo +1 -1
  42. package/package.json +17 -11
  43. package/dist/src/mcp/reactor.d.ts +0 -630
  44. package/dist/src/mcp/reactor.d.ts.map +0 -1
  45. package/dist/src/mcp/reactor.js.map +0 -1
  46. package/dist/src/mcp/types.d.ts.map +0 -1
  47. package/dist/src/mcp/utils.d.ts.map +0 -1
  48. package/dist/src/mcp/utils.js +0 -62
  49. package/dist/src/mcp/utils.js.map +0 -1
  50. package/dist/src/reactor.d.ts +0 -43
  51. package/dist/src/reactor.d.ts.map +0 -1
  52. package/dist/src/reactor.js +0 -142
  53. package/dist/src/reactor.js.map +0 -1
  54. package/dist/src/utils.d.ts +0 -10
  55. package/dist/src/utils.d.ts.map +0 -1
  56. package/dist/src/utils.js.map +0 -1
  57. /package/dist/src/{mcp → tools}/types.d.ts +0 -0
  58. /package/dist/src/{mcp → tools}/types.js +0 -0
package/dist/src/cli.js CHANGED
@@ -1,6 +1,10 @@
1
- import { init } from "./index.js";
2
- init().catch((error) => {
3
- console.error(error);
1
+ import { logger } from "./logger.js";
2
+ import { initStdioMcpServer } from "./stdio/index.js";
3
+ initStdioMcpServer({
4
+ remoteDrive: process.argv.at(2),
5
+ root: process.cwd(),
6
+ }).catch((error) => {
7
+ logger.error(error);
4
8
  process.exit(1);
5
9
  });
6
10
  //# sourceMappingURL=cli.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/cli.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAElC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,KAAc,EAAE,EAAE;IAC9B,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACrB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/cli.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAEtD,kBAAkB,CAAC;IACjB,WAAW,EAAE,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;IAC/B,IAAI,EAAE,OAAO,CAAC,GAAG,EAAE;CACpB,CAAC,CAAC,KAAK,CAAC,CAAC,KAAc,EAAE,EAAE;IAC1B,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACpB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { type McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
2
+ import { type IDocumentDriveServer } from "document-drive";
3
+ import { type Express } from "express";
4
+ export declare function setupMcpServer(reactor: IDocumentDriveServer, app: Express): Promise<McpServer>;
5
+ //# sourceMappingURL=express.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"express.d.ts","sourceRoot":"","sources":["../../src/express.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAEzE,OAAO,EAAE,KAAK,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,EAAE,KAAK,OAAO,EAA+B,MAAM,SAAS,CAAC;AAIpE,wBAAsB,cAAc,CAClC,OAAO,EAAE,oBAAoB,EAC7B,GAAG,EAAE,OAAO,GACX,OAAO,CAAC,SAAS,CAAC,CA6DpB"}
@@ -0,0 +1,59 @@
1
+ import { StreamableHTTPServerTransport } from "@modelcontextprotocol/sdk/server/streamableHttp.js";
2
+ import { logger } from "./logger.js";
3
+ import { createServer } from "./server.js";
4
+ export async function setupMcpServer(reactor, app) {
5
+ const server = await createServer(reactor);
6
+ app.post("/mcp", (req, res) => {
7
+ // In stateless mode, create a new instance of transport and server for each request
8
+ // to ensure complete isolation. A single instance would cause request ID collisions
9
+ // when multiple clients connect concurrently.
10
+ try {
11
+ const transport = new StreamableHTTPServerTransport({
12
+ sessionIdGenerator: undefined,
13
+ });
14
+ res.on("close", () => {
15
+ void transport.close();
16
+ void server.close();
17
+ });
18
+ void server.connect(transport);
19
+ void transport.handleRequest(req, res, req.body);
20
+ }
21
+ catch (error) {
22
+ logger.error("Error handling MCP request:", error);
23
+ if (!res.headersSent) {
24
+ res.status(500).json({
25
+ jsonrpc: "2.0",
26
+ error: {
27
+ code: -32603,
28
+ message: "Internal server error",
29
+ },
30
+ id: null,
31
+ });
32
+ }
33
+ }
34
+ });
35
+ // SSE notifications not supported in stateless mode
36
+ app.get("/mcp", (req, res) => {
37
+ res.writeHead(405).end(JSON.stringify({
38
+ jsonrpc: "2.0",
39
+ error: {
40
+ code: -32000,
41
+ message: "Method not allowed.",
42
+ },
43
+ id: null,
44
+ }));
45
+ });
46
+ // Session termination not needed in stateless mode
47
+ app.delete("/mcp", (req, res) => {
48
+ res.writeHead(405).end(JSON.stringify({
49
+ jsonrpc: "2.0",
50
+ error: {
51
+ code: -32000,
52
+ message: "Method not allowed.",
53
+ },
54
+ id: null,
55
+ }));
56
+ });
57
+ return server;
58
+ }
59
+ //# sourceMappingURL=express.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"express.js","sourceRoot":"","sources":["../../src/express.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,6BAA6B,EAAE,MAAM,oDAAoD,CAAC;AAGnG,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,OAA6B,EAC7B,GAAY;IAEZ,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,OAAO,CAAC,CAAC;IAC3C,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,GAAY,EAAE,GAAa,EAAE,EAAE;QAC/C,oFAAoF;QACpF,oFAAoF;QACpF,8CAA8C;QAC9C,IAAI,CAAC;YACH,MAAM,SAAS,GACb,IAAI,6BAA6B,CAAC;gBAChC,kBAAkB,EAAE,SAAS;aAC9B,CAAC,CAAC;YACL,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;gBACnB,KAAK,SAAS,CAAC,KAAK,EAAE,CAAC;gBACvB,KAAK,MAAM,CAAC,KAAK,EAAE,CAAC;YACtB,CAAC,CAAC,CAAC;YACH,KAAK,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAC/B,KAAK,SAAS,CAAC,aAAa,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;QACnD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,6BAA6B,EAAE,KAAK,CAAC,CAAC;YACnD,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;gBACrB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;oBACnB,OAAO,EAAE,KAAK;oBACd,KAAK,EAAE;wBACL,IAAI,EAAE,CAAC,KAAK;wBACZ,OAAO,EAAE,uBAAuB;qBACjC;oBACD,EAAE,EAAE,IAAI;iBACT,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,oDAAoD;IACpD,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,GAAY,EAAE,GAAa,EAAE,EAAE;QAC9C,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,GAAG,CACpB,IAAI,CAAC,SAAS,CAAC;YACb,OAAO,EAAE,KAAK;YACd,KAAK,EAAE;gBACL,IAAI,EAAE,CAAC,KAAK;gBACZ,OAAO,EAAE,qBAAqB;aAC/B;YACD,EAAE,EAAE,IAAI;SACT,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,mDAAmD;IACnD,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,GAAY,EAAE,GAAa,EAAE,EAAE;QACjD,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,GAAG,CACpB,IAAI,CAAC,SAAS,CAAC;YACb,OAAO,EAAE,KAAK;YACd,KAAK,EAAE;gBACL,IAAI,EAAE,CAAC,KAAK;gBACZ,OAAO,EAAE,qBAAqB;aAC/B;YACD,EAAE,EAAE,IAAI;SACT,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AAChB,CAAC"}
@@ -1,2 +1,2 @@
1
- export declare function init(): Promise<void>;
1
+ export { createServer } from "./server.js";
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAIA,wBAAsB,IAAI,kBAOzB"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC"}
package/dist/src/index.js CHANGED
@@ -1,11 +1,2 @@
1
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
2
- import { initDocumentModelMcp } from "./reactor.js";
3
- import { createServer } from "./server.js";
4
- export async function init() {
5
- const documentModelMcp = await initDocumentModelMcp();
6
- const server = createServer(documentModelMcp);
7
- // Start receiving messages on stdin and sending messages on stdout
8
- const transport = new StdioServerTransport();
9
- await server.connect(transport);
10
- }
1
+ export { createServer } from "./server.js";
11
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AACjF,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,CAAC,KAAK,UAAU,IAAI;IACxB,MAAM,gBAAgB,GAAG,MAAM,oBAAoB,EAAE,CAAC;IACtD,MAAM,MAAM,GAAG,YAAY,CAAC,gBAAgB,CAAC,CAAC;IAE9C,mEAAmE;IACnE,MAAM,SAAS,GAAG,IAAI,oBAAoB,EAAE,CAAC;IAC7C,MAAM,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;AAClC,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { type ILogger } from "document-drive";
2
+ export declare const logger: ILogger;
3
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,KAAK,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAE3D,eAAO,MAAM,MAAM,EAAE,OAAsC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { childLogger } from "document-drive";
2
+ export const logger = childLogger(["reactor-mcp"]);
3
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAgB,MAAM,gBAAgB,CAAC;AAE3D,MAAM,CAAC,MAAM,MAAM,GAAY,WAAW,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC"}
@@ -0,0 +1,19 @@
1
+ import type { Provider } from "ai";
2
+ export interface ChatMessage {
3
+ role: "user" | "assistant" | "system";
4
+ content: string;
5
+ }
6
+ export interface ChatOptions {
7
+ provider?: Provider;
8
+ model?: string;
9
+ systemPrompt?: string;
10
+ }
11
+ export declare class LLMChat {
12
+ private provider;
13
+ private model;
14
+ private systemPrompt;
15
+ constructor(options?: ChatOptions);
16
+ sendMessage(messages: ChatMessage[]): Promise<string>;
17
+ streamMessage(messages: ChatMessage[], onChunk: (chunk: string) => void): Promise<void>;
18
+ }
19
+ //# sourceMappingURL=chat.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat.d.ts","sourceRoot":"","sources":["../../../src/sdk/chat.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAgB,QAAQ,EAAE,MAAM,IAAI,CAAC;AAIjD,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,EAAE,QAAQ,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,qBAAa,OAAO;IAClB,OAAO,CAAC,QAAQ,CAAW;IAC3B,OAAO,CAAC,KAAK,CAAS;IACtB,OAAO,CAAC,YAAY,CAAS;gBAEjB,OAAO,GAAE,WAAgB;IAU/B,WAAW,CAAC,QAAQ,EAAE,WAAW,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAyBrD,aAAa,CACjB,QAAQ,EAAE,WAAW,EAAE,EACvB,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,GAC/B,OAAO,CAAC,IAAI,CAAC;CAqBjB"}
@@ -0,0 +1,60 @@
1
+ import { createOpenAI } from "@ai-sdk/openai";
2
+ import { streamText } from "ai";
3
+ import { logger } from "../logger.js";
4
+ export class LLMChat {
5
+ provider;
6
+ model;
7
+ systemPrompt;
8
+ constructor(options = {}) {
9
+ this.provider =
10
+ options.provider ||
11
+ createOpenAI({
12
+ apiKey: process.env.OPENAI_API_KEY || "",
13
+ });
14
+ this.model = options.model || "gpt-4-turbo";
15
+ this.systemPrompt = options.systemPrompt || "You are a helpful assistant.";
16
+ }
17
+ async sendMessage(messages) {
18
+ try {
19
+ const coreMessages = messages.map((msg) => ({
20
+ role: msg.role,
21
+ content: msg.content,
22
+ }));
23
+ const result = streamText({
24
+ model: this.provider.languageModel(this.model),
25
+ system: this.systemPrompt,
26
+ messages: coreMessages,
27
+ });
28
+ let fullResponse = "";
29
+ for await (const textPart of result.textStream) {
30
+ fullResponse += textPart;
31
+ }
32
+ return fullResponse;
33
+ }
34
+ catch (error) {
35
+ logger.error("Error sending message to LLM:", error);
36
+ throw error;
37
+ }
38
+ }
39
+ async streamMessage(messages, onChunk) {
40
+ try {
41
+ const coreMessages = messages.map((msg) => ({
42
+ role: msg.role,
43
+ content: msg.content,
44
+ }));
45
+ const result = streamText({
46
+ model: this.provider.languageModel(this.model),
47
+ system: this.systemPrompt,
48
+ messages: coreMessages,
49
+ });
50
+ for await (const textPart of result.textStream) {
51
+ onChunk(textPart);
52
+ }
53
+ }
54
+ catch (error) {
55
+ logger.error("Error streaming message from LLM:", error);
56
+ throw error;
57
+ }
58
+ }
59
+ }
60
+ //# sourceMappingURL=chat.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat.js","sourceRoot":"","sources":["../../../src/sdk/chat.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE9C,OAAO,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAatC,MAAM,OAAO,OAAO;IACV,QAAQ,CAAW;IACnB,KAAK,CAAS;IACd,YAAY,CAAS;IAE7B,YAAY,UAAuB,EAAE;QACnC,IAAI,CAAC,QAAQ;YACX,OAAO,CAAC,QAAQ;gBAChB,YAAY,CAAC;oBACX,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,EAAE;iBACzC,CAAC,CAAC;QACL,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,aAAa,CAAC;QAC5C,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,IAAI,8BAA8B,CAAC;IAC7E,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,QAAuB;QACvC,IAAI,CAAC;YACH,MAAM,YAAY,GAAmB,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBAC1D,IAAI,EAAE,GAAG,CAAC,IAAI;gBACd,OAAO,EAAE,GAAG,CAAC,OAAO;aACrB,CAAC,CAAC,CAAC;YAEJ,MAAM,MAAM,GAAG,UAAU,CAAC;gBACxB,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC9C,MAAM,EAAE,IAAI,CAAC,YAAY;gBACzB,QAAQ,EAAE,YAAY;aACvB,CAAC,CAAC;YAEH,IAAI,YAAY,GAAG,EAAE,CAAC;YACtB,IAAI,KAAK,EAAE,MAAM,QAAQ,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;gBAC/C,YAAY,IAAI,QAAQ,CAAC;YAC3B,CAAC;YAED,OAAO,YAAY,CAAC;QACtB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,+BAA+B,EAAE,KAAK,CAAC,CAAC;YACrD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAED,KAAK,CAAC,aAAa,CACjB,QAAuB,EACvB,OAAgC;QAEhC,IAAI,CAAC;YACH,MAAM,YAAY,GAAmB,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBAC1D,IAAI,EAAE,GAAG,CAAC,IAAI;gBACd,OAAO,EAAE,GAAG,CAAC,OAAO;aACrB,CAAC,CAAC,CAAC;YAEJ,MAAM,MAAM,GAAG,UAAU,CAAC;gBACxB,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC9C,MAAM,EAAE,IAAI,CAAC,YAAY;gBACzB,QAAQ,EAAE,YAAY;aACvB,CAAC,CAAC;YAEH,IAAI,KAAK,EAAE,MAAM,QAAQ,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;gBAC/C,OAAO,CAAC,QAAQ,CAAC,CAAC;YACpB,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,mCAAmC,EAAE,KAAK,CAAC,CAAC;YACzD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;CACF"}
@@ -1,4 +1,5 @@
1
1
  import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
2
- import { type IReactorMcp, type IDocumentModelMcp } from "./reactor.js";
3
- export declare function createServer(reactor: IReactorMcp & IDocumentModelMcp): McpServer;
2
+ import { type IDocumentDriveServer } from "document-drive";
3
+ export declare const ReactorMcpInstructions = "MUST BE USED when handling documents or document-models for the Powerhouse/Vetra ecosystem.\nThere are 5 main concepts to know of: \n- Document Model: A template for creating documents. It defines the schema and allowed operations for a type of document.\n- Document: An instance of a document model. It contains actual data following the structure defined by the document model and can be changed using operations.\n- Drive: A document of type \"powerhouse/document-drive\" which represents a collection of documents and folders. To add documents to a drive, use the \"addActions\" tool with an \"ADD_FILE\" action.\n- Action: A proposed change to a document. It is a JSON object with the action name and input that defines the action to be taken on the document. Should be dispatched by calling the \"addActions\" tool.\n- Operation: A change done to a document. It contains the action object plus additional metadata such as the index of the operation in the document history, the timestamp it was added, the hash of the resulting document data, the number of operations skipped, and the error message if the operation failed. Actions dispatched with \"addActions\" get converted into an operation.\n\nWhen planning to add multiple actions to a document, try to reduce the number of \"addActions\" calls to a minimum by adding multiple actions at once.\nUnless the user specifies otherwise, and a drive with slug \"vetra\" is available, add newly created documents to it.\n\nExamples:\n<example>Context: User needs to create a new document model for their application. user: 'I need to create a user profile document model with fields for name, email, and preferences' assistant: 'I'll use the reactor-mcp-server to help you create this document model.' <commentary>Since the user is requesting document model creation, use the reactor-mcp-document-expert agent to ensure proper reactor-mcp tool usage.</commentary></example> <example>Context: User is building a content management system and needs create documents for certain types of document models. user: 'Can you help me create example documents for blog posts and categories document models?' assistant: 'Let me use the reactor-mcp-server to create these documents using the appropriate reactor-mcp tool calls.' <commentary>Document model creation requires the reactor-mcp-server tool calls to ensure compliance.</commentary></example>\n<example>Context: User needs to create a new document instance of a given document model. user: 'I need to create a demo user profile document' assistant: 'I'll use the reactor-mcp-server to help you create this document with example values.' <commentary>Since the user is requesting document model creation, use the reactor-mcp-document-expert agent to ensure proper reactor-mcp tool usage.</commentary></example> <example>Context: User is building a content management system and needs create documents for certain types of document models. user: 'Can you help me create example documents for blog posts and categories document models?' assistant: 'Let me use the reactor-mcp-server to create these documents using the appropriate reactor-mcp tool calls.' <commentary>Document creation requires the reactor-mcp-server tool calls to ensure compliance.</commentary></example>\n";
4
+ export declare function createServer(reactor: IDocumentDriveServer): Promise<McpServer>;
4
5
  //# sourceMappingURL=server.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/server.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAEV,MAAM,yCAAyC,CAAC;AAQjD,OAAO,EAAE,KAAK,WAAW,EAAE,KAAK,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAyQxE,wBAAgB,YAAY,CAAC,OAAO,EAAE,WAAW,GAAG,iBAAiB,aAylBpE"}
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/server.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AACpE,OAAO,EAAE,KAAK,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAE3D,eAAO,MAAM,sBAAsB,+sGAclC,CAAC;AAEF,wBAAsB,YAAY,CAChC,OAAO,EAAE,oBAAoB,GAC5B,OAAO,CAAC,SAAS,CAAC,CAoDpB"}