@nxuss/lemma 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.
Files changed (179) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +311 -0
  3. package/dist/cloud/KeyManager.d.ts +29 -0
  4. package/dist/cloud/KeyManager.d.ts.map +1 -0
  5. package/dist/cloud/KeyManager.js +142 -0
  6. package/dist/cloud/KeyManager.js.map +1 -0
  7. package/dist/cloud/TenantCache.d.ts +29 -0
  8. package/dist/cloud/TenantCache.d.ts.map +1 -0
  9. package/dist/cloud/TenantCache.js +162 -0
  10. package/dist/cloud/TenantCache.js.map +1 -0
  11. package/dist/cloud/index.d.ts +4 -0
  12. package/dist/cloud/index.d.ts.map +1 -0
  13. package/dist/cloud/index.js +23 -0
  14. package/dist/cloud/index.js.map +1 -0
  15. package/dist/cloud/server.d.ts +17 -0
  16. package/dist/cloud/server.d.ts.map +1 -0
  17. package/dist/cloud/server.js +189 -0
  18. package/dist/cloud/server.js.map +1 -0
  19. package/dist/cloud/types.d.ts +35 -0
  20. package/dist/cloud/types.d.ts.map +1 -0
  21. package/dist/cloud/types.js +14 -0
  22. package/dist/cloud/types.js.map +1 -0
  23. package/dist/config/index.d.ts +44 -0
  24. package/dist/config/index.d.ts.map +1 -0
  25. package/dist/config/index.js +161 -0
  26. package/dist/config/index.js.map +1 -0
  27. package/dist/consensus/ConsensusEngine.d.ts +119 -0
  28. package/dist/consensus/ConsensusEngine.d.ts.map +1 -0
  29. package/dist/consensus/ConsensusEngine.js +314 -0
  30. package/dist/consensus/ConsensusEngine.js.map +1 -0
  31. package/dist/consensus/ModelPool.d.ts +103 -0
  32. package/dist/consensus/ModelPool.d.ts.map +1 -0
  33. package/dist/consensus/ModelPool.js +276 -0
  34. package/dist/consensus/ModelPool.js.map +1 -0
  35. package/dist/consensus/index.d.ts +8 -0
  36. package/dist/consensus/index.d.ts.map +1 -0
  37. package/dist/consensus/index.js +13 -0
  38. package/dist/consensus/index.js.map +1 -0
  39. package/dist/core/AgentRegistry.d.ts +89 -0
  40. package/dist/core/AgentRegistry.d.ts.map +1 -0
  41. package/dist/core/AgentRegistry.js +264 -0
  42. package/dist/core/AgentRegistry.js.map +1 -0
  43. package/dist/core/DashboardBroadcaster.d.ts +67 -0
  44. package/dist/core/DashboardBroadcaster.d.ts.map +1 -0
  45. package/dist/core/DashboardBroadcaster.js +264 -0
  46. package/dist/core/DashboardBroadcaster.js.map +1 -0
  47. package/dist/core/OrchestrationEngine.d.ts +84 -0
  48. package/dist/core/OrchestrationEngine.d.ts.map +1 -0
  49. package/dist/core/OrchestrationEngine.js +455 -0
  50. package/dist/core/OrchestrationEngine.js.map +1 -0
  51. package/dist/core/SubconsciousEngine.d.ts +53 -0
  52. package/dist/core/SubconsciousEngine.d.ts.map +1 -0
  53. package/dist/core/SubconsciousEngine.js +273 -0
  54. package/dist/core/SubconsciousEngine.js.map +1 -0
  55. package/dist/core/WebSocketServer.d.ts +89 -0
  56. package/dist/core/WebSocketServer.d.ts.map +1 -0
  57. package/dist/core/WebSocketServer.js +416 -0
  58. package/dist/core/WebSocketServer.js.map +1 -0
  59. package/dist/core/index.d.ts +15 -0
  60. package/dist/core/index.d.ts.map +1 -0
  61. package/dist/core/index.js +24 -0
  62. package/dist/core/index.js.map +1 -0
  63. package/dist/core/router.d.ts +105 -0
  64. package/dist/core/router.d.ts.map +1 -0
  65. package/dist/core/router.js +420 -0
  66. package/dist/core/router.js.map +1 -0
  67. package/dist/embed/index.d.ts +153 -0
  68. package/dist/embed/index.d.ts.map +1 -0
  69. package/dist/embed/index.js +408 -0
  70. package/dist/embed/index.js.map +1 -0
  71. package/dist/embed.d.ts +11 -0
  72. package/dist/embed.d.ts.map +1 -0
  73. package/dist/embed.js +19 -0
  74. package/dist/embed.js.map +1 -0
  75. package/dist/index.d.ts +83 -0
  76. package/dist/index.d.ts.map +1 -0
  77. package/dist/index.js +176 -0
  78. package/dist/index.js.map +1 -0
  79. package/dist/protocol/flows.d.ts +126 -0
  80. package/dist/protocol/flows.d.ts.map +1 -0
  81. package/dist/protocol/flows.js +347 -0
  82. package/dist/protocol/flows.js.map +1 -0
  83. package/dist/protocol/iap.d.ts +54 -0
  84. package/dist/protocol/iap.d.ts.map +1 -0
  85. package/dist/protocol/iap.js +108 -0
  86. package/dist/protocol/iap.js.map +1 -0
  87. package/dist/protocol/index.d.ts +23 -0
  88. package/dist/protocol/index.d.ts.map +1 -0
  89. package/dist/protocol/index.js +45 -0
  90. package/dist/protocol/index.js.map +1 -0
  91. package/dist/protocol/types.d.ts +332 -0
  92. package/dist/protocol/types.d.ts.map +1 -0
  93. package/dist/protocol/types.js +57 -0
  94. package/dist/protocol/types.js.map +1 -0
  95. package/dist/protocol/utils.d.ts +130 -0
  96. package/dist/protocol/utils.d.ts.map +1 -0
  97. package/dist/protocol/utils.js +292 -0
  98. package/dist/protocol/utils.js.map +1 -0
  99. package/dist/protocol/validators.d.ts +54 -0
  100. package/dist/protocol/validators.d.ts.map +1 -0
  101. package/dist/protocol/validators.js +344 -0
  102. package/dist/protocol/validators.js.map +1 -0
  103. package/dist/security/AuthManager.d.ts +73 -0
  104. package/dist/security/AuthManager.d.ts.map +1 -0
  105. package/dist/security/AuthManager.js +102 -0
  106. package/dist/security/AuthManager.js.map +1 -0
  107. package/dist/security/MessageSanitizer.d.ts +51 -0
  108. package/dist/security/MessageSanitizer.d.ts.map +1 -0
  109. package/dist/security/MessageSanitizer.js +166 -0
  110. package/dist/security/MessageSanitizer.js.map +1 -0
  111. package/dist/security/RateLimiter.d.ts +46 -0
  112. package/dist/security/RateLimiter.d.ts.map +1 -0
  113. package/dist/security/RateLimiter.js +133 -0
  114. package/dist/security/RateLimiter.js.map +1 -0
  115. package/dist/security/SecurityMiddleware.d.ts +88 -0
  116. package/dist/security/SecurityMiddleware.d.ts.map +1 -0
  117. package/dist/security/SecurityMiddleware.js +146 -0
  118. package/dist/security/SecurityMiddleware.js.map +1 -0
  119. package/dist/security/index.d.ts +35 -0
  120. package/dist/security/index.d.ts.map +1 -0
  121. package/dist/security/index.js +42 -0
  122. package/dist/security/index.js.map +1 -0
  123. package/dist/speculative/PredictionEngine.d.ts +99 -0
  124. package/dist/speculative/PredictionEngine.d.ts.map +1 -0
  125. package/dist/speculative/PredictionEngine.js +291 -0
  126. package/dist/speculative/PredictionEngine.js.map +1 -0
  127. package/dist/speculative/SpeculativeCache.d.ts +117 -0
  128. package/dist/speculative/SpeculativeCache.d.ts.map +1 -0
  129. package/dist/speculative/SpeculativeCache.js +292 -0
  130. package/dist/speculative/SpeculativeCache.js.map +1 -0
  131. package/dist/speculative/SpeculativeEngine.d.ts +114 -0
  132. package/dist/speculative/SpeculativeEngine.d.ts.map +1 -0
  133. package/dist/speculative/SpeculativeEngine.js +244 -0
  134. package/dist/speculative/SpeculativeEngine.js.map +1 -0
  135. package/dist/speculative/WorkerPool.d.ts +109 -0
  136. package/dist/speculative/WorkerPool.d.ts.map +1 -0
  137. package/dist/speculative/WorkerPool.js +327 -0
  138. package/dist/speculative/WorkerPool.js.map +1 -0
  139. package/dist/speculative/index.d.ts +10 -0
  140. package/dist/speculative/index.d.ts.map +1 -0
  141. package/dist/speculative/index.js +17 -0
  142. package/dist/speculative/index.js.map +1 -0
  143. package/dist/subconscious/EmbeddingService.d.ts +73 -0
  144. package/dist/subconscious/EmbeddingService.d.ts.map +1 -0
  145. package/dist/subconscious/EmbeddingService.js +196 -0
  146. package/dist/subconscious/EmbeddingService.js.map +1 -0
  147. package/dist/subconscious/SemanticCache.d.ts +82 -0
  148. package/dist/subconscious/SemanticCache.d.ts.map +1 -0
  149. package/dist/subconscious/SemanticCache.js +164 -0
  150. package/dist/subconscious/SemanticCache.js.map +1 -0
  151. package/dist/subconscious/SubconsciousEngine.d.ts +121 -0
  152. package/dist/subconscious/SubconsciousEngine.d.ts.map +1 -0
  153. package/dist/subconscious/SubconsciousEngine.js +241 -0
  154. package/dist/subconscious/SubconsciousEngine.js.map +1 -0
  155. package/dist/subconscious/VectorStore.d.ts +54 -0
  156. package/dist/subconscious/VectorStore.d.ts.map +1 -0
  157. package/dist/subconscious/VectorStore.js +168 -0
  158. package/dist/subconscious/VectorStore.js.map +1 -0
  159. package/dist/subconscious/cache.d.ts +34 -0
  160. package/dist/subconscious/cache.d.ts.map +1 -0
  161. package/dist/subconscious/cache.js +156 -0
  162. package/dist/subconscious/cache.js.map +1 -0
  163. package/dist/subconscious/embeddings.d.ts +25 -0
  164. package/dist/subconscious/embeddings.d.ts.map +1 -0
  165. package/dist/subconscious/embeddings.js +65 -0
  166. package/dist/subconscious/embeddings.js.map +1 -0
  167. package/dist/subconscious/index.d.ts +12 -0
  168. package/dist/subconscious/index.d.ts.map +1 -0
  169. package/dist/subconscious/index.js +19 -0
  170. package/dist/subconscious/index.js.map +1 -0
  171. package/dist/types/index.d.ts +286 -0
  172. package/dist/types/index.d.ts.map +1 -0
  173. package/dist/types/index.js +43 -0
  174. package/dist/types/index.js.map +1 -0
  175. package/dist/utils/logger.d.ts +63 -0
  176. package/dist/utils/logger.d.ts.map +1 -0
  177. package/dist/utils/logger.js +126 -0
  178. package/dist/utils/logger.js.map +1 -0
  179. package/package.json +99 -0
@@ -0,0 +1,162 @@
1
+ "use strict";
2
+ /**
3
+ * Lemma Cloud — Tenant Cache Manager
4
+ *
5
+ * Each tenant gets an isolated ChromaDB collection + usage stats.
6
+ * Handles semantic search via Ollama embeddings.
7
+ */
8
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
9
+ if (k2 === undefined) k2 = k;
10
+ var desc = Object.getOwnPropertyDescriptor(m, k);
11
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
12
+ desc = { enumerable: true, get: function() { return m[k]; } };
13
+ }
14
+ Object.defineProperty(o, k2, desc);
15
+ }) : (function(o, m, k, k2) {
16
+ if (k2 === undefined) k2 = k;
17
+ o[k2] = m[k];
18
+ }));
19
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
20
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
21
+ }) : function(o, v) {
22
+ o["default"] = v;
23
+ });
24
+ var __importStar = (this && this.__importStar) || (function () {
25
+ var ownKeys = function(o) {
26
+ ownKeys = Object.getOwnPropertyNames || function (o) {
27
+ var ar = [];
28
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
29
+ return ar;
30
+ };
31
+ return ownKeys(o);
32
+ };
33
+ return function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ })();
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.TenantCache = void 0;
43
+ const types_1 = require("./types");
44
+ class TenantCache {
45
+ constructor(tenantId, chromaUrl, ollamaUrl, model) {
46
+ this.chromaClient = null;
47
+ this.chromaCollection = null;
48
+ this.embeddingCache = new Map();
49
+ this.stats = { hits: 0, misses: 0 };
50
+ this.tenantId = tenantId;
51
+ this.chromaUrl = chromaUrl;
52
+ this.ollamaUrl = ollamaUrl;
53
+ this.model = model;
54
+ // Each tenant gets their own isolated collection
55
+ this.collectionName = `lemma_${tenantId.replace(/[^a-z0-9]/gi, '_').toLowerCase()}`;
56
+ }
57
+ async initialize() {
58
+ const { ChromaClient } = await Promise.resolve().then(() => __importStar(require('chromadb')));
59
+ this.chromaClient = new ChromaClient({ path: this.chromaUrl });
60
+ this.chromaCollection = await this.chromaClient.getOrCreateCollection({
61
+ name: this.collectionName,
62
+ metadata: { 'hnsw:space': 'cosine', tenant: this.tenantId },
63
+ });
64
+ }
65
+ // ─── Query ──────────────────────────────────────────────────────────────────
66
+ async query(input, threshold) {
67
+ if (!this.chromaCollection)
68
+ await this.initialize();
69
+ try {
70
+ const embedding = await this.embed(input);
71
+ const results = await this.chromaCollection.query({
72
+ queryEmbeddings: [embedding],
73
+ nResults: 1,
74
+ include: ['metadatas', 'distances'],
75
+ });
76
+ if (!results.ids?.[0]?.length) {
77
+ this.stats.misses++;
78
+ return { hit: false };
79
+ }
80
+ const distance = results.distances[0][0];
81
+ const similarity = 1 - distance;
82
+ if (similarity < threshold) {
83
+ this.stats.misses++;
84
+ return { hit: false };
85
+ }
86
+ const meta = results.metadatas[0][0];
87
+ // Check TTL
88
+ if (meta.ttl > 0 && Date.now() - meta.createdAt > meta.ttl) {
89
+ this.stats.misses++;
90
+ return { hit: false };
91
+ }
92
+ this.stats.hits++;
93
+ return { hit: true, data: JSON.parse(meta.data), similarity };
94
+ }
95
+ catch (err) {
96
+ console.error(`[TenantCache:${this.tenantId}] Query error:`, err);
97
+ return { hit: false };
98
+ }
99
+ }
100
+ // ─── Store ──────────────────────────────────────────────────────────────────
101
+ async store(key, input, data, ttl) {
102
+ if (!this.chromaCollection)
103
+ await this.initialize();
104
+ try {
105
+ const embedding = await this.embed(input);
106
+ await this.chromaCollection.upsert({
107
+ ids: [key],
108
+ embeddings: [embedding],
109
+ documents: [input],
110
+ metadatas: [{
111
+ data: JSON.stringify(data),
112
+ createdAt: Date.now(),
113
+ ttl,
114
+ tenant: this.tenantId,
115
+ }],
116
+ });
117
+ }
118
+ catch (err) {
119
+ console.error(`[TenantCache:${this.tenantId}] Store error:`, err);
120
+ throw err;
121
+ }
122
+ }
123
+ // ─── Stats ──────────────────────────────────────────────────────────────────
124
+ async getStats() {
125
+ const total = this.stats.hits + this.stats.misses;
126
+ const hitRate = total > 0 ? this.stats.hits / total : 0;
127
+ const tokensSaved = this.stats.hits * types_1.AVG_TOKENS_PER_REQUEST;
128
+ let cacheSize = 0;
129
+ try {
130
+ if (this.chromaCollection)
131
+ cacheSize = await this.chromaCollection.count();
132
+ }
133
+ catch { }
134
+ return {
135
+ tenantId: this.tenantId,
136
+ plan: 'pro', // resolved by KeyManager
137
+ hits: this.stats.hits,
138
+ misses: this.stats.misses,
139
+ totalRequests: total,
140
+ hitRate,
141
+ estimatedTokensSaved: tokensSaved,
142
+ estimatedCostSaved: parseFloat((tokensSaved * types_1.COST_PER_TOKEN).toFixed(4)),
143
+ cacheSize,
144
+ };
145
+ }
146
+ // ─── Embeddings ─────────────────────────────────────────────────────────────
147
+ async embed(text) {
148
+ const normalized = text.trim().toLowerCase();
149
+ if (this.embeddingCache.has(normalized))
150
+ return this.embeddingCache.get(normalized);
151
+ const axios = (await Promise.resolve().then(() => __importStar(require('axios')))).default;
152
+ const res = await axios.post(`${this.ollamaUrl}/api/embeddings`, { model: this.model, prompt: text }, { timeout: 15000 });
153
+ const embedding = res.data.embedding;
154
+ // Keep embedding cache bounded
155
+ if (this.embeddingCache.size > 5000)
156
+ this.embeddingCache.clear();
157
+ this.embeddingCache.set(normalized, embedding);
158
+ return embedding;
159
+ }
160
+ }
161
+ exports.TenantCache = TenantCache;
162
+ //# sourceMappingURL=TenantCache.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TenantCache.js","sourceRoot":"","sources":["../../src/cloud/TenantCache.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export { KeyManager } from './KeyManager';
2
+ export { TenantCache } from './TenantCache';
3
+ export * from './types';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/cloud/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,cAAc,SAAS,CAAC"}
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.TenantCache = exports.KeyManager = void 0;
18
+ var KeyManager_1 = require("./KeyManager");
19
+ Object.defineProperty(exports, "KeyManager", { enumerable: true, get: function () { return KeyManager_1.KeyManager; } });
20
+ var TenantCache_1 = require("./TenantCache");
21
+ Object.defineProperty(exports, "TenantCache", { enumerable: true, get: function () { return TenantCache_1.TenantCache; } });
22
+ __exportStar(require("./types"), exports);
23
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cloud/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,2CAA0C;AAAjC,wGAAA,UAAU,OAAA;AACnB,6CAA4C;AAAnC,0GAAA,WAAW,OAAA;AACpB,0CAAwB"}
@@ -0,0 +1,17 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Lemma Cloud API Server
4
+ *
5
+ * REST API for managed semantic caching.
6
+ * Handles multi-tenant isolation, usage tracking, and plan enforcement.
7
+ *
8
+ * Start: node dist/cloud/server.js
9
+ * Or: npm run cloud:start
10
+ */
11
+ import { KeyManager } from './KeyManager';
12
+ import { TenantCache } from './TenantCache';
13
+ declare const app: import("express-serve-static-core").Express;
14
+ declare const keyManager: KeyManager;
15
+ declare const tenantCaches: Map<string, TenantCache>;
16
+ export { app, keyManager, tenantCaches };
17
+ //# sourceMappingURL=server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/cloud/server.ts"],"names":[],"mappings":";AACA;;;;;;;;GAQG;AAGH,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAG5C,QAAA,MAAM,GAAG,6CAAY,CAAC;AAYtB,QAAA,MAAM,UAAU,YAAmB,CAAC;AACpC,QAAA,MAAM,YAAY,0BAAiC,CAAC;AA2LpD,OAAO,EAAE,GAAG,EAAE,UAAU,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,189 @@
1
+ #!/usr/bin/env node
2
+ "use strict";
3
+ /**
4
+ * Lemma Cloud API Server
5
+ *
6
+ * REST API for managed semantic caching.
7
+ * Handles multi-tenant isolation, usage tracking, and plan enforcement.
8
+ *
9
+ * Start: node dist/cloud/server.js
10
+ * Or: npm run cloud:start
11
+ */
12
+ var __importDefault = (this && this.__importDefault) || function (mod) {
13
+ return (mod && mod.__esModule) ? mod : { "default": mod };
14
+ };
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.tenantCaches = exports.keyManager = exports.app = void 0;
17
+ const express_1 = __importDefault(require("express"));
18
+ const KeyManager_1 = require("./KeyManager");
19
+ const TenantCache_1 = require("./TenantCache");
20
+ const app = (0, express_1.default)();
21
+ exports.app = app;
22
+ app.use(express_1.default.json({ limit: '10mb' }));
23
+ // ─── Config ───────────────────────────────────────────────────────────────────
24
+ const PORT = parseInt(process.env.LEMMA_CLOUD_PORT || '3100');
25
+ const CHROMA_URL = process.env.CHROMA_URL || 'http://localhost:8000';
26
+ const OLLAMA_URL = process.env.OLLAMA_URL || 'http://localhost:11434';
27
+ const OLLAMA_MODEL = process.env.OLLAMA_MODEL || 'nomic-embed-text';
28
+ // ─── State ────────────────────────────────────────────────────────────────────
29
+ const keyManager = new KeyManager_1.KeyManager();
30
+ exports.keyManager = keyManager;
31
+ const tenantCaches = new Map();
32
+ exports.tenantCaches = tenantCaches;
33
+ function authenticate(req, res, next) {
34
+ const auth = req.headers.authorization;
35
+ if (!auth || !auth.startsWith('Bearer ')) {
36
+ return res.status(401).json({ error: 'Missing or invalid Authorization header' });
37
+ }
38
+ const keyId = auth.replace('Bearer ', '');
39
+ const validation = keyManager.validate(keyId);
40
+ if (!validation.valid) {
41
+ return res.status(validation.reason?.includes('limit') ? 429 : 403).json({
42
+ error: validation.reason,
43
+ });
44
+ }
45
+ req.apiKey = validation.key;
46
+ keyManager.recordRequest(keyId);
47
+ next();
48
+ }
49
+ function getTenantCache(tenantId) {
50
+ if (!tenantCaches.has(tenantId)) {
51
+ const cache = new TenantCache_1.TenantCache(tenantId, CHROMA_URL, OLLAMA_URL, OLLAMA_MODEL);
52
+ tenantCaches.set(tenantId, cache);
53
+ }
54
+ return tenantCaches.get(tenantId);
55
+ }
56
+ // ─── Routes ───────────────────────────────────────────────────────────────────
57
+ /**
58
+ * Health check + key validation
59
+ */
60
+ app.get('/v1/ping', authenticate, (req, res) => {
61
+ res.json({
62
+ ok: true,
63
+ tenant: req.apiKey.tenantId,
64
+ plan: req.apiKey.plan,
65
+ usage: req.apiKey.usage,
66
+ });
67
+ });
68
+ /**
69
+ * Query cache
70
+ * POST /v1/query
71
+ * Body: { input: string, threshold: number }
72
+ */
73
+ app.post('/v1/query', authenticate, async (req, res) => {
74
+ const { input, threshold = 0.92 } = req.body;
75
+ if (!input || typeof input !== 'string') {
76
+ return res.status(400).json({ error: 'Missing or invalid "input" field' });
77
+ }
78
+ try {
79
+ const cache = getTenantCache(req.apiKey.tenantId);
80
+ const result = await cache.query(input, threshold);
81
+ res.json(result);
82
+ }
83
+ catch (err) {
84
+ console.error('[API] Query error:', err);
85
+ res.status(500).json({ error: 'Internal server error', details: err.message });
86
+ }
87
+ });
88
+ /**
89
+ * Store in cache
90
+ * POST /v1/cache
91
+ * Body: { key: string, input: string, data: any, ttl?: number }
92
+ */
93
+ app.post('/v1/cache', authenticate, async (req, res) => {
94
+ const { key, input, data, ttl = 0 } = req.body;
95
+ if (!key || !input || data === undefined) {
96
+ return res.status(400).json({ error: 'Missing required fields: key, input, data' });
97
+ }
98
+ try {
99
+ const cache = getTenantCache(req.apiKey.tenantId);
100
+ await cache.store(key, input, data, ttl);
101
+ res.json({ ok: true });
102
+ }
103
+ catch (err) {
104
+ console.error('[API] Store error:', err);
105
+ res.status(500).json({ error: 'Internal server error', details: err.message });
106
+ }
107
+ });
108
+ /**
109
+ * Get tenant stats (for dashboard)
110
+ * GET /v1/stats
111
+ */
112
+ app.get('/v1/stats', authenticate, async (req, res) => {
113
+ try {
114
+ const cache = getTenantCache(req.apiKey.tenantId);
115
+ const stats = await cache.getStats();
116
+ stats.plan = req.apiKey.plan; // override with actual plan from key
117
+ res.json(stats);
118
+ }
119
+ catch (err) {
120
+ console.error('[API] Stats error:', err);
121
+ res.status(500).json({ error: 'Internal server error', details: err.message });
122
+ }
123
+ });
124
+ /**
125
+ * Admin: Generate API key
126
+ * POST /admin/keys
127
+ * Body: { tenantId: string, name: string, plan?: 'free' | 'pro' | 'scale' }
128
+ * Auth: X-Admin-Secret header
129
+ */
130
+ app.post('/admin/keys', (req, res) => {
131
+ const adminSecret = req.headers['x-admin-secret'];
132
+ if (adminSecret !== process.env.ADMIN_SECRET) {
133
+ return res.status(403).json({ error: 'Forbidden' });
134
+ }
135
+ const { tenantId, name, plan = 'free' } = req.body;
136
+ if (!tenantId || !name) {
137
+ return res.status(400).json({ error: 'Missing tenantId or name' });
138
+ }
139
+ const key = keyManager.generate(tenantId, name, plan);
140
+ res.json({ key });
141
+ });
142
+ /**
143
+ * Admin: Upgrade plan
144
+ * POST /admin/keys/:keyId/upgrade
145
+ * Body: { plan: 'pro' | 'scale' }
146
+ */
147
+ app.post('/admin/keys/:keyId/upgrade', (req, res) => {
148
+ const adminSecret = req.headers['x-admin-secret'];
149
+ if (adminSecret !== process.env.ADMIN_SECRET) {
150
+ return res.status(403).json({ error: 'Forbidden' });
151
+ }
152
+ const { keyId } = req.params;
153
+ const { plan } = req.body;
154
+ if (!['pro', 'scale'].includes(plan)) {
155
+ return res.status(400).json({ error: 'Invalid plan. Must be "pro" or "scale"' });
156
+ }
157
+ const success = keyManager.upgradePlan(keyId, plan);
158
+ if (!success) {
159
+ return res.status(404).json({ error: 'Key not found' });
160
+ }
161
+ res.json({ ok: true, keyId, plan });
162
+ });
163
+ // ─── Error Handler ────────────────────────────────────────────────────────────
164
+ app.use((err, req, res, next) => {
165
+ console.error('[API] Unhandled error:', err);
166
+ res.status(500).json({ error: 'Internal server error' });
167
+ });
168
+ // ─── Start ────────────────────────────────────────────────────────────────────
169
+ app.listen(PORT, () => {
170
+ console.log('╔════════════════════════════════════════╗');
171
+ console.log('║ Lemma Cloud API Server ║');
172
+ console.log('╚════════════════════════════════════════╝');
173
+ console.log('');
174
+ console.log(`🚀 Listening on port ${PORT}`);
175
+ console.log(`📊 ChromaDB: ${CHROMA_URL}`);
176
+ console.log(`🧠 Ollama: ${OLLAMA_URL} (${OLLAMA_MODEL})`);
177
+ console.log('');
178
+ console.log('Endpoints:');
179
+ console.log(' GET /v1/ping — Health check');
180
+ console.log(' POST /v1/query — Query cache');
181
+ console.log(' POST /v1/cache — Store in cache');
182
+ console.log(' GET /v1/stats — Get tenant stats');
183
+ console.log('');
184
+ console.log('Admin:');
185
+ console.log(' POST /admin/keys — Generate API key');
186
+ console.log(' POST /admin/keys/:id/upgrade — Upgrade plan');
187
+ console.log('');
188
+ });
189
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/cloud/server.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ /**
2
+ * Lemma Cloud — Shared Types
3
+ */
4
+ export interface ApiKey {
5
+ id: string;
6
+ tenantId: string;
7
+ name: string;
8
+ plan: 'free' | 'pro' | 'scale';
9
+ createdAt: number;
10
+ expiresAt?: number;
11
+ active: boolean;
12
+ usage: {
13
+ today: number;
14
+ total: number;
15
+ lastReset: number;
16
+ };
17
+ }
18
+ export interface TenantStats {
19
+ tenantId: string;
20
+ plan: 'free' | 'pro' | 'scale';
21
+ hits: number;
22
+ misses: number;
23
+ totalRequests: number;
24
+ hitRate: number;
25
+ estimatedTokensSaved: number;
26
+ estimatedCostSaved: number;
27
+ cacheSize: number;
28
+ }
29
+ export declare const PLAN_LIMITS: Record<string, {
30
+ dailyRequests: number;
31
+ cacheEntries: number;
32
+ }>;
33
+ export declare const AVG_TOKENS_PER_REQUEST = 800;
34
+ export declare const COST_PER_TOKEN = 0.000002;
35
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/cloud/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,WAAW,MAAM;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,GAAG,KAAK,GAAG,OAAO,CAAC;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,OAAO,CAAC;IAChB,KAAK,EAAE;QACL,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,EAAE,MAAM,CAAC;QACd,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC;CACH;AAED,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,GAAG,KAAK,GAAG,OAAO,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,aAAa,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,eAAO,MAAM,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE;IAAE,aAAa,EAAE,MAAM,CAAC;IAAC,YAAY,EAAE,MAAM,CAAA;CAAE,CAIvF,CAAC;AAEF,eAAO,MAAM,sBAAsB,MAAM,CAAC;AAC1C,eAAO,MAAM,cAAc,WAAW,CAAC"}
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ /**
3
+ * Lemma Cloud — Shared Types
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.COST_PER_TOKEN = exports.AVG_TOKENS_PER_REQUEST = exports.PLAN_LIMITS = void 0;
7
+ exports.PLAN_LIMITS = {
8
+ free: { dailyRequests: 1000, cacheEntries: 500 },
9
+ pro: { dailyRequests: 100000, cacheEntries: 50000 },
10
+ scale: { dailyRequests: Infinity, cacheEntries: Infinity },
11
+ };
12
+ exports.AVG_TOKENS_PER_REQUEST = 800;
13
+ exports.COST_PER_TOKEN = 0.000002; // gpt-4o-mini input+output blended
14
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/cloud/types.ts"],"names":[],"mappings":";AAAA;;GAEG;;;AA6BU,QAAA,WAAW,GAAoE;IAC1F,IAAI,EAAG,EAAE,aAAa,EAAE,IAAK,EAAI,YAAY,EAAE,GAAG,EAAE;IACpD,GAAG,EAAI,EAAE,aAAa,EAAE,MAAO,EAAE,YAAY,EAAE,KAAM,EAAE;IACvD,KAAK,EAAE,EAAE,aAAa,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE;CAC3D,CAAC;AAEW,QAAA,sBAAsB,GAAG,GAAG,CAAC;AAC7B,QAAA,cAAc,GAAG,QAAQ,CAAC,CAAC,mCAAmC"}
@@ -0,0 +1,44 @@
1
+ import { EnvironmentConfig } from '../types';
2
+ /**
3
+ * Application configuration loaded from environment variables
4
+ */
5
+ export declare const config: EnvironmentConfig;
6
+ /**
7
+ * Validate configuration
8
+ */
9
+ export declare function validateConfig(): void;
10
+ /**
11
+ * Get full ChromaDB URL
12
+ */
13
+ export declare function getChromaURL(): string;
14
+ /**
15
+ * Print configuration (safe - no secrets)
16
+ */
17
+ export declare function printConfig(): void;
18
+ /**
19
+ * Get security configuration
20
+ */
21
+ export declare function getSecurityConfig(): {
22
+ auth: {
23
+ enabled: boolean;
24
+ requireApiKey: boolean;
25
+ allowedOrigins: string[];
26
+ defaultRateLimit: {
27
+ requestsPerMinute: number;
28
+ requestsPerHour: number;
29
+ };
30
+ };
31
+ rateLimit: {
32
+ enabled: boolean;
33
+ requestsPerMinute: number;
34
+ requestsPerHour: number;
35
+ blockDuration: number;
36
+ };
37
+ sanitization: {
38
+ enabled: boolean;
39
+ maxStringLength: number;
40
+ maxArrayLength: number;
41
+ maxObjectDepth: number;
42
+ };
43
+ };
44
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AA+B7C;;GAEG;AACH,eAAO,MAAM,MAAM,EAAE,iBAuCpB,CAAC;AAEF;;GAEG;AACH,wBAAgB,cAAc,IAAI,IAAI,CA6BrC;AAED;;GAEG;AACH,wBAAgB,YAAY,IAAI,MAAM,CAErC;AAED;;GAEG;AACH,wBAAgB,WAAW,IAAI,IAAI,CAelC;AAED;;GAEG;AACH,wBAAgB,iBAAiB;;;;;;;;;;;;;;;;;;;;;;EAwBhC"}