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