fivocell 1.0.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 (249) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/CONTRIBUTING.md +60 -0
  3. package/LICENSE +98 -0
  4. package/README.md +267 -0
  5. package/bin/cell.js +2 -0
  6. package/dist/cli.d.ts +3 -0
  7. package/dist/cli.d.ts.map +1 -0
  8. package/dist/cli.js +1131 -0
  9. package/dist/cli.js.map +1 -0
  10. package/dist/core/ab-test-framework.d.ts +33 -0
  11. package/dist/core/ab-test-framework.d.ts.map +1 -0
  12. package/dist/core/ab-test-framework.js +93 -0
  13. package/dist/core/ab-test-framework.js.map +1 -0
  14. package/dist/core/ast-extractor.d.ts +10 -0
  15. package/dist/core/ast-extractor.d.ts.map +1 -0
  16. package/dist/core/ast-extractor.js +111 -0
  17. package/dist/core/ast-extractor.js.map +1 -0
  18. package/dist/core/build-failure-predictor.d.ts +25 -0
  19. package/dist/core/build-failure-predictor.d.ts.map +1 -0
  20. package/dist/core/build-failure-predictor.js +124 -0
  21. package/dist/core/build-failure-predictor.js.map +1 -0
  22. package/dist/core/cell-pro.d.ts +28 -0
  23. package/dist/core/cell-pro.d.ts.map +1 -0
  24. package/dist/core/cell-pro.js +70 -0
  25. package/dist/core/cell-pro.js.map +1 -0
  26. package/dist/core/circular-dependency-detector.d.ts +22 -0
  27. package/dist/core/circular-dependency-detector.d.ts.map +1 -0
  28. package/dist/core/circular-dependency-detector.js +95 -0
  29. package/dist/core/circular-dependency-detector.js.map +1 -0
  30. package/dist/core/cloud-client.d.ts +40 -0
  31. package/dist/core/cloud-client.d.ts.map +1 -0
  32. package/dist/core/cloud-client.js +126 -0
  33. package/dist/core/cloud-client.js.map +1 -0
  34. package/dist/core/community-full.d.ts +38 -0
  35. package/dist/core/community-full.d.ts.map +1 -0
  36. package/dist/core/community-full.js +125 -0
  37. package/dist/core/community-full.js.map +1 -0
  38. package/dist/core/community-live.d.ts +31 -0
  39. package/dist/core/community-live.d.ts.map +1 -0
  40. package/dist/core/community-live.js +187 -0
  41. package/dist/core/community-live.js.map +1 -0
  42. package/dist/core/community-prior.d.ts +25 -0
  43. package/dist/core/community-prior.d.ts.map +1 -0
  44. package/dist/core/community-prior.js +181 -0
  45. package/dist/core/community-prior.js.map +1 -0
  46. package/dist/core/complexity-analyzer.d.ts +28 -0
  47. package/dist/core/complexity-analyzer.d.ts.map +1 -0
  48. package/dist/core/complexity-analyzer.js +110 -0
  49. package/dist/core/complexity-analyzer.js.map +1 -0
  50. package/dist/core/confidence-engine.d.ts +16 -0
  51. package/dist/core/confidence-engine.d.ts.map +1 -0
  52. package/dist/core/confidence-engine.js +155 -0
  53. package/dist/core/confidence-engine.js.map +1 -0
  54. package/dist/core/config-attribution.d.ts +30 -0
  55. package/dist/core/config-attribution.d.ts.map +1 -0
  56. package/dist/core/config-attribution.js +288 -0
  57. package/dist/core/config-attribution.js.map +1 -0
  58. package/dist/core/conflict-detector.d.ts +43 -0
  59. package/dist/core/conflict-detector.d.ts.map +1 -0
  60. package/dist/core/conflict-detector.js +205 -0
  61. package/dist/core/conflict-detector.js.map +1 -0
  62. package/dist/core/context-restore.d.ts +25 -0
  63. package/dist/core/context-restore.d.ts.map +1 -0
  64. package/dist/core/context-restore.js +129 -0
  65. package/dist/core/context-restore.js.map +1 -0
  66. package/dist/core/cross-domain-projections.d.ts +19 -0
  67. package/dist/core/cross-domain-projections.d.ts.map +1 -0
  68. package/dist/core/cross-domain-projections.js +69 -0
  69. package/dist/core/cross-domain-projections.js.map +1 -0
  70. package/dist/core/cross-language-mappings.d.ts +15 -0
  71. package/dist/core/cross-language-mappings.d.ts.map +1 -0
  72. package/dist/core/cross-language-mappings.js +202 -0
  73. package/dist/core/cross-language-mappings.js.map +1 -0
  74. package/dist/core/cross-project-sync.d.ts +24 -0
  75. package/dist/core/cross-project-sync.d.ts.map +1 -0
  76. package/dist/core/cross-project-sync.js +132 -0
  77. package/dist/core/cross-project-sync.js.map +1 -0
  78. package/dist/core/dead-code-detector.d.ts +20 -0
  79. package/dist/core/dead-code-detector.d.ts.map +1 -0
  80. package/dist/core/dead-code-detector.js +106 -0
  81. package/dist/core/dead-code-detector.js.map +1 -0
  82. package/dist/core/decay-engine.d.ts +14 -0
  83. package/dist/core/decay-engine.d.ts.map +1 -0
  84. package/dist/core/decay-engine.js +41 -0
  85. package/dist/core/decay-engine.js.map +1 -0
  86. package/dist/core/dependency-health-checker.d.ts +23 -0
  87. package/dist/core/dependency-health-checker.d.ts.map +1 -0
  88. package/dist/core/dependency-health-checker.js +94 -0
  89. package/dist/core/dependency-health-checker.js.map +1 -0
  90. package/dist/core/duplication-detector.d.ts +29 -0
  91. package/dist/core/duplication-detector.d.ts.map +1 -0
  92. package/dist/core/duplication-detector.js +115 -0
  93. package/dist/core/duplication-detector.js.map +1 -0
  94. package/dist/core/enterprise-features.d.ts +32 -0
  95. package/dist/core/enterprise-features.d.ts.map +1 -0
  96. package/dist/core/enterprise-features.js +87 -0
  97. package/dist/core/enterprise-features.js.map +1 -0
  98. package/dist/core/enterprise.d.ts +27 -0
  99. package/dist/core/enterprise.d.ts.map +1 -0
  100. package/dist/core/enterprise.js +41 -0
  101. package/dist/core/enterprise.js.map +1 -0
  102. package/dist/core/error-predictor.d.ts +16 -0
  103. package/dist/core/error-predictor.d.ts.map +1 -0
  104. package/dist/core/error-predictor.js +123 -0
  105. package/dist/core/error-predictor.js.map +1 -0
  106. package/dist/core/extraction-cascade.d.ts +18 -0
  107. package/dist/core/extraction-cascade.d.ts.map +1 -0
  108. package/dist/core/extraction-cascade.js +48 -0
  109. package/dist/core/extraction-cascade.js.map +1 -0
  110. package/dist/core/git-branch-pregenerator.d.ts +23 -0
  111. package/dist/core/git-branch-pregenerator.d.ts.map +1 -0
  112. package/dist/core/git-branch-pregenerator.js +100 -0
  113. package/dist/core/git-branch-pregenerator.js.map +1 -0
  114. package/dist/core/handoff-detector.d.ts +24 -0
  115. package/dist/core/handoff-detector.d.ts.map +1 -0
  116. package/dist/core/handoff-detector.js +116 -0
  117. package/dist/core/handoff-detector.js.map +1 -0
  118. package/dist/core/identity-resolver.d.ts +7 -0
  119. package/dist/core/identity-resolver.d.ts.map +1 -0
  120. package/dist/core/identity-resolver.js +82 -0
  121. package/dist/core/identity-resolver.js.map +1 -0
  122. package/dist/core/interruption-recovery.d.ts +26 -0
  123. package/dist/core/interruption-recovery.d.ts.map +1 -0
  124. package/dist/core/interruption-recovery.js +135 -0
  125. package/dist/core/interruption-recovery.js.map +1 -0
  126. package/dist/core/knowledge-silo-detector.d.ts +20 -0
  127. package/dist/core/knowledge-silo-detector.d.ts.map +1 -0
  128. package/dist/core/knowledge-silo-detector.js +117 -0
  129. package/dist/core/knowledge-silo-detector.js.map +1 -0
  130. package/dist/core/language-switch-assistant.d.ts +18 -0
  131. package/dist/core/language-switch-assistant.d.ts.map +1 -0
  132. package/dist/core/language-switch-assistant.js +98 -0
  133. package/dist/core/language-switch-assistant.js.map +1 -0
  134. package/dist/core/merge-conflict-predictor.d.ts +18 -0
  135. package/dist/core/merge-conflict-predictor.d.ts.map +1 -0
  136. package/dist/core/merge-conflict-predictor.js +98 -0
  137. package/dist/core/merge-conflict-predictor.js.map +1 -0
  138. package/dist/core/model-intelligence.d.ts +24 -0
  139. package/dist/core/model-intelligence.d.ts.map +1 -0
  140. package/dist/core/model-intelligence.js +73 -0
  141. package/dist/core/model-intelligence.js.map +1 -0
  142. package/dist/core/next-action-predictor.d.ts +26 -0
  143. package/dist/core/next-action-predictor.d.ts.map +1 -0
  144. package/dist/core/next-action-predictor.js +136 -0
  145. package/dist/core/next-action-predictor.js.map +1 -0
  146. package/dist/core/offline-queue.d.ts +40 -0
  147. package/dist/core/offline-queue.d.ts.map +1 -0
  148. package/dist/core/offline-queue.js +193 -0
  149. package/dist/core/offline-queue.js.map +1 -0
  150. package/dist/core/pattern-store.d.ts +27 -0
  151. package/dist/core/pattern-store.d.ts.map +1 -0
  152. package/dist/core/pattern-store.js +233 -0
  153. package/dist/core/pattern-store.js.map +1 -0
  154. package/dist/core/performance-predictor.d.ts +16 -0
  155. package/dist/core/performance-predictor.d.ts.map +1 -0
  156. package/dist/core/performance-predictor.js +111 -0
  157. package/dist/core/performance-predictor.js.map +1 -0
  158. package/dist/core/platt-calibration.d.ts +18 -0
  159. package/dist/core/platt-calibration.d.ts.map +1 -0
  160. package/dist/core/platt-calibration.js +89 -0
  161. package/dist/core/platt-calibration.js.map +1 -0
  162. package/dist/core/pr-review-assistant.d.ts +17 -0
  163. package/dist/core/pr-review-assistant.d.ts.map +1 -0
  164. package/dist/core/pr-review-assistant.js +85 -0
  165. package/dist/core/pr-review-assistant.js.map +1 -0
  166. package/dist/core/prompt-conditioner.d.ts +10 -0
  167. package/dist/core/prompt-conditioner.d.ts.map +1 -0
  168. package/dist/core/prompt-conditioner.js +54 -0
  169. package/dist/core/prompt-conditioner.js.map +1 -0
  170. package/dist/core/realtime-guardian.d.ts +19 -0
  171. package/dist/core/realtime-guardian.d.ts.map +1 -0
  172. package/dist/core/realtime-guardian.js +64 -0
  173. package/dist/core/realtime-guardian.js.map +1 -0
  174. package/dist/core/regex-extractor.d.ts +10 -0
  175. package/dist/core/regex-extractor.d.ts.map +1 -0
  176. package/dist/core/regex-extractor.js +141 -0
  177. package/dist/core/regex-extractor.js.map +1 -0
  178. package/dist/core/scale-tester.d.ts +20 -0
  179. package/dist/core/scale-tester.d.ts.map +1 -0
  180. package/dist/core/scale-tester.js +79 -0
  181. package/dist/core/scale-tester.js.map +1 -0
  182. package/dist/core/security-predictor.d.ts +15 -0
  183. package/dist/core/security-predictor.d.ts.map +1 -0
  184. package/dist/core/security-predictor.js +91 -0
  185. package/dist/core/security-predictor.js.map +1 -0
  186. package/dist/core/session-recovery.d.ts +19 -0
  187. package/dist/core/session-recovery.d.ts.map +1 -0
  188. package/dist/core/session-recovery.js +138 -0
  189. package/dist/core/session-recovery.js.map +1 -0
  190. package/dist/core/signal-capture.d.ts +22 -0
  191. package/dist/core/signal-capture.d.ts.map +1 -0
  192. package/dist/core/signal-capture.js +76 -0
  193. package/dist/core/signal-capture.js.map +1 -0
  194. package/dist/core/solution-index.d.ts +33 -0
  195. package/dist/core/solution-index.d.ts.map +1 -0
  196. package/dist/core/solution-index.js +175 -0
  197. package/dist/core/solution-index.js.map +1 -0
  198. package/dist/core/standup-generator.d.ts +17 -0
  199. package/dist/core/standup-generator.d.ts.map +1 -0
  200. package/dist/core/standup-generator.js +84 -0
  201. package/dist/core/standup-generator.js.map +1 -0
  202. package/dist/core/team-composer.d.ts +29 -0
  203. package/dist/core/team-composer.d.ts.map +1 -0
  204. package/dist/core/team-composer.js +150 -0
  205. package/dist/core/team-composer.js.map +1 -0
  206. package/dist/core/test-anticipator.d.ts +17 -0
  207. package/dist/core/test-anticipator.d.ts.map +1 -0
  208. package/dist/core/test-anticipator.js +113 -0
  209. package/dist/core/test-anticipator.js.map +1 -0
  210. package/dist/daemon/lifecycle.d.ts +19 -0
  211. package/dist/daemon/lifecycle.d.ts.map +1 -0
  212. package/dist/daemon/lifecycle.js +199 -0
  213. package/dist/daemon/lifecycle.js.map +1 -0
  214. package/dist/daemon/server.d.ts +81 -0
  215. package/dist/daemon/server.d.ts.map +1 -0
  216. package/dist/daemon/server.js +505 -0
  217. package/dist/daemon/server.js.map +1 -0
  218. package/dist/daemon/watchdog.d.ts +2 -0
  219. package/dist/daemon/watchdog.d.ts.map +1 -0
  220. package/dist/daemon/watchdog.js +93 -0
  221. package/dist/daemon/watchdog.js.map +1 -0
  222. package/dist/daemon/websocket.d.ts +5 -0
  223. package/dist/daemon/websocket.d.ts.map +1 -0
  224. package/dist/daemon/websocket.js +90 -0
  225. package/dist/daemon/websocket.js.map +1 -0
  226. package/dist/index.d.ts +44 -0
  227. package/dist/index.d.ts.map +1 -0
  228. package/dist/index.js +90 -0
  229. package/dist/index.js.map +1 -0
  230. package/dist/types.d.ts +88 -0
  231. package/dist/types.d.ts.map +1 -0
  232. package/dist/types.js +28 -0
  233. package/dist/types.js.map +1 -0
  234. package/extensions/jetbrains/plugin.json +9 -0
  235. package/extensions/shell/copilot-sync.js +59 -0
  236. package/extensions/shell/install.sh +38 -0
  237. package/extensions/shell/watcher.js +113 -0
  238. package/extensions/vscode/.vscodeignore +5 -0
  239. package/extensions/vscode/dist/daemon-client.js +94 -0
  240. package/extensions/vscode/dist/diff-tracker.js +94 -0
  241. package/extensions/vscode/dist/extension.js +100 -0
  242. package/extensions/vscode/dist/status-bar.js +70 -0
  243. package/extensions/vscode/package-lock.json +40 -0
  244. package/extensions/vscode/package.json +27 -0
  245. package/package.json +53 -0
  246. package/packages/mcp-server/dist/server.d.ts +2 -0
  247. package/packages/mcp-server/dist/server.js +213 -0
  248. package/packages/mcp-server/package-lock.json +970 -0
  249. package/packages/mcp-server/package.json +19 -0
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NextActionPredictor = void 0;
4
+ class NextActionPredictor {
5
+ transitionMatrix = new Map();
6
+ actionHistory = [];
7
+ feedbackScores = new Map();
8
+ commonSequences = [
9
+ ['model', 'validation', 'routes', 'tests'],
10
+ ['component', 'styles', 'tests'],
11
+ ['hook', 'component', 'tests'],
12
+ ['interface', 'implementation', 'tests'],
13
+ ['schema', 'migration', 'seed'],
14
+ ['api_route', 'service', 'repository', 'tests'],
15
+ ];
16
+ recordAction(action) {
17
+ if (this.actionHistory.length > 0) {
18
+ const prev = this.actionHistory[this.actionHistory.length - 1];
19
+ if (!this.transitionMatrix.has(prev)) {
20
+ this.transitionMatrix.set(prev, new Map());
21
+ }
22
+ const counts = this.transitionMatrix.get(prev);
23
+ counts.set(action, (counts.get(action) || 0) + 1);
24
+ }
25
+ this.actionHistory.push(action);
26
+ if (this.actionHistory.length > 100) {
27
+ this.actionHistory = this.actionHistory.slice(-50);
28
+ }
29
+ }
30
+ predictNext(patterns) {
31
+ const predictions = [];
32
+ if (this.actionHistory.length === 0) {
33
+ return this.getDefaultSuggestions(patterns);
34
+ }
35
+ const lastAction = this.actionHistory[this.actionHistory.length - 1];
36
+ const transitions = this.transitionMatrix.get(lastAction);
37
+ if (transitions && transitions.size > 0) {
38
+ const total = Array.from(transitions.values()).reduce((a, b) => a + b, 0);
39
+ for (const [action, count] of transitions) {
40
+ const prob = count / total;
41
+ if (prob >= 0.15) {
42
+ predictions.push({
43
+ action,
44
+ description: this.describeAction(action),
45
+ confidence: Math.round(prob * 100) / 100,
46
+ isBulk: false,
47
+ });
48
+ }
49
+ }
50
+ }
51
+ for (const sequence of this.commonSequences) {
52
+ const idx = sequence.indexOf(lastAction);
53
+ if (idx >= 0 && idx < sequence.length - 1) {
54
+ const nextInSeq = sequence[idx + 1];
55
+ if (!predictions.some((p) => p.action === nextInSeq)) {
56
+ predictions.push({
57
+ action: nextInSeq,
58
+ description: this.describeAction(nextInSeq),
59
+ confidence: 0.5,
60
+ isBulk: false,
61
+ });
62
+ }
63
+ }
64
+ }
65
+ predictions.sort((a, b) => b.confidence - a.confidence);
66
+ return predictions.slice(0, 5);
67
+ }
68
+ getBulkSuggestion(predictions) {
69
+ if (predictions.length >= 2) {
70
+ const actions = predictions.map((p) => p.action).join(' → ');
71
+ return {
72
+ action: 'generate_all',
73
+ description: `Generate All: ${actions}`,
74
+ confidence: predictions.length > 0 ? Math.round(predictions.reduce((s, p) => s + p.confidence, 0) / predictions.length * 100) / 100 : 0,
75
+ isBulk: true,
76
+ };
77
+ }
78
+ return null;
79
+ }
80
+ recordFeedback(action, wasUseful) {
81
+ if (!this.feedbackScores.has(action)) {
82
+ this.feedbackScores.set(action, []);
83
+ }
84
+ this.feedbackScores.get(action).push(wasUseful ? 1 : 0);
85
+ }
86
+ getFeedbackScore(action) {
87
+ const scores = this.feedbackScores.get(action);
88
+ if (!scores || scores.length === 0)
89
+ return 0;
90
+ return scores.reduce((a, b) => a + b, 0) / scores.length;
91
+ }
92
+ getStats() {
93
+ let transitions = 0;
94
+ for (const [, counts] of this.transitionMatrix) {
95
+ transitions += counts.size;
96
+ }
97
+ return {
98
+ transitions,
99
+ sequences: this.commonSequences.length,
100
+ feedbackEntries: Array.from(this.feedbackScores.values()).reduce((a, b) => a + b.length, 0),
101
+ };
102
+ }
103
+ getDefaultSuggestions(pattern) {
104
+ const suggestions = [
105
+ { action: 'model', description: 'Create data model', confidence: 0.6, isBulk: false },
106
+ { action: 'component', description: 'Create UI component', confidence: 0.5, isBulk: false },
107
+ { action: 'tests', description: 'Write tests', confidence: 0.55, isBulk: false },
108
+ ];
109
+ if (pattern.some((p) => p.category === 'variable_declaration')) {
110
+ suggestions.push({ action: 'validation', description: 'Add input validation', confidence: 0.45, isBulk: false });
111
+ }
112
+ return suggestions;
113
+ }
114
+ describeAction(action) {
115
+ const descriptions = {
116
+ model: 'Create data model',
117
+ validation: 'Add input validation',
118
+ routes: 'Define API routes',
119
+ tests: 'Write tests',
120
+ component: 'Create UI component',
121
+ styles: 'Add component styles',
122
+ hook: 'Create custom hook',
123
+ interface: 'Define TypeScript interface',
124
+ implementation: 'Implement the interface',
125
+ schema: 'Define database schema',
126
+ migration: 'Create database migration',
127
+ seed: 'Add seed data',
128
+ api_route: 'Create API route handler',
129
+ service: 'Create service layer',
130
+ repository: 'Create data repository',
131
+ };
132
+ return descriptions[action] || action;
133
+ }
134
+ }
135
+ exports.NextActionPredictor = NextActionPredictor;
136
+ //# sourceMappingURL=next-action-predictor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"next-action-predictor.js","sourceRoot":"","sources":["../../src/core/next-action-predictor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,40 @@
1
+ export interface QueuedSignal {
2
+ id: string;
3
+ type: string;
4
+ data: Record<string, unknown>;
5
+ timestamp: string;
6
+ retryCount: number;
7
+ }
8
+ export interface EngineStatus {
9
+ state: 'ONLINE' | 'DEGRADED' | 'OFFLINE';
10
+ lastHeartbeat: string;
11
+ consecutiveFailures: number;
12
+ }
13
+ export declare class OfflineQueue {
14
+ private queuePath;
15
+ private statusPath;
16
+ private maxRetries;
17
+ private timeoutMs;
18
+ private lastFlush;
19
+ constructor(cellDir: string);
20
+ enqueue(type: string, data: Record<string, unknown>): QueuedSignal;
21
+ dequeue(): QueuedSignal | null;
22
+ peek(): QueuedSignal | null;
23
+ getQueueSize(): number;
24
+ getPendingCount(): number;
25
+ getLastFlush(): string | null;
26
+ syncOnReconnect(sendFn?: (signal: QueuedSignal) => Promise<boolean>): Promise<{
27
+ synced: number;
28
+ failed: number;
29
+ }>;
30
+ checkEngineHealth(): EngineStatus;
31
+ heartbeat(): void;
32
+ getDegradedMessage(status: EngineStatus): string;
33
+ clearQueue(): void;
34
+ private loadQueue;
35
+ private saveQueue;
36
+ private loadStatus;
37
+ private saveStatus;
38
+ private ensureDirectory;
39
+ }
40
+ //# sourceMappingURL=offline-queue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"offline-queue.d.ts","sourceRoot":"","sources":["../../src/core/offline-queue.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,QAAQ,GAAG,UAAU,GAAG,SAAS,CAAC;IACzC,aAAa,EAAE,MAAM,CAAC;IACtB,mBAAmB,EAAE,MAAM,CAAC;CAC7B;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,SAAS,CAAgB;gBAErB,OAAO,EAAE,MAAM;IAS3B,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,YAAY;IAgBlE,OAAO,IAAI,YAAY,GAAG,IAAI;IAS9B,IAAI,IAAI,YAAY,GAAG,IAAI;IAK3B,YAAY,IAAI,MAAM;IAItB,eAAe,IAAI,MAAM;IAIzB,YAAY,IAAI,MAAM,GAAG,IAAI;IAIvB,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,OAAO,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;IAkCvH,iBAAiB,IAAI,YAAY;IAqBjC,SAAS,IAAI,IAAI;IAQjB,kBAAkB,CAAC,MAAM,EAAE,YAAY,GAAG,MAAM;IAWhD,UAAU,IAAI,IAAI;IAIlB,OAAO,CAAC,SAAS;IASjB,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,UAAU;IAWlB,OAAO,CAAC,UAAU;IAIlB,OAAO,CAAC,eAAe;CAKxB"}
@@ -0,0 +1,193 @@
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.OfflineQueue = void 0;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const crypto_1 = require("crypto");
40
+ class OfflineQueue {
41
+ queuePath;
42
+ statusPath;
43
+ maxRetries;
44
+ timeoutMs;
45
+ lastFlush;
46
+ constructor(cellDir) {
47
+ this.queuePath = path.join(cellDir, 'offline', 'queue.json');
48
+ this.statusPath = path.join(cellDir, 'offline', 'status.json');
49
+ this.maxRetries = 3;
50
+ this.timeoutMs = 5000;
51
+ this.lastFlush = null;
52
+ this.ensureDirectory(path.dirname(this.queuePath));
53
+ }
54
+ enqueue(type, data) {
55
+ const signal = {
56
+ id: `q_${Date.now()}_${(0, crypto_1.randomUUID)().substring(0, 8)}`,
57
+ type,
58
+ data,
59
+ timestamp: new Date().toISOString(),
60
+ retryCount: 0,
61
+ };
62
+ const queue = this.loadQueue();
63
+ queue.push(signal);
64
+ this.saveQueue(queue);
65
+ return signal;
66
+ }
67
+ dequeue() {
68
+ const queue = this.loadQueue();
69
+ if (queue.length === 0)
70
+ return null;
71
+ const signal = queue.shift();
72
+ this.saveQueue(queue);
73
+ return signal;
74
+ }
75
+ peek() {
76
+ const queue = this.loadQueue();
77
+ return queue.length > 0 ? queue[0] : null;
78
+ }
79
+ getQueueSize() {
80
+ return this.loadQueue().length;
81
+ }
82
+ getPendingCount() {
83
+ return this.loadQueue().length;
84
+ }
85
+ getLastFlush() {
86
+ return this.lastFlush;
87
+ }
88
+ async syncOnReconnect(sendFn) {
89
+ const queue = this.loadQueue();
90
+ let synced = 0;
91
+ let failed = 0;
92
+ const remaining = [];
93
+ for (const signal of queue) {
94
+ if (signal.retryCount >= this.maxRetries) {
95
+ failed++;
96
+ continue;
97
+ }
98
+ let sent = false;
99
+ if (sendFn) {
100
+ try {
101
+ sent = await sendFn(signal);
102
+ }
103
+ catch {
104
+ sent = false;
105
+ }
106
+ }
107
+ if (sent) {
108
+ synced++;
109
+ }
110
+ else {
111
+ signal.retryCount++;
112
+ remaining.push(signal);
113
+ }
114
+ }
115
+ this.lastFlush = new Date().toISOString();
116
+ this.saveQueue(remaining);
117
+ return { synced, failed };
118
+ }
119
+ checkEngineHealth() {
120
+ const status = this.loadStatus();
121
+ const now = Date.now();
122
+ const lastHeartbeat = new Date(status.lastHeartbeat).getTime();
123
+ if (now - lastHeartbeat > this.timeoutMs) {
124
+ status.consecutiveFailures++;
125
+ if (status.consecutiveFailures >= 3) {
126
+ status.state = 'OFFLINE';
127
+ }
128
+ else {
129
+ status.state = 'DEGRADED';
130
+ }
131
+ }
132
+ else {
133
+ status.state = 'ONLINE';
134
+ status.consecutiveFailures = 0;
135
+ }
136
+ this.saveStatus(status);
137
+ return status;
138
+ }
139
+ heartbeat() {
140
+ const status = this.loadStatus();
141
+ status.lastHeartbeat = new Date().toISOString();
142
+ status.state = 'ONLINE';
143
+ status.consecutiveFailures = 0;
144
+ this.saveStatus(status);
145
+ }
146
+ getDegradedMessage(status) {
147
+ switch (status.state) {
148
+ case 'DEGRADED':
149
+ return `Engine is degraded (${status.consecutiveFailures} failures). Retrying...`;
150
+ case 'OFFLINE':
151
+ return `Engine is OFFLINE. ${this.getQueueSize()} signals queued locally. Will sync on reconnect. Admin alert sent.`;
152
+ default:
153
+ return 'Engine is online.';
154
+ }
155
+ }
156
+ clearQueue() {
157
+ this.saveQueue([]);
158
+ }
159
+ loadQueue() {
160
+ if (!fs.existsSync(this.queuePath))
161
+ return [];
162
+ try {
163
+ return JSON.parse(fs.readFileSync(this.queuePath, 'utf-8'));
164
+ }
165
+ catch {
166
+ return [];
167
+ }
168
+ }
169
+ saveQueue(queue) {
170
+ fs.writeFileSync(this.queuePath, JSON.stringify(queue, null, 2), 'utf-8');
171
+ }
172
+ loadStatus() {
173
+ if (!fs.existsSync(this.statusPath)) {
174
+ return { state: 'ONLINE', lastHeartbeat: new Date().toISOString(), consecutiveFailures: 0 };
175
+ }
176
+ try {
177
+ return JSON.parse(fs.readFileSync(this.statusPath, 'utf-8'));
178
+ }
179
+ catch {
180
+ return { state: 'ONLINE', lastHeartbeat: new Date().toISOString(), consecutiveFailures: 0 };
181
+ }
182
+ }
183
+ saveStatus(status) {
184
+ fs.writeFileSync(this.statusPath, JSON.stringify(status, null, 2), 'utf-8');
185
+ }
186
+ ensureDirectory(dir) {
187
+ if (!fs.existsSync(dir)) {
188
+ fs.mkdirSync(dir, { recursive: true });
189
+ }
190
+ }
191
+ }
192
+ exports.OfflineQueue = OfflineQueue;
193
+ //# sourceMappingURL=offline-queue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"offline-queue.js","sourceRoot":"","sources":["../../src/core/offline-queue.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ import { Pattern, TasteModel } from '../types';
2
+ export declare class PatternStore {
3
+ private storePath;
4
+ private patterns;
5
+ private patternIndex;
6
+ private confidenceEngine;
7
+ constructor(cellDir: string);
8
+ addOrUpdatePattern(category: string, description: string, from: string, to: string, isPositive: boolean, conditions?: Pattern['conditions'], scope?: Pattern['scope']): Pattern;
9
+ getPattern(patternId: string): Pattern | undefined;
10
+ getAllPatterns(): Pattern[];
11
+ getPatternsByTier(tier: string): Pattern[];
12
+ getPatternsAboveConfidence(threshold: number): Pattern[];
13
+ getPatternCount(): number;
14
+ getTotalSignals(): number;
15
+ exportTasteModel(): TasteModel;
16
+ exportTasteMarkdown(): string;
17
+ save(): void;
18
+ clear(): void;
19
+ private findExistingPattern;
20
+ private createPattern;
21
+ private updatePattern;
22
+ private load;
23
+ private groupByCategory;
24
+ private formatCategoryName;
25
+ private ensureDirectory;
26
+ }
27
+ //# sourceMappingURL=pattern-store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pattern-store.d.ts","sourceRoot":"","sources":["../../src/core/pattern-store.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,UAAU,EAA2C,MAAM,UAAU,CAAC;AAIxF,qBAAa,YAAY;IACvB,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,QAAQ,CAAuB;IACvC,OAAO,CAAC,YAAY,CAAsB;IAC1C,OAAO,CAAC,gBAAgB,CAAmB;gBAE/B,OAAO,EAAE,MAAM;IAS3B,kBAAkB,CAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,MAAM,EACV,UAAU,EAAE,OAAO,EACnB,UAAU,GAAE,OAAO,CAAC,YAAY,CAAM,EACtC,KAAK,GAAE,OAAO,CAAC,OAAO,CAAY,GACjC,OAAO;IAUV,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS;IAIlD,cAAc,IAAI,OAAO,EAAE;IAI3B,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,EAAE;IAO1C,0BAA0B,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,EAAE;IAIxD,eAAe,IAAI,MAAM;IAIzB,eAAe,IAAI,MAAM;IAQzB,gBAAgB,IAAI,UAAU;IAS9B,mBAAmB,IAAI,MAAM;IAwB7B,IAAI,IAAI,IAAI;IAsBZ,KAAK,IAAI,IAAI;IAMb,OAAO,CAAC,mBAAmB;IAI3B,OAAO,CAAC,aAAa;IA8CrB,OAAO,CAAC,aAAa;IAoBrB,OAAO,CAAC,IAAI;IAgBZ,OAAO,CAAC,eAAe;IAWvB,OAAO,CAAC,kBAAkB;IAO1B,OAAO,CAAC,eAAe;CAKxB"}
@@ -0,0 +1,233 @@
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.PatternStore = void 0;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const types_1 = require("../types");
40
+ const confidence_engine_1 = require("./confidence-engine");
41
+ const crypto_1 = require("crypto");
42
+ class PatternStore {
43
+ storePath;
44
+ patterns;
45
+ patternIndex;
46
+ confidenceEngine;
47
+ constructor(cellDir) {
48
+ this.storePath = path.join(cellDir, 'cell.json');
49
+ this.patterns = new Map();
50
+ this.patternIndex = new Map();
51
+ this.confidenceEngine = new confidence_engine_1.ConfidenceEngine();
52
+ this.ensureDirectory(cellDir);
53
+ this.load();
54
+ }
55
+ addOrUpdatePattern(category, description, from, to, isPositive, conditions = [], scope = 'global') {
56
+ const existingKey = this.findExistingPattern(category, from, to);
57
+ if (existingKey) {
58
+ return this.updatePattern(existingKey, isPositive);
59
+ }
60
+ return this.createPattern(category, description, from, to, isPositive, conditions, scope);
61
+ }
62
+ getPattern(patternId) {
63
+ return this.patterns.get(patternId);
64
+ }
65
+ getAllPatterns() {
66
+ return Array.from(this.patterns.values());
67
+ }
68
+ getPatternsByTier(tier) {
69
+ return this.getAllPatterns().filter((p) => {
70
+ const t = this.confidenceEngine.getTier(p.confidence);
71
+ return t === tier;
72
+ });
73
+ }
74
+ getPatternsAboveConfidence(threshold) {
75
+ return this.getAllPatterns().filter((p) => p.confidence.mean >= threshold);
76
+ }
77
+ getPatternCount() {
78
+ return this.patterns.size;
79
+ }
80
+ getTotalSignals() {
81
+ let total = 0;
82
+ for (const p of this.patterns.values()) {
83
+ total += p.signals.total;
84
+ }
85
+ return total;
86
+ }
87
+ exportTasteModel() {
88
+ return {
89
+ version: types_1.TASTE_MODEL_VERSION,
90
+ lastUpdated: new Date().toISOString(),
91
+ totalSignals: this.getTotalSignals(),
92
+ patterns: this.getAllPatterns(),
93
+ };
94
+ }
95
+ exportTasteMarkdown() {
96
+ const model = this.exportTasteModel();
97
+ const grouped = this.groupByCategory(model.patterns);
98
+ let md = '# FIVO Cell — Your Taste Profile\n\n';
99
+ md += `> Last updated: ${model.lastUpdated}\n`;
100
+ md += `> Total signals: ${model.totalSignals}\n`;
101
+ md += `> Patterns learned: ${model.patterns.length}\n\n`;
102
+ for (const [category, patterns] of Object.entries(grouped)) {
103
+ md += `## ${this.formatCategoryName(category)}\n\n`;
104
+ for (const p of patterns) {
105
+ const tier = this.confidenceEngine.getTier(p.confidence);
106
+ md += `- ${p.description}. `;
107
+ md += `Confidence: ${p.confidence.mean} `;
108
+ md += `| Signals: ${p.signals.positive}/${p.signals.total} `;
109
+ md += `| Tier: ${tier}\n`;
110
+ }
111
+ md += '\n';
112
+ }
113
+ return md;
114
+ }
115
+ save() {
116
+ const model = this.exportTasteModel();
117
+ fs.writeFileSync(this.storePath, JSON.stringify(model, null, 2), 'utf-8');
118
+ const mdPath = this.storePath.replace('cell.json', 'cell.md');
119
+ fs.writeFileSync(mdPath, this.exportTasteMarkdown(), 'utf-8');
120
+ const metaPath = this.storePath.replace('cell.json', 'cell-meta.json');
121
+ let existingMeta = {};
122
+ if (fs.existsSync(metaPath)) {
123
+ try {
124
+ existingMeta = JSON.parse(fs.readFileSync(metaPath, 'utf-8'));
125
+ }
126
+ catch { }
127
+ }
128
+ const meta = {
129
+ ...existingMeta,
130
+ version: types_1.TASTE_MODEL_VERSION,
131
+ lastUpdated: model.lastUpdated,
132
+ totalSignals: model.totalSignals,
133
+ patternCount: model.patterns.length,
134
+ };
135
+ fs.writeFileSync(metaPath, JSON.stringify(meta, null, 2), 'utf-8');
136
+ }
137
+ clear() {
138
+ this.patterns.clear();
139
+ this.patternIndex.clear();
140
+ this.save();
141
+ }
142
+ findExistingPattern(category, from, to) {
143
+ return this.patternIndex.get(`${category}|${from}|${to}`) || null;
144
+ }
145
+ createPattern(category, description, from, to, isPositive, conditions, scope) {
146
+ const patternId = `p_${(0, crypto_1.randomUUID)()}`;
147
+ const positive = isPositive ? 1 : 0;
148
+ const negative = isPositive ? 0 : 1;
149
+ const confidence = this.confidenceEngine.computeConfidence(positive, negative);
150
+ const attribution = {
151
+ primaryCondition: conditions.length > 0 ? `${conditions[0].type}=${conditions[0].value}` : 'unknown',
152
+ conditionConfidence: conditions.length > 0 ? conditions[0].matchScore : 0,
153
+ sourceFiles: [],
154
+ note: 'Config-conditioned correlation, not proven causation',
155
+ };
156
+ const pattern = {
157
+ patternId,
158
+ category,
159
+ description,
160
+ from,
161
+ to,
162
+ conditions,
163
+ confidence,
164
+ signals: {
165
+ positive,
166
+ negative,
167
+ total: 1,
168
+ lastSignal: Date.now(),
169
+ },
170
+ attribution,
171
+ scope,
172
+ survivedDays: 0,
173
+ };
174
+ this.patterns.set(patternId, pattern);
175
+ this.patternIndex.set(`${category}|${from}|${to}`, patternId);
176
+ return pattern;
177
+ }
178
+ updatePattern(patternId, isPositive) {
179
+ const pattern = this.patterns.get(patternId);
180
+ if (!pattern)
181
+ throw new Error(`Pattern ${patternId} not found`);
182
+ if (isPositive) {
183
+ pattern.signals.positive++;
184
+ }
185
+ else {
186
+ pattern.signals.negative++;
187
+ }
188
+ pattern.signals.total++;
189
+ pattern.signals.lastSignal = Date.now();
190
+ pattern.confidence = this.confidenceEngine.computeConfidence(pattern.signals.positive, pattern.signals.negative);
191
+ return pattern;
192
+ }
193
+ load() {
194
+ if (fs.existsSync(this.storePath)) {
195
+ try {
196
+ const data = fs.readFileSync(this.storePath, 'utf-8');
197
+ const model = JSON.parse(data);
198
+ for (const pattern of model.patterns) {
199
+ if (!pattern.patternId || !pattern.category)
200
+ continue;
201
+ this.patterns.set(pattern.patternId, pattern);
202
+ this.patternIndex.set(`${pattern.category}|${pattern.from}|${pattern.to}`, pattern.patternId);
203
+ }
204
+ }
205
+ catch {
206
+ this.patterns.clear();
207
+ }
208
+ }
209
+ }
210
+ groupByCategory(patterns) {
211
+ const grouped = {};
212
+ for (const p of patterns) {
213
+ if (!grouped[p.category]) {
214
+ grouped[p.category] = [];
215
+ }
216
+ grouped[p.category].push(p);
217
+ }
218
+ return grouped;
219
+ }
220
+ formatCategoryName(category) {
221
+ return category
222
+ .split('_')
223
+ .map((w) => w.charAt(0).toUpperCase() + w.slice(1))
224
+ .join(' ');
225
+ }
226
+ ensureDirectory(dir) {
227
+ if (!fs.existsSync(dir)) {
228
+ fs.mkdirSync(dir, { recursive: true });
229
+ }
230
+ }
231
+ }
232
+ exports.PatternStore = PatternStore;
233
+ //# sourceMappingURL=pattern-store.js.map