- Run npx @claude-flow/cli@latest init --force: 115 files created (agents, commands, helpers, skills, settings, MCP config) - Initialize memory.db (147 KB): 84 files analyzed, 30 patterns extracted, 46 trajectories evaluated via 4-step RETRIEVE/JUDGE/DISTILL/CONSOLIDATE - Run pretraining with MoE model: hyperbolic Poincaré embeddings, 3 contradictions resolved, all-MiniLM-L6-v2 ONNX embedding index - Include .claude/memory.db and .claude-flow/metrics/learning.json in repo for team sharing (semantic search available to all contributors) - Update CLAUDE.md: add wifi-densepose project context, key crates, ruvector integration map, correct build/test commands for this repo, ADR cross-reference (ADR-014 through ADR-017) https://claude.ai/code/session_01BSBAQJ34SLkiJy4A8SoiL4
136 lines
3.6 KiB
JavaScript
136 lines
3.6 KiB
JavaScript
#!/usr/bin/env node
|
|
/**
|
|
* Claude Flow Session Manager
|
|
* Handles session lifecycle: start, restore, end
|
|
*/
|
|
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
|
|
const SESSION_DIR = path.join(process.cwd(), '.claude-flow', 'sessions');
|
|
const SESSION_FILE = path.join(SESSION_DIR, 'current.json');
|
|
|
|
const commands = {
|
|
start: () => {
|
|
const sessionId = `session-${Date.now()}`;
|
|
const session = {
|
|
id: sessionId,
|
|
startedAt: new Date().toISOString(),
|
|
cwd: process.cwd(),
|
|
context: {},
|
|
metrics: {
|
|
edits: 0,
|
|
commands: 0,
|
|
tasks: 0,
|
|
errors: 0,
|
|
},
|
|
};
|
|
|
|
fs.mkdirSync(SESSION_DIR, { recursive: true });
|
|
fs.writeFileSync(SESSION_FILE, JSON.stringify(session, null, 2));
|
|
|
|
console.log(`Session started: ${sessionId}`);
|
|
return session;
|
|
},
|
|
|
|
restore: () => {
|
|
if (!fs.existsSync(SESSION_FILE)) {
|
|
console.log('No session to restore');
|
|
return null;
|
|
}
|
|
|
|
const session = JSON.parse(fs.readFileSync(SESSION_FILE, 'utf-8'));
|
|
session.restoredAt = new Date().toISOString();
|
|
fs.writeFileSync(SESSION_FILE, JSON.stringify(session, null, 2));
|
|
|
|
console.log(`Session restored: ${session.id}`);
|
|
return session;
|
|
},
|
|
|
|
end: () => {
|
|
if (!fs.existsSync(SESSION_FILE)) {
|
|
console.log('No active session');
|
|
return null;
|
|
}
|
|
|
|
const session = JSON.parse(fs.readFileSync(SESSION_FILE, 'utf-8'));
|
|
session.endedAt = new Date().toISOString();
|
|
session.duration = Date.now() - new Date(session.startedAt).getTime();
|
|
|
|
// Archive session
|
|
const archivePath = path.join(SESSION_DIR, `${session.id}.json`);
|
|
fs.writeFileSync(archivePath, JSON.stringify(session, null, 2));
|
|
fs.unlinkSync(SESSION_FILE);
|
|
|
|
console.log(`Session ended: ${session.id}`);
|
|
console.log(`Duration: ${Math.round(session.duration / 1000 / 60)} minutes`);
|
|
console.log(`Metrics: ${JSON.stringify(session.metrics)}`);
|
|
|
|
return session;
|
|
},
|
|
|
|
status: () => {
|
|
if (!fs.existsSync(SESSION_FILE)) {
|
|
console.log('No active session');
|
|
return null;
|
|
}
|
|
|
|
const session = JSON.parse(fs.readFileSync(SESSION_FILE, 'utf-8'));
|
|
const duration = Date.now() - new Date(session.startedAt).getTime();
|
|
|
|
console.log(`Session: ${session.id}`);
|
|
console.log(`Started: ${session.startedAt}`);
|
|
console.log(`Duration: ${Math.round(duration / 1000 / 60)} minutes`);
|
|
console.log(`Metrics: ${JSON.stringify(session.metrics)}`);
|
|
|
|
return session;
|
|
},
|
|
|
|
update: (key, value) => {
|
|
if (!fs.existsSync(SESSION_FILE)) {
|
|
console.log('No active session');
|
|
return null;
|
|
}
|
|
|
|
const session = JSON.parse(fs.readFileSync(SESSION_FILE, 'utf-8'));
|
|
session.context[key] = value;
|
|
session.updatedAt = new Date().toISOString();
|
|
fs.writeFileSync(SESSION_FILE, JSON.stringify(session, null, 2));
|
|
|
|
return session;
|
|
},
|
|
|
|
get: (key) => {
|
|
if (!fs.existsSync(SESSION_FILE)) return null;
|
|
try {
|
|
const session = JSON.parse(fs.readFileSync(SESSION_FILE, 'utf-8'));
|
|
return key ? (session.context || {})[key] : session.context;
|
|
} catch { return null; }
|
|
},
|
|
|
|
metric: (name) => {
|
|
if (!fs.existsSync(SESSION_FILE)) {
|
|
return null;
|
|
}
|
|
|
|
const session = JSON.parse(fs.readFileSync(SESSION_FILE, 'utf-8'));
|
|
if (session.metrics[name] !== undefined) {
|
|
session.metrics[name]++;
|
|
fs.writeFileSync(SESSION_FILE, JSON.stringify(session, null, 2));
|
|
}
|
|
|
|
return session;
|
|
},
|
|
};
|
|
|
|
// CLI
|
|
const [,, command, ...args] = process.argv;
|
|
|
|
if (command && commands[command]) {
|
|
commands[command](...args);
|
|
} else {
|
|
console.log('Usage: session.js <start|restore|end|status|update|metric> [args]');
|
|
}
|
|
|
|
module.exports = commands;
|