@stackmemoryai/stackmemory 0.2.4 → 0.2.6
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/README.md +108 -0
- package/dist/index.js +382 -0
- package/dist/src/analytics/api/analytics-api.d.ts +24 -0
- package/dist/src/analytics/api/analytics-api.d.ts.map +1 -0
- package/dist/src/analytics/api/analytics-api.js +279 -0
- package/dist/src/analytics/api/analytics-api.js.map +1 -0
- package/dist/src/analytics/core/analytics-service.d.ts +23 -0
- package/dist/src/analytics/core/analytics-service.d.ts.map +1 -0
- package/dist/src/analytics/core/analytics-service.js +160 -0
- package/dist/src/analytics/core/analytics-service.js.map +1 -0
- package/dist/src/analytics/index.d.ts +12 -0
- package/dist/src/analytics/index.d.ts.map +1 -0
- package/dist/src/analytics/index.js +11 -0
- package/dist/src/analytics/index.js.map +1 -0
- package/dist/src/analytics/queries/metrics-queries.d.ts +11 -0
- package/dist/src/analytics/queries/metrics-queries.d.ts.map +1 -0
- package/dist/src/analytics/queries/metrics-queries.js +179 -0
- package/dist/src/analytics/queries/metrics-queries.js.map +1 -0
- package/dist/src/analytics/types/metrics.d.ts +60 -0
- package/dist/src/analytics/types/metrics.d.ts.map +1 -0
- package/dist/src/analytics/types/metrics.js +2 -0
- package/dist/src/analytics/types/metrics.js.map +1 -0
- package/dist/src/cli/analytics-viewer.d.ts +3 -0
- package/dist/src/cli/analytics-viewer.d.ts.map +1 -0
- package/dist/src/cli/analytics-viewer.js +89 -0
- package/dist/src/cli/analytics-viewer.js.map +1 -0
- package/dist/src/cli/browser-test.d.ts +6 -0
- package/dist/src/cli/browser-test.d.ts.map +1 -0
- package/dist/src/cli/browser-test.js +32 -0
- package/dist/src/cli/browser-test.js.map +1 -0
- package/dist/src/cli/cli.js +157 -0
- package/dist/src/cli/cli.js.map +1 -1
- package/dist/src/cli/commands/projects.d.ts +8 -0
- package/dist/src/cli/commands/projects.d.ts.map +1 -0
- package/dist/src/cli/commands/projects.js +220 -0
- package/dist/src/cli/commands/projects.js.map +1 -0
- package/dist/src/cli/index.d.ts +7 -0
- package/dist/src/cli/index.d.ts.map +1 -0
- package/dist/src/cli/index.js +704 -0
- package/dist/src/cli/index.js.map +1 -0
- package/dist/src/cli/project-commands.d.ts +8 -0
- package/dist/src/cli/project-commands.d.ts.map +1 -0
- package/dist/src/cli/project-commands.js +212 -0
- package/dist/src/cli/project-commands.js.map +1 -0
- package/dist/src/cli/utils/viewer.d.ts +3 -0
- package/dist/src/cli/utils/viewer.d.ts.map +1 -0
- package/dist/src/cli/utils/viewer.js +89 -0
- package/dist/src/cli/utils/viewer.js.map +1 -0
- package/dist/src/core/context/frame-manager.d.ts +106 -0
- package/dist/src/core/context/frame-manager.d.ts.map +1 -0
- package/dist/src/core/context/frame-manager.js +387 -0
- package/dist/src/core/context/frame-manager.js.map +1 -0
- package/dist/src/core/logger.test.js +1 -1
- package/dist/src/core/logger.test.js.map +1 -1
- package/dist/src/core/monitoring/error-handler.d.ts +46 -0
- package/dist/src/core/monitoring/error-handler.d.ts.map +1 -0
- package/dist/src/core/monitoring/error-handler.js +212 -0
- package/dist/src/core/monitoring/error-handler.js.map +1 -0
- package/dist/src/core/monitoring/logger.d.ts +24 -0
- package/dist/src/core/monitoring/logger.d.ts.map +1 -0
- package/dist/src/core/monitoring/logger.js +121 -0
- package/dist/src/core/monitoring/logger.js.map +1 -0
- package/dist/src/core/monitoring/metrics.d.ts +7 -0
- package/dist/src/core/monitoring/metrics.d.ts.map +1 -0
- package/dist/src/core/monitoring/metrics.js +13 -0
- package/dist/src/core/monitoring/metrics.js.map +1 -0
- package/dist/src/core/monitoring/progress-tracker.d.ts +95 -0
- package/dist/src/core/monitoring/progress-tracker.d.ts.map +1 -0
- package/dist/src/core/monitoring/progress-tracker.js +178 -0
- package/dist/src/core/monitoring/progress-tracker.js.map +1 -0
- package/dist/src/core/project-manager.d.ts +130 -0
- package/dist/src/core/project-manager.d.ts.map +1 -0
- package/dist/src/core/project-manager.js +582 -0
- package/dist/src/core/project-manager.js.map +1 -0
- package/dist/src/core/projects/project-manager.d.ts +130 -0
- package/dist/src/core/projects/project-manager.d.ts.map +1 -0
- package/dist/src/core/projects/project-manager.js +591 -0
- package/dist/src/core/projects/project-manager.js.map +1 -0
- package/dist/src/core/utils/update-checker.d.ts +38 -0
- package/dist/src/core/utils/update-checker.d.ts.map +1 -0
- package/dist/src/core/utils/update-checker.js +156 -0
- package/dist/src/core/utils/update-checker.js.map +1 -0
- package/dist/src/features/analytics/api/analytics-api.d.ts +24 -0
- package/dist/src/features/analytics/api/analytics-api.d.ts.map +1 -0
- package/dist/src/features/analytics/api/analytics-api.js +289 -0
- package/dist/src/features/analytics/api/analytics-api.js.map +1 -0
- package/dist/src/features/analytics/core/analytics-service.d.ts +23 -0
- package/dist/src/features/analytics/core/analytics-service.d.ts.map +1 -0
- package/dist/src/features/analytics/core/analytics-service.js +160 -0
- package/dist/src/features/analytics/core/analytics-service.js.map +1 -0
- package/dist/src/features/analytics/index.d.ts +12 -0
- package/dist/src/features/analytics/index.d.ts.map +1 -0
- package/dist/src/features/analytics/index.js +11 -0
- package/dist/src/features/analytics/index.js.map +1 -0
- package/dist/src/features/analytics/queries/metrics-queries.d.ts +11 -0
- package/dist/src/features/analytics/queries/metrics-queries.d.ts.map +1 -0
- package/dist/src/features/analytics/queries/metrics-queries.js +183 -0
- package/dist/src/features/analytics/queries/metrics-queries.js.map +1 -0
- package/dist/src/features/analytics/types/metrics.d.ts +60 -0
- package/dist/src/features/analytics/types/metrics.d.ts.map +1 -0
- package/dist/src/features/analytics/types/metrics.js +2 -0
- package/dist/src/features/analytics/types/metrics.js.map +1 -0
- package/dist/src/features/browser/browser-mcp.d.ts +94 -0
- package/dist/src/features/browser/browser-mcp.d.ts.map +1 -0
- package/dist/src/features/browser/browser-mcp.js +456 -0
- package/dist/src/features/browser/browser-mcp.js.map +1 -0
- package/dist/src/features/tasks/pebbles-task-store.d.ts +117 -0
- package/dist/src/features/tasks/pebbles-task-store.d.ts.map +1 -0
- package/dist/src/features/tasks/pebbles-task-store.js +335 -0
- package/dist/src/features/tasks/pebbles-task-store.js.map +1 -0
- package/dist/src/features/tasks/task-aware-context.d.ts +103 -0
- package/dist/src/features/tasks/task-aware-context.d.ts.map +1 -0
- package/dist/src/features/tasks/task-aware-context.js +412 -0
- package/dist/src/features/tasks/task-aware-context.js.map +1 -0
- package/dist/src/index.d.ts +4 -4
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +4 -4
- package/dist/src/index.js.map +1 -1
- package/dist/src/integrations/browser-mcp.d.ts +94 -0
- package/dist/src/integrations/browser-mcp.d.ts.map +1 -0
- package/dist/src/integrations/browser-mcp.js +431 -0
- package/dist/src/integrations/browser-mcp.js.map +1 -0
- package/dist/src/integrations/linear/auth.d.ts +99 -0
- package/dist/src/integrations/linear/auth.d.ts.map +1 -0
- package/dist/src/integrations/linear/auth.js +319 -0
- package/dist/src/integrations/linear/auth.js.map +1 -0
- package/dist/src/integrations/linear/auto-sync.d.ts +77 -0
- package/dist/src/integrations/linear/auto-sync.d.ts.map +1 -0
- package/dist/src/integrations/linear/auto-sync.js +268 -0
- package/dist/src/integrations/linear/auto-sync.js.map +1 -0
- package/dist/src/integrations/linear/client.d.ts +86 -0
- package/dist/src/integrations/linear/client.d.ts.map +1 -0
- package/dist/src/integrations/linear/client.js +277 -0
- package/dist/src/integrations/linear/client.js.map +1 -0
- package/dist/src/integrations/linear/config.d.ts +51 -0
- package/dist/src/integrations/linear/config.d.ts.map +1 -0
- package/dist/src/integrations/linear/config.js +103 -0
- package/dist/src/integrations/linear/config.js.map +1 -0
- package/dist/src/integrations/linear/sync.d.ts +97 -0
- package/dist/src/integrations/linear/sync.d.ts.map +1 -0
- package/dist/src/integrations/linear/sync.js +391 -0
- package/dist/src/integrations/linear/sync.js.map +1 -0
- package/dist/src/integrations/mcp/server.d.ts +40 -0
- package/dist/src/integrations/mcp/server.d.ts.map +1 -0
- package/dist/src/integrations/mcp/server.js +828 -0
- package/dist/src/integrations/mcp/server.js.map +1 -0
- package/dist/src/mcp/mcp-server.d.ts +1 -0
- package/dist/src/mcp/mcp-server.d.ts.map +1 -1
- package/dist/src/mcp/mcp-server.js +11 -0
- package/dist/src/mcp/mcp-server.js.map +1 -1
- package/dist/src/railway/index.d.ts +7 -0
- package/dist/src/railway/index.d.ts.map +1 -0
- package/dist/src/railway/index.js +401 -0
- package/dist/src/railway/index.js.map +1 -0
- package/dist/src/runway/auth/auth-middleware.d.ts +66 -0
- package/dist/src/runway/auth/auth-middleware.d.ts.map +1 -0
- package/dist/src/runway/auth/auth-middleware.js +337 -0
- package/dist/src/runway/auth/auth-middleware.js.map +1 -0
- package/dist/src/runway/server/runway-mcp-server.d.ts +46 -0
- package/dist/src/runway/server/runway-mcp-server.d.ts.map +1 -0
- package/dist/src/runway/server/runway-mcp-server.js +601 -0
- package/dist/src/runway/server/runway-mcp-server.js.map +1 -0
- package/dist/src/runway.bak/auth/auth-middleware.d.ts +66 -0
- package/dist/src/runway.bak/auth/auth-middleware.d.ts.map +1 -0
- package/dist/src/runway.bak/auth/auth-middleware.js +337 -0
- package/dist/src/runway.bak/auth/auth-middleware.js.map +1 -0
- package/dist/src/runway.bak/server/runway-mcp-server.d.ts +46 -0
- package/dist/src/runway.bak/server/runway-mcp-server.d.ts.map +1 -0
- package/dist/src/runway.bak/server/runway-mcp-server.js +601 -0
- package/dist/src/runway.bak/server/runway-mcp-server.js.map +1 -0
- package/dist/src/servers/production/auth-middleware.d.ts +66 -0
- package/dist/src/servers/production/auth-middleware.d.ts.map +1 -0
- package/dist/src/servers/production/auth-middleware.js +346 -0
- package/dist/src/servers/production/auth-middleware.js.map +1 -0
- package/dist/src/servers/railway/index.d.ts +7 -0
- package/dist/src/servers/railway/index.d.ts.map +1 -0
- package/dist/src/servers/railway/index.js +401 -0
- package/dist/src/servers/railway/index.js.map +1 -0
- package/package.json +27 -5
|
@@ -0,0 +1,582 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Automatic Project Management for StackMemory
|
|
3
|
+
* Auto-detects and organizes projects based on Git origins
|
|
4
|
+
*/
|
|
5
|
+
import { execSync } from 'child_process';
|
|
6
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';
|
|
7
|
+
import { join, basename, dirname } from 'path';
|
|
8
|
+
import { homedir } from 'os';
|
|
9
|
+
import Database from 'better-sqlite3';
|
|
10
|
+
import { logger } from './logger.js';
|
|
11
|
+
export class ProjectManager {
|
|
12
|
+
static instance;
|
|
13
|
+
db;
|
|
14
|
+
configPath;
|
|
15
|
+
organizations = new Map();
|
|
16
|
+
projectCache = new Map();
|
|
17
|
+
currentProject;
|
|
18
|
+
constructor() {
|
|
19
|
+
this.configPath = join(homedir(), '.stackmemory');
|
|
20
|
+
this.ensureDirectoryStructure();
|
|
21
|
+
this.initializeDatabase();
|
|
22
|
+
this.loadOrganizations();
|
|
23
|
+
this.autoDiscoverOrganizations();
|
|
24
|
+
}
|
|
25
|
+
static getInstance() {
|
|
26
|
+
if (!ProjectManager.instance) {
|
|
27
|
+
ProjectManager.instance = new ProjectManager();
|
|
28
|
+
}
|
|
29
|
+
return ProjectManager.instance;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Auto-detect project from current directory
|
|
33
|
+
*/
|
|
34
|
+
async detectProject(projectPath) {
|
|
35
|
+
const path = projectPath || process.cwd();
|
|
36
|
+
// Check cache first
|
|
37
|
+
const cached = this.projectCache.get(path);
|
|
38
|
+
if (cached && this.isCacheValid(cached)) {
|
|
39
|
+
return cached;
|
|
40
|
+
}
|
|
41
|
+
const project = await this.analyzeProject(path);
|
|
42
|
+
// Auto-categorize based on git origin
|
|
43
|
+
if (project.gitRemote) {
|
|
44
|
+
project.organization = this.extractOrganization(project.gitRemote);
|
|
45
|
+
project.accountType = this.determineAccountType(project.gitRemote, project.organization);
|
|
46
|
+
project.isPrivate = this.isPrivateRepo(project.gitRemote);
|
|
47
|
+
}
|
|
48
|
+
// Detect framework and language
|
|
49
|
+
project.primaryLanguage = this.detectPrimaryLanguage(path);
|
|
50
|
+
project.framework = this.detectFramework(path);
|
|
51
|
+
// Store in database
|
|
52
|
+
this.saveProject(project);
|
|
53
|
+
this.projectCache.set(path, project);
|
|
54
|
+
this.currentProject = project;
|
|
55
|
+
logger.info('Project auto-detected', {
|
|
56
|
+
id: project.id,
|
|
57
|
+
org: project.organization,
|
|
58
|
+
type: project.accountType
|
|
59
|
+
});
|
|
60
|
+
return project;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Analyze project directory
|
|
64
|
+
*/
|
|
65
|
+
async analyzeProject(projectPath) {
|
|
66
|
+
const gitInfo = this.getGitInfo(projectPath);
|
|
67
|
+
const projectName = gitInfo.name || basename(projectPath);
|
|
68
|
+
return {
|
|
69
|
+
id: this.generateProjectId(gitInfo.remote || projectPath),
|
|
70
|
+
name: projectName,
|
|
71
|
+
path: projectPath,
|
|
72
|
+
gitRemote: gitInfo.remote,
|
|
73
|
+
organization: undefined,
|
|
74
|
+
accountType: 'personal',
|
|
75
|
+
isPrivate: false,
|
|
76
|
+
lastAccessed: new Date(),
|
|
77
|
+
metadata: {
|
|
78
|
+
branch: gitInfo.branch,
|
|
79
|
+
lastCommit: gitInfo.lastCommit,
|
|
80
|
+
isDirty: gitInfo.isDirty
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Extract Git information
|
|
86
|
+
*/
|
|
87
|
+
getGitInfo(projectPath) {
|
|
88
|
+
const info = {};
|
|
89
|
+
try {
|
|
90
|
+
// Get remote origin
|
|
91
|
+
info.remote = execSync('git config --get remote.origin.url', {
|
|
92
|
+
cwd: projectPath,
|
|
93
|
+
encoding: 'utf-8'
|
|
94
|
+
}).trim();
|
|
95
|
+
// Get current branch
|
|
96
|
+
info.branch = execSync('git branch --show-current', {
|
|
97
|
+
cwd: projectPath,
|
|
98
|
+
encoding: 'utf-8'
|
|
99
|
+
}).trim();
|
|
100
|
+
// Get last commit
|
|
101
|
+
info.lastCommit = execSync('git log -1 --format=%H', {
|
|
102
|
+
cwd: projectPath,
|
|
103
|
+
encoding: 'utf-8'
|
|
104
|
+
}).trim();
|
|
105
|
+
// Check if working tree is dirty
|
|
106
|
+
const status = execSync('git status --porcelain', {
|
|
107
|
+
cwd: projectPath,
|
|
108
|
+
encoding: 'utf-8'
|
|
109
|
+
});
|
|
110
|
+
info.isDirty = status.length > 0;
|
|
111
|
+
// Extract project name from remote
|
|
112
|
+
const match = info.remote.match(/\/([^\/]+?)(\.git)?$/);
|
|
113
|
+
info.name = match ? match[1] : basename(projectPath);
|
|
114
|
+
}
|
|
115
|
+
catch (error) {
|
|
116
|
+
// Not a git repository or git not available
|
|
117
|
+
info.name = basename(projectPath);
|
|
118
|
+
}
|
|
119
|
+
return info;
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Extract organization from Git remote
|
|
123
|
+
*/
|
|
124
|
+
extractOrganization(gitRemote) {
|
|
125
|
+
// GitHub: git@github.com:org/repo.git or https://github.com/org/repo
|
|
126
|
+
const githubMatch = gitRemote.match(/github\.com[:/]([^/]+)\//);
|
|
127
|
+
if (githubMatch)
|
|
128
|
+
return githubMatch[1];
|
|
129
|
+
// GitLab: git@gitlab.com:org/repo.git
|
|
130
|
+
const gitlabMatch = gitRemote.match(/gitlab\.com[:/]([^/]+)\//);
|
|
131
|
+
if (gitlabMatch)
|
|
132
|
+
return gitlabMatch[1];
|
|
133
|
+
// Bitbucket: git@bitbucket.org:org/repo.git
|
|
134
|
+
const bitbucketMatch = gitRemote.match(/bitbucket\.org[:/]([^/]+)\//);
|
|
135
|
+
if (bitbucketMatch)
|
|
136
|
+
return bitbucketMatch[1];
|
|
137
|
+
// Custom domain: git@git.company.com:team/repo.git
|
|
138
|
+
const customMatch = gitRemote.match(/@([^:]+)[:/]([^/]+)\//);
|
|
139
|
+
if (customMatch)
|
|
140
|
+
return customMatch[2];
|
|
141
|
+
return 'unknown';
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Determine account type based on patterns
|
|
145
|
+
*/
|
|
146
|
+
determineAccountType(gitRemote, organization) {
|
|
147
|
+
// Check against known organizations
|
|
148
|
+
for (const [, org] of this.organizations) {
|
|
149
|
+
if (org.githubOrgs.includes(organization || '')) {
|
|
150
|
+
return org.accountType;
|
|
151
|
+
}
|
|
152
|
+
// Check if remote matches any known domain
|
|
153
|
+
for (const domain of org.domains) {
|
|
154
|
+
if (gitRemote.includes(domain)) {
|
|
155
|
+
return org.accountType;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
// Auto-detection heuristics
|
|
160
|
+
if (organization) {
|
|
161
|
+
// Common work patterns
|
|
162
|
+
if (organization.includes('corp') || organization.includes('company') ||
|
|
163
|
+
organization.includes('team') || organization.includes('work')) {
|
|
164
|
+
return 'work';
|
|
165
|
+
}
|
|
166
|
+
// Common opensource patterns
|
|
167
|
+
if (organization.includes('apache') || organization.includes('mozilla') ||
|
|
168
|
+
organization.includes('foundation') || gitRemote.includes('gitlab.freedesktop')) {
|
|
169
|
+
return 'opensource';
|
|
170
|
+
}
|
|
171
|
+
// Check if it's the user's own org
|
|
172
|
+
const username = this.getCurrentGitUser();
|
|
173
|
+
if (username && organization.toLowerCase() === username.toLowerCase()) {
|
|
174
|
+
return 'personal';
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
// Check if it's a private repo (likely work or personal)
|
|
178
|
+
if (this.isPrivateRepo(gitRemote)) {
|
|
179
|
+
// Use additional heuristics
|
|
180
|
+
const currentPath = process.cwd();
|
|
181
|
+
if (currentPath.includes('/work/') || currentPath.includes('/Work/') ||
|
|
182
|
+
currentPath.includes('/company/') || currentPath.includes('/job/')) {
|
|
183
|
+
return 'work';
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
return 'personal';
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* Check if repository is private
|
|
190
|
+
*/
|
|
191
|
+
isPrivateRepo(gitRemote) {
|
|
192
|
+
// SSH URLs are typically private
|
|
193
|
+
if (gitRemote.startsWith('git@')) {
|
|
194
|
+
return true;
|
|
195
|
+
}
|
|
196
|
+
// HTTPS with credentials
|
|
197
|
+
if (gitRemote.includes('@')) {
|
|
198
|
+
return true;
|
|
199
|
+
}
|
|
200
|
+
// Try to check GitHub API (requires authentication for private repos)
|
|
201
|
+
// This is a simplified check
|
|
202
|
+
return false;
|
|
203
|
+
}
|
|
204
|
+
/**
|
|
205
|
+
* Detect primary programming language
|
|
206
|
+
*/
|
|
207
|
+
detectPrimaryLanguage(projectPath) {
|
|
208
|
+
const checks = [
|
|
209
|
+
{ file: 'package.json', language: 'JavaScript/TypeScript' },
|
|
210
|
+
{ file: 'Cargo.toml', language: 'Rust' },
|
|
211
|
+
{ file: 'go.mod', language: 'Go' },
|
|
212
|
+
{ file: 'pom.xml', language: 'Java' },
|
|
213
|
+
{ file: 'requirements.txt', language: 'Python' },
|
|
214
|
+
{ file: 'Gemfile', language: 'Ruby' },
|
|
215
|
+
{ file: 'composer.json', language: 'PHP' },
|
|
216
|
+
{ file: '*.csproj', language: 'C#' },
|
|
217
|
+
{ file: 'Podfile', language: 'Swift/Objective-C' }
|
|
218
|
+
];
|
|
219
|
+
for (const check of checks) {
|
|
220
|
+
if (check.file.includes('*')) {
|
|
221
|
+
// Glob pattern
|
|
222
|
+
try {
|
|
223
|
+
const files = execSync(`find ${projectPath} -maxdepth 2 -name "${check.file}" 2>/dev/null`, {
|
|
224
|
+
encoding: 'utf-8'
|
|
225
|
+
});
|
|
226
|
+
if (files.trim())
|
|
227
|
+
return check.language;
|
|
228
|
+
}
|
|
229
|
+
catch { }
|
|
230
|
+
}
|
|
231
|
+
else if (existsSync(join(projectPath, check.file))) {
|
|
232
|
+
return check.language;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
return undefined;
|
|
236
|
+
}
|
|
237
|
+
/**
|
|
238
|
+
* Detect framework
|
|
239
|
+
*/
|
|
240
|
+
detectFramework(projectPath) {
|
|
241
|
+
const packageJsonPath = join(projectPath, 'package.json');
|
|
242
|
+
if (existsSync(packageJsonPath)) {
|
|
243
|
+
try {
|
|
244
|
+
const pkg = JSON.parse(readFileSync(packageJsonPath, 'utf-8'));
|
|
245
|
+
const deps = { ...pkg.dependencies, ...pkg.devDependencies };
|
|
246
|
+
// Check for common frameworks
|
|
247
|
+
if (deps['next'])
|
|
248
|
+
return 'Next.js';
|
|
249
|
+
if (deps['react'])
|
|
250
|
+
return 'React';
|
|
251
|
+
if (deps['vue'])
|
|
252
|
+
return 'Vue';
|
|
253
|
+
if (deps['@angular/core'])
|
|
254
|
+
return 'Angular';
|
|
255
|
+
if (deps['express'])
|
|
256
|
+
return 'Express';
|
|
257
|
+
if (deps['fastify'])
|
|
258
|
+
return 'Fastify';
|
|
259
|
+
if (deps['@nestjs/core'])
|
|
260
|
+
return 'NestJS';
|
|
261
|
+
}
|
|
262
|
+
catch { }
|
|
263
|
+
}
|
|
264
|
+
// Check for other framework indicators
|
|
265
|
+
if (existsSync(join(projectPath, 'Cargo.toml'))) {
|
|
266
|
+
const cargo = readFileSync(join(projectPath, 'Cargo.toml'), 'utf-8');
|
|
267
|
+
if (cargo.includes('actix-web'))
|
|
268
|
+
return 'Actix';
|
|
269
|
+
if (cargo.includes('rocket'))
|
|
270
|
+
return 'Rocket';
|
|
271
|
+
}
|
|
272
|
+
return undefined;
|
|
273
|
+
}
|
|
274
|
+
/**
|
|
275
|
+
* Get current Git user
|
|
276
|
+
*/
|
|
277
|
+
getCurrentGitUser() {
|
|
278
|
+
try {
|
|
279
|
+
const email = execSync('git config --global user.email', {
|
|
280
|
+
encoding: 'utf-8'
|
|
281
|
+
}).trim();
|
|
282
|
+
const username = email.split('@')[0];
|
|
283
|
+
return username;
|
|
284
|
+
}
|
|
285
|
+
catch {
|
|
286
|
+
return undefined;
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
/**
|
|
290
|
+
* Generate unique project ID
|
|
291
|
+
*/
|
|
292
|
+
generateProjectId(identifier) {
|
|
293
|
+
// Create a stable ID from the git remote or path
|
|
294
|
+
const cleaned = identifier
|
|
295
|
+
.replace(/\.git$/, '')
|
|
296
|
+
.replace(/[^a-zA-Z0-9-]/g, '-')
|
|
297
|
+
.toLowerCase();
|
|
298
|
+
return cleaned.substring(cleaned.length - 50); // Last 50 chars
|
|
299
|
+
}
|
|
300
|
+
/**
|
|
301
|
+
* Initialize database
|
|
302
|
+
*/
|
|
303
|
+
initializeDatabase() {
|
|
304
|
+
const dbPath = join(this.configPath, 'projects.db');
|
|
305
|
+
this.db = new Database(dbPath);
|
|
306
|
+
this.db.exec(`
|
|
307
|
+
CREATE TABLE IF NOT EXISTS projects (
|
|
308
|
+
id TEXT PRIMARY KEY,
|
|
309
|
+
name TEXT NOT NULL,
|
|
310
|
+
path TEXT NOT NULL UNIQUE,
|
|
311
|
+
git_remote TEXT,
|
|
312
|
+
organization TEXT,
|
|
313
|
+
account_type TEXT,
|
|
314
|
+
is_private BOOLEAN,
|
|
315
|
+
primary_language TEXT,
|
|
316
|
+
framework TEXT,
|
|
317
|
+
last_accessed DATETIME,
|
|
318
|
+
metadata JSON,
|
|
319
|
+
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
|
320
|
+
updated_at DATETIME DEFAULT CURRENT_TIMESTAMP
|
|
321
|
+
);
|
|
322
|
+
|
|
323
|
+
CREATE TABLE IF NOT EXISTS organizations (
|
|
324
|
+
name TEXT PRIMARY KEY,
|
|
325
|
+
type TEXT,
|
|
326
|
+
account_type TEXT,
|
|
327
|
+
config JSON,
|
|
328
|
+
created_at DATETIME DEFAULT CURRENT_TIMESTAMP
|
|
329
|
+
);
|
|
330
|
+
|
|
331
|
+
CREATE TABLE IF NOT EXISTS project_contexts (
|
|
332
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
333
|
+
project_id TEXT NOT NULL,
|
|
334
|
+
context_type TEXT,
|
|
335
|
+
content TEXT,
|
|
336
|
+
metadata JSON,
|
|
337
|
+
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
|
338
|
+
FOREIGN KEY (project_id) REFERENCES projects(id)
|
|
339
|
+
);
|
|
340
|
+
|
|
341
|
+
CREATE INDEX IF NOT EXISTS idx_projects_org ON projects(organization);
|
|
342
|
+
CREATE INDEX IF NOT EXISTS idx_projects_type ON projects(account_type);
|
|
343
|
+
CREATE INDEX IF NOT EXISTS idx_contexts_project ON project_contexts(project_id);
|
|
344
|
+
`);
|
|
345
|
+
}
|
|
346
|
+
/**
|
|
347
|
+
* Save project to database
|
|
348
|
+
*/
|
|
349
|
+
saveProject(project) {
|
|
350
|
+
const stmt = this.db.prepare(`
|
|
351
|
+
INSERT OR REPLACE INTO projects
|
|
352
|
+
(id, name, path, git_remote, organization, account_type, is_private,
|
|
353
|
+
primary_language, framework, last_accessed, metadata, updated_at)
|
|
354
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, CURRENT_TIMESTAMP)
|
|
355
|
+
`);
|
|
356
|
+
stmt.run(project.id, project.name, project.path, project.gitRemote, project.organization, project.accountType, project.isPrivate ? 1 : 0, project.primaryLanguage, project.framework, project.lastAccessed.toISOString(), JSON.stringify(project.metadata));
|
|
357
|
+
}
|
|
358
|
+
/**
|
|
359
|
+
* Load organizations configuration
|
|
360
|
+
*/
|
|
361
|
+
loadOrganizations() {
|
|
362
|
+
const configFile = join(this.configPath, 'organizations.json');
|
|
363
|
+
if (existsSync(configFile)) {
|
|
364
|
+
try {
|
|
365
|
+
const config = JSON.parse(readFileSync(configFile, 'utf-8'));
|
|
366
|
+
for (const org of config.organizations || []) {
|
|
367
|
+
this.organizations.set(org.name, org);
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
catch (error) {
|
|
371
|
+
logger.error('Failed to load organizations config', error);
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
/**
|
|
376
|
+
* Auto-discover organizations from existing projects
|
|
377
|
+
*/
|
|
378
|
+
autoDiscoverOrganizations() {
|
|
379
|
+
try {
|
|
380
|
+
const stmt = this.db.prepare(`
|
|
381
|
+
SELECT DISTINCT organization, account_type, COUNT(*) as project_count
|
|
382
|
+
FROM projects
|
|
383
|
+
WHERE organization IS NOT NULL
|
|
384
|
+
GROUP BY organization, account_type
|
|
385
|
+
`);
|
|
386
|
+
const orgs = stmt.all();
|
|
387
|
+
for (const org of orgs) {
|
|
388
|
+
if (!this.organizations.has(org.organization)) {
|
|
389
|
+
// Auto-create organization config
|
|
390
|
+
this.organizations.set(org.organization, {
|
|
391
|
+
name: org.organization,
|
|
392
|
+
type: org.account_type === 'work' ? 'company' : 'personal',
|
|
393
|
+
domains: [],
|
|
394
|
+
githubOrgs: [org.organization],
|
|
395
|
+
accountType: org.account_type,
|
|
396
|
+
autoPatterns: []
|
|
397
|
+
});
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
catch (error) {
|
|
402
|
+
logger.error('Failed to auto-discover organizations', error);
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
/**
|
|
406
|
+
* Ensure directory structure exists
|
|
407
|
+
*/
|
|
408
|
+
ensureDirectoryStructure() {
|
|
409
|
+
const dirs = [
|
|
410
|
+
this.configPath,
|
|
411
|
+
join(this.configPath, 'accounts'),
|
|
412
|
+
join(this.configPath, 'accounts', 'personal'),
|
|
413
|
+
join(this.configPath, 'accounts', 'work'),
|
|
414
|
+
join(this.configPath, 'accounts', 'opensource'),
|
|
415
|
+
join(this.configPath, 'accounts', 'client'),
|
|
416
|
+
join(this.configPath, 'contexts'),
|
|
417
|
+
join(this.configPath, 'patterns')
|
|
418
|
+
];
|
|
419
|
+
for (const dir of dirs) {
|
|
420
|
+
if (!existsSync(dir)) {
|
|
421
|
+
mkdirSync(dir, { recursive: true });
|
|
422
|
+
}
|
|
423
|
+
}
|
|
424
|
+
}
|
|
425
|
+
/**
|
|
426
|
+
* Check if cache is still valid
|
|
427
|
+
*/
|
|
428
|
+
isCacheValid(project) {
|
|
429
|
+
const cacheAge = Date.now() - project.lastAccessed.getTime();
|
|
430
|
+
return cacheAge < 5 * 60 * 1000; // 5 minutes
|
|
431
|
+
}
|
|
432
|
+
/**
|
|
433
|
+
* Get all projects
|
|
434
|
+
*/
|
|
435
|
+
getAllProjects() {
|
|
436
|
+
const stmt = this.db.prepare(`
|
|
437
|
+
SELECT * FROM projects
|
|
438
|
+
ORDER BY last_accessed DESC
|
|
439
|
+
`);
|
|
440
|
+
const projects = stmt.all();
|
|
441
|
+
return projects.map(p => ({
|
|
442
|
+
...p,
|
|
443
|
+
isPrivate: p.is_private === 1,
|
|
444
|
+
lastAccessed: new Date(p.last_accessed),
|
|
445
|
+
metadata: JSON.parse(p.metadata || '{}')
|
|
446
|
+
}));
|
|
447
|
+
}
|
|
448
|
+
/**
|
|
449
|
+
* Get projects by organization
|
|
450
|
+
*/
|
|
451
|
+
getProjectsByOrganization(organization) {
|
|
452
|
+
const stmt = this.db.prepare(`
|
|
453
|
+
SELECT * FROM projects
|
|
454
|
+
WHERE organization = ?
|
|
455
|
+
ORDER BY last_accessed DESC
|
|
456
|
+
`);
|
|
457
|
+
const projects = stmt.all(organization);
|
|
458
|
+
return projects.map(p => ({
|
|
459
|
+
...p,
|
|
460
|
+
isPrivate: p.is_private === 1,
|
|
461
|
+
lastAccessed: new Date(p.last_accessed),
|
|
462
|
+
metadata: JSON.parse(p.metadata || '{}')
|
|
463
|
+
}));
|
|
464
|
+
}
|
|
465
|
+
/**
|
|
466
|
+
* Get projects by account type
|
|
467
|
+
*/
|
|
468
|
+
getProjectsByAccountType(accountType) {
|
|
469
|
+
const stmt = this.db.prepare(`
|
|
470
|
+
SELECT * FROM projects
|
|
471
|
+
WHERE account_type = ?
|
|
472
|
+
ORDER BY last_accessed DESC
|
|
473
|
+
`);
|
|
474
|
+
const projects = stmt.all(accountType);
|
|
475
|
+
return projects.map(p => ({
|
|
476
|
+
...p,
|
|
477
|
+
isPrivate: p.is_private === 1,
|
|
478
|
+
lastAccessed: new Date(p.last_accessed),
|
|
479
|
+
metadata: JSON.parse(p.metadata || '{}')
|
|
480
|
+
}));
|
|
481
|
+
}
|
|
482
|
+
/**
|
|
483
|
+
* Get current project
|
|
484
|
+
*/
|
|
485
|
+
getCurrentProject() {
|
|
486
|
+
if (!this.currentProject) {
|
|
487
|
+
this.detectProject();
|
|
488
|
+
}
|
|
489
|
+
return this.currentProject;
|
|
490
|
+
}
|
|
491
|
+
/**
|
|
492
|
+
* Save organization config
|
|
493
|
+
*/
|
|
494
|
+
saveOrganization(org) {
|
|
495
|
+
this.organizations.set(org.name, org);
|
|
496
|
+
// Save to file
|
|
497
|
+
const configFile = join(this.configPath, 'organizations.json');
|
|
498
|
+
const config = {
|
|
499
|
+
organizations: Array.from(this.organizations.values())
|
|
500
|
+
};
|
|
501
|
+
writeFileSync(configFile, JSON.stringify(config, null, 2));
|
|
502
|
+
// Save to database
|
|
503
|
+
const stmt = this.db.prepare(`
|
|
504
|
+
INSERT OR REPLACE INTO organizations (name, type, account_type, config)
|
|
505
|
+
VALUES (?, ?, ?, ?)
|
|
506
|
+
`);
|
|
507
|
+
stmt.run(org.name, org.type, org.accountType, JSON.stringify(org));
|
|
508
|
+
}
|
|
509
|
+
/**
|
|
510
|
+
* Auto-categorize all Git repositories in home directory
|
|
511
|
+
*/
|
|
512
|
+
async scanAndCategorizeAllProjects(basePaths) {
|
|
513
|
+
const paths = basePaths || [
|
|
514
|
+
join(homedir(), 'Dev'),
|
|
515
|
+
join(homedir(), 'dev'),
|
|
516
|
+
join(homedir(), 'Projects'),
|
|
517
|
+
join(homedir(), 'projects'),
|
|
518
|
+
join(homedir(), 'Work'),
|
|
519
|
+
join(homedir(), 'work'),
|
|
520
|
+
join(homedir(), 'Documents/GitHub'),
|
|
521
|
+
join(homedir(), 'code')
|
|
522
|
+
];
|
|
523
|
+
logger.info('Scanning for Git repositories...');
|
|
524
|
+
for (const basePath of paths) {
|
|
525
|
+
if (!existsSync(basePath))
|
|
526
|
+
continue;
|
|
527
|
+
try {
|
|
528
|
+
// Find all .git directories
|
|
529
|
+
const gitDirs = execSync(`find ${basePath} -type d -name .git -maxdepth 4 2>/dev/null`, { encoding: 'utf-8' }).trim().split('\n').filter(Boolean);
|
|
530
|
+
for (const gitDir of gitDirs) {
|
|
531
|
+
const projectPath = dirname(gitDir);
|
|
532
|
+
try {
|
|
533
|
+
await this.detectProject(projectPath);
|
|
534
|
+
logger.info(`Discovered project: ${projectPath}`);
|
|
535
|
+
}
|
|
536
|
+
catch (error) {
|
|
537
|
+
logger.warn(`Failed to analyze project: ${projectPath}`, error);
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
}
|
|
541
|
+
catch (error) {
|
|
542
|
+
logger.warn(`Failed to scan ${basePath}`, error);
|
|
543
|
+
}
|
|
544
|
+
}
|
|
545
|
+
logger.info(`Scan complete. Found ${this.projectCache.size} projects`);
|
|
546
|
+
}
|
|
547
|
+
/**
|
|
548
|
+
* Generate summary report
|
|
549
|
+
*/
|
|
550
|
+
generateReport() {
|
|
551
|
+
const allProjects = this.getAllProjects();
|
|
552
|
+
const report = {
|
|
553
|
+
total: allProjects.length,
|
|
554
|
+
byAccountType: {},
|
|
555
|
+
byOrganization: {},
|
|
556
|
+
byLanguage: {},
|
|
557
|
+
byFramework: {}
|
|
558
|
+
};
|
|
559
|
+
for (const project of allProjects) {
|
|
560
|
+
// Count by account type
|
|
561
|
+
report.byAccountType[project.accountType] =
|
|
562
|
+
(report.byAccountType[project.accountType] || 0) + 1;
|
|
563
|
+
// Count by organization
|
|
564
|
+
if (project.organization) {
|
|
565
|
+
report.byOrganization[project.organization] =
|
|
566
|
+
(report.byOrganization[project.organization] || 0) + 1;
|
|
567
|
+
}
|
|
568
|
+
// Count by language
|
|
569
|
+
if (project.primaryLanguage) {
|
|
570
|
+
report.byLanguage[project.primaryLanguage] =
|
|
571
|
+
(report.byLanguage[project.primaryLanguage] || 0) + 1;
|
|
572
|
+
}
|
|
573
|
+
// Count by framework
|
|
574
|
+
if (project.framework) {
|
|
575
|
+
report.byFramework[project.framework] =
|
|
576
|
+
(report.byFramework[project.framework] || 0) + 1;
|
|
577
|
+
}
|
|
578
|
+
}
|
|
579
|
+
return JSON.stringify(report, null, 2);
|
|
580
|
+
}
|
|
581
|
+
}
|
|
582
|
+
//# sourceMappingURL=project-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project-manager.js","sourceRoot":"","sources":["../../../src/core/project-manager.ts"],"names":[],"mappings":"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"}
|