@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.
- package/LICENSE +21 -0
- package/README.md +311 -0
- package/dist/cloud/KeyManager.d.ts +29 -0
- package/dist/cloud/KeyManager.d.ts.map +1 -0
- package/dist/cloud/KeyManager.js +142 -0
- package/dist/cloud/KeyManager.js.map +1 -0
- package/dist/cloud/TenantCache.d.ts +29 -0
- package/dist/cloud/TenantCache.d.ts.map +1 -0
- package/dist/cloud/TenantCache.js +162 -0
- package/dist/cloud/TenantCache.js.map +1 -0
- package/dist/cloud/index.d.ts +4 -0
- package/dist/cloud/index.d.ts.map +1 -0
- package/dist/cloud/index.js +23 -0
- package/dist/cloud/index.js.map +1 -0
- package/dist/cloud/server.d.ts +17 -0
- package/dist/cloud/server.d.ts.map +1 -0
- package/dist/cloud/server.js +189 -0
- package/dist/cloud/server.js.map +1 -0
- package/dist/cloud/types.d.ts +35 -0
- package/dist/cloud/types.d.ts.map +1 -0
- package/dist/cloud/types.js +14 -0
- package/dist/cloud/types.js.map +1 -0
- package/dist/config/index.d.ts +44 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +161 -0
- package/dist/config/index.js.map +1 -0
- package/dist/consensus/ConsensusEngine.d.ts +119 -0
- package/dist/consensus/ConsensusEngine.d.ts.map +1 -0
- package/dist/consensus/ConsensusEngine.js +314 -0
- package/dist/consensus/ConsensusEngine.js.map +1 -0
- package/dist/consensus/ModelPool.d.ts +103 -0
- package/dist/consensus/ModelPool.d.ts.map +1 -0
- package/dist/consensus/ModelPool.js +276 -0
- package/dist/consensus/ModelPool.js.map +1 -0
- package/dist/consensus/index.d.ts +8 -0
- package/dist/consensus/index.d.ts.map +1 -0
- package/dist/consensus/index.js +13 -0
- package/dist/consensus/index.js.map +1 -0
- package/dist/core/AgentRegistry.d.ts +89 -0
- package/dist/core/AgentRegistry.d.ts.map +1 -0
- package/dist/core/AgentRegistry.js +264 -0
- package/dist/core/AgentRegistry.js.map +1 -0
- package/dist/core/DashboardBroadcaster.d.ts +67 -0
- package/dist/core/DashboardBroadcaster.d.ts.map +1 -0
- package/dist/core/DashboardBroadcaster.js +264 -0
- package/dist/core/DashboardBroadcaster.js.map +1 -0
- package/dist/core/OrchestrationEngine.d.ts +84 -0
- package/dist/core/OrchestrationEngine.d.ts.map +1 -0
- package/dist/core/OrchestrationEngine.js +455 -0
- package/dist/core/OrchestrationEngine.js.map +1 -0
- package/dist/core/SubconsciousEngine.d.ts +53 -0
- package/dist/core/SubconsciousEngine.d.ts.map +1 -0
- package/dist/core/SubconsciousEngine.js +273 -0
- package/dist/core/SubconsciousEngine.js.map +1 -0
- package/dist/core/WebSocketServer.d.ts +89 -0
- package/dist/core/WebSocketServer.d.ts.map +1 -0
- package/dist/core/WebSocketServer.js +416 -0
- package/dist/core/WebSocketServer.js.map +1 -0
- package/dist/core/index.d.ts +15 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +24 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/router.d.ts +105 -0
- package/dist/core/router.d.ts.map +1 -0
- package/dist/core/router.js +420 -0
- package/dist/core/router.js.map +1 -0
- package/dist/embed/index.d.ts +153 -0
- package/dist/embed/index.d.ts.map +1 -0
- package/dist/embed/index.js +408 -0
- package/dist/embed/index.js.map +1 -0
- package/dist/embed.d.ts +11 -0
- package/dist/embed.d.ts.map +1 -0
- package/dist/embed.js +19 -0
- package/dist/embed.js.map +1 -0
- package/dist/index.d.ts +83 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +176 -0
- package/dist/index.js.map +1 -0
- package/dist/protocol/flows.d.ts +126 -0
- package/dist/protocol/flows.d.ts.map +1 -0
- package/dist/protocol/flows.js +347 -0
- package/dist/protocol/flows.js.map +1 -0
- package/dist/protocol/iap.d.ts +54 -0
- package/dist/protocol/iap.d.ts.map +1 -0
- package/dist/protocol/iap.js +108 -0
- package/dist/protocol/iap.js.map +1 -0
- package/dist/protocol/index.d.ts +23 -0
- package/dist/protocol/index.d.ts.map +1 -0
- package/dist/protocol/index.js +45 -0
- package/dist/protocol/index.js.map +1 -0
- package/dist/protocol/types.d.ts +332 -0
- package/dist/protocol/types.d.ts.map +1 -0
- package/dist/protocol/types.js +57 -0
- package/dist/protocol/types.js.map +1 -0
- package/dist/protocol/utils.d.ts +130 -0
- package/dist/protocol/utils.d.ts.map +1 -0
- package/dist/protocol/utils.js +292 -0
- package/dist/protocol/utils.js.map +1 -0
- package/dist/protocol/validators.d.ts +54 -0
- package/dist/protocol/validators.d.ts.map +1 -0
- package/dist/protocol/validators.js +344 -0
- package/dist/protocol/validators.js.map +1 -0
- package/dist/security/AuthManager.d.ts +73 -0
- package/dist/security/AuthManager.d.ts.map +1 -0
- package/dist/security/AuthManager.js +102 -0
- package/dist/security/AuthManager.js.map +1 -0
- package/dist/security/MessageSanitizer.d.ts +51 -0
- package/dist/security/MessageSanitizer.d.ts.map +1 -0
- package/dist/security/MessageSanitizer.js +166 -0
- package/dist/security/MessageSanitizer.js.map +1 -0
- package/dist/security/RateLimiter.d.ts +46 -0
- package/dist/security/RateLimiter.d.ts.map +1 -0
- package/dist/security/RateLimiter.js +133 -0
- package/dist/security/RateLimiter.js.map +1 -0
- package/dist/security/SecurityMiddleware.d.ts +88 -0
- package/dist/security/SecurityMiddleware.d.ts.map +1 -0
- package/dist/security/SecurityMiddleware.js +146 -0
- package/dist/security/SecurityMiddleware.js.map +1 -0
- package/dist/security/index.d.ts +35 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +42 -0
- package/dist/security/index.js.map +1 -0
- package/dist/speculative/PredictionEngine.d.ts +99 -0
- package/dist/speculative/PredictionEngine.d.ts.map +1 -0
- package/dist/speculative/PredictionEngine.js +291 -0
- package/dist/speculative/PredictionEngine.js.map +1 -0
- package/dist/speculative/SpeculativeCache.d.ts +117 -0
- package/dist/speculative/SpeculativeCache.d.ts.map +1 -0
- package/dist/speculative/SpeculativeCache.js +292 -0
- package/dist/speculative/SpeculativeCache.js.map +1 -0
- package/dist/speculative/SpeculativeEngine.d.ts +114 -0
- package/dist/speculative/SpeculativeEngine.d.ts.map +1 -0
- package/dist/speculative/SpeculativeEngine.js +244 -0
- package/dist/speculative/SpeculativeEngine.js.map +1 -0
- package/dist/speculative/WorkerPool.d.ts +109 -0
- package/dist/speculative/WorkerPool.d.ts.map +1 -0
- package/dist/speculative/WorkerPool.js +327 -0
- package/dist/speculative/WorkerPool.js.map +1 -0
- package/dist/speculative/index.d.ts +10 -0
- package/dist/speculative/index.d.ts.map +1 -0
- package/dist/speculative/index.js +17 -0
- package/dist/speculative/index.js.map +1 -0
- package/dist/subconscious/EmbeddingService.d.ts +73 -0
- package/dist/subconscious/EmbeddingService.d.ts.map +1 -0
- package/dist/subconscious/EmbeddingService.js +196 -0
- package/dist/subconscious/EmbeddingService.js.map +1 -0
- package/dist/subconscious/SemanticCache.d.ts +82 -0
- package/dist/subconscious/SemanticCache.d.ts.map +1 -0
- package/dist/subconscious/SemanticCache.js +164 -0
- package/dist/subconscious/SemanticCache.js.map +1 -0
- package/dist/subconscious/SubconsciousEngine.d.ts +121 -0
- package/dist/subconscious/SubconsciousEngine.d.ts.map +1 -0
- package/dist/subconscious/SubconsciousEngine.js +241 -0
- package/dist/subconscious/SubconsciousEngine.js.map +1 -0
- package/dist/subconscious/VectorStore.d.ts +54 -0
- package/dist/subconscious/VectorStore.d.ts.map +1 -0
- package/dist/subconscious/VectorStore.js +168 -0
- package/dist/subconscious/VectorStore.js.map +1 -0
- package/dist/subconscious/cache.d.ts +34 -0
- package/dist/subconscious/cache.d.ts.map +1 -0
- package/dist/subconscious/cache.js +156 -0
- package/dist/subconscious/cache.js.map +1 -0
- package/dist/subconscious/embeddings.d.ts +25 -0
- package/dist/subconscious/embeddings.d.ts.map +1 -0
- package/dist/subconscious/embeddings.js +65 -0
- package/dist/subconscious/embeddings.js.map +1 -0
- package/dist/subconscious/index.d.ts +12 -0
- package/dist/subconscious/index.d.ts.map +1 -0
- package/dist/subconscious/index.js +19 -0
- package/dist/subconscious/index.js.map +1 -0
- package/dist/types/index.d.ts +286 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +43 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/logger.d.ts +63 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +126 -0
- package/dist/utils/logger.js.map +1 -0
- 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 @@
|
|
|
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"}
|