@cybermem/mcp 0.9.12 → 0.13.3

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/Dockerfile CHANGED
@@ -1,4 +1,4 @@
1
- FROM node:18-alpine AS builder
1
+ FROM node:20-alpine AS builder
2
2
 
3
3
  WORKDIR /app
4
4
  # Install build dependencies for native modules (better-sqlite3)
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ // Redirect all stdout to stderr IMMEDIATELY to protect Stdio protocol
4
+ const originalStdoutWrite = process.stdout.write.bind(process.stdout);
5
+ process.stdout.write = (chunk, encoding, callback) => {
6
+ const str = typeof chunk === "string" ? chunk : chunk.toString();
7
+ if (str.includes('"jsonrpc":')) {
8
+ return originalStdoutWrite(chunk, encoding, callback);
9
+ }
10
+ return process.stderr.write(chunk, encoding, callback);
11
+ };
12
+ // Also redirect console outputs
13
+ console.log = console.error;
14
+ console.info = console.error;
package/dist/env.js CHANGED
@@ -3,12 +3,22 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- /**
7
- * Environment Initialization for CyberMem MCP
8
- * Must be imported first to set side-effect vars.
9
- */
10
6
  const dotenv_1 = __importDefault(require("dotenv"));
7
+ const os_1 = __importDefault(require("os"));
8
+ const path_1 = __importDefault(require("path"));
11
9
  dotenv_1.default.config();
10
+ // CLI Enforcement: Ensure CyberMem is deployed via @cybermem/cli
11
+ if (!process.env.CYBERMEM_INSTANCE) {
12
+ console.error("\n❌ FATAL: CyberMem must be started via @cybermem/cli ('mcp install' or 'mcp up').");
13
+ console.error("Manual 'npm start' or 'docker-compose up' without CLI tagging is forbidden.\n");
14
+ process.exit(1);
15
+ }
16
+ // Normalize OM_DB_PATH early so all components (SDK, exporters) use the same file
17
+ const homedir = os_1.default.homedir();
18
+ process.env.OM_DB_PATH =
19
+ process.env.OM_DB_PATH ||
20
+ path_1.default.resolve(homedir, ".cybermem/data/openmemory.sqlite");
21
+ process.env.DB_PATH = process.env.OM_DB_PATH;
12
22
  process.env.OM_TIER = process.env.OM_TIER || "hybrid";
13
23
  process.env.OM_PORT = process.env.OM_PORT || "0";
14
24
  process.env.PORT = process.env.PORT || "0";